社区
C语言
帖子详情
请教程序在内存存放的问题
lxb365
2006-06-26 10:06:50
我们知道,内存分为代码段,数据段,栈,堆,我想问,所谓栈区,是不是采用的数据结构里面的堆栈方式来存储局部变量,具体是如何存储的,我在编程的时候还遇到参数入栈的不同形式,比如_cdecl和_stdcall,请教相关知识。
...全文
256
4
打赏
收藏
请教程序在内存存放的问题
我们知道,内存分为代码段,数据段,栈,堆,我想问,所谓栈区,是不是采用的数据结构里面的堆栈方式来存储局部变量,具体是如何存储的,我在编程的时候还遇到参数入栈的不同形式,比如_cdecl和_stdcall,请教相关知识。
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
4 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
jixingzhong
2006-06-30
打赏
举报
回复
一篇 老文档:
函数调用约定有多种,这里简单说一下:
1、__stdcall调用约定相当于16位动态库中经常使用的PASCAL调用约定。在32位的VC++5.0中PASCAL调用约定不再被支持(实际上它已被定义为__stdcall。除了__pascal外,__fortran和__syscall也不被支持),取而代之的是__stdcall调用约定。两者实质上是一致的,即函数的参数自右向左通过栈传递,被调用的函数在返回前清理传送参数的内存栈,但不同的是函数名的修饰部分(关于函数名的修饰部分在后面将详细说明)。
_stdcall是Pascal程序的缺省调用方式,通常用于Win32 Api中,函数采用从右到左的压栈方式,自己在退出时清空堆栈。VC将函数编译后会在函数名前面加上下划线前缀,在函数名后加上"@"和参数的字节数。
2、C调用约定(即用__cdecl关键字说明)按从右至左的顺序压参数入栈,由调用者把参数弹出栈。对于传送参数的内存栈是由调用者来维护的(正因为如此,实现可变参数的函数只能使用该调用约定)。另外,在函数名修饰约定方面也有所不同。
_cdecl是C和C++程序的缺省调用方式。每一个调用它的函数都包含清空堆栈的代码,所以产生的可执行文件大小会比调用_stdcall函数的大。函数采用从右到左的压栈方式。VC将函数编译后会在函数名前面加上下划线前缀。是MFC缺省调用约定。
3、__fastcall调用约定是"人"如其名,它的主要特点就是快,因为它是通过寄存器来传送参数的(实际上,它用ECX和EDX传送前两个双字(DWORD)或更小的参数,剩下的参数仍旧自右向左压栈传送,被调用的函数在返回前清理传送参数的内存栈),在函数名修饰约定方面,它和前两者均不同。
_fastcall方式的函数采用寄存器传递参数,VC将函数编译后会在函数名前面加上"@"前缀,在函数名后加上"@"和参数的字节数。
4、thiscall仅仅应用于"C++"成员函数。this指针存放于CX寄存器,参数从右到左压。thiscall不是关键词,因此不能被程序员指定。
5、naked call采用1-4的调用约定时,如果必要的话,进入函数时编译器会产生代码来保存ESI,EDI,EBX,EBP寄存器,退出函数时则产生代码恢复这些寄存器的内容。
naked call不产生这样的代码。naked call不是类型修饰符,故必须和_declspec共同使用。
关键字 __stdcall、__cdecl和__fastcall可以直接加在要输出的函数前,也可以在编译环境的Setting...\C/C++ \Code Generation项选择。当加在输出函数前的关键字与编译环境中的选择不同时,直接加在输出函数前的关键字有效。它们对应的命令行参数分别为/Gz、/Gd和/Gr。缺省状态为/Gd,即__cdecl。
要完全模仿PASCAL调用约定首先必须使用__stdcall调用约定,至于函数名修饰约定,可以通过其它方法模仿。还有一个值得一提的是WINAPI宏,Windows.h支持该宏,它可以将出函数翻译成适当的调用约定,在WIN32中,它被定义为__stdcall。使用WINAPI宏可以创建自己的APIs
haha168_2002
2006-06-30
打赏
举报
回复
栈区,有编译器自动分配释放,存放函数的参数,局部变量等。操作方式类似于数据结构中的栈。
堆区,有程序员分配释放,例:malloc().与数据结构的堆是两回事,分配方式类似于链表。
全局区(静态区),存放全局变量和静态变量。初始化的在一起,未初始化的在另一块。程序结束后系统释放。
文字常量区,存放常量字符串。
程序代码区,存放函数体的二进制代码。
vssql2005
2006-06-26
打赏
举报
回复
这些问题要查看数据结构的书,以及多用VC++进行调试,查看的它的内存占用情况,栈区,在C++中是在内存区域,分划成了很多区域,来存取不同的变量,如:全量变量、局部变量、静态变量等等分别存在不同的区域。栈,就是数据结构中所指出的“后进先出”的数据存储结构。把计算机的软件书多看看。
gongzilv
2006-06-26
打赏
举报
回复
建议参考 看雪学院的《加密解密》里的PE文件格式。
作者段刚,电子工业出版社出版,网上有电子书。
游戏画面就弹出
内存
不能为read修复工具
出现这个现象有方面的,一是硬件,即
内存
方面有
问题
,二是软件,这就有多方面的
问题
了。 一:先说说硬件: 一般来说,电脑硬件是很不容易坏的。
内存
出现
问题
的可能性并不大(除非你的
内存
真的是杂牌的一塌徒地),主要方面是:1。
内存
条坏了(二手
内存
情况居多)、2。使用了有质量
问题
的
内存
,3。
内存
插在主板上的金手指部分灰尘太多。4。使用不同品牌不同容量的
内存
,从而出现不兼容的情况。5。超频带来的散热
问题
。你可以使用MemTest 这个软件来检测一下
内存
,它可以彻底的检测出
内存
的稳定度。 二、如果都没有,那就从软件方面排除故障了。 先说原理:
内存
有个
存放
数据的地方叫缓冲区,当
程序
把数据放在缓冲区,需要操作系统提供的“功能函数”来申请,如果
内存
分配成功,函数就会将所新开辟的
内存
区地址返回给应用
程序
,应用
程序
就可以通过这个地址使用这块
内存
。这就是“动态
内存
分配”,
内存
地址也就是编程中的“光标”。
内存
不是永远都招之即来、用之不尽的,有时候
内存
分配也会失败。当分配失败时系统函数会返回一个0值,这时返回值“0”已不表示新启用的光标,而是系统向应用
程序
发出的一个通知,告知出现了错误。作为应用
程序
,在每一次申请
内存
后都应该检查返回值是否为0,如果是,则意味着出现了故障,应该采取一些措施挽救,这就增强了
程序
的“健壮性”。若应用
程序
没有检查这个错误,它就会按照“思维惯性”认为这个值是给它分配的可用光标,继续在之后的执行中使用这块
内存
。真正的0地址
内存
区储存的是计算机系统中最重要的“中断描述符表”,绝对不允许应用
程序
使用。在没有保护机制的操作系统下(如DOS),写数据到这个地址会导致立即当机,而在健壮的操作系统中,如Windows等,这个操作会马上被系统的保护机制捕获,其结果就是由操作系统强行关闭出错的应用
程序
,以防止其错误扩大。这时候,就会出现上述的
内存
不能为“read”错误,并指出被引用的
内存
地址为“0x00000000“。
内存
分配失败故障的原因很多,
内存
不够、系统函数的版本不匹配等都可能有影响。因此,这种分配失败多见于操作系统使用很长时间后,安装了多种应用
程序
(包括无意中“安装”的病毒
程序
),更改了大量的系统参数和系统档案之后。 在使用动态分配的应用
程序
中,有时会有这样的情况出现:
程序
试图读写一块“应该可用”的
内存
,但不知为什么,这个预料中可用的光标已经失效了。有可能是 “忘记了”向操作系统要求分配,也可能是
程序
自己在某个时候已经注销了这块
内存
而“没有留意”等等。注销了的
内存
被系统回收,其访问权已经不属于该应用
程序
,因此读写操作也同样会触发系统的保护机制,企图“违法”的
程序
唯一的下场就是被操作终止执行,回收全部资源。计算机世界的法律还是要比人类有效和严厉得多啊!像这样的情况都属于
程序
自身的BUG,你往往可在特定的操作顺序下重现错误。无效光标不一定总是0,因此错误提示中的
内存
地址也不一定为 “0x00000000”,而是其它随机数字。 首先建议: 1、 检查系统中是否有木马或病毒。这类
程序
为了控制系统往往不负责任地修改系统,从而导致操作系统异常。平常应加强信息安全意识,对来源不明的可执行
程序
绝不好奇。 2、 更新操作系统,让操作系统的安装
程序
重新拷贝正确版本的系统档案、修正系统参数。有时候操作系统本身也会有BUG,要注意安装官方发行的升级
程序
。 3、 尽量使用最新正式版本的应用
程序
、Beta版、试用版都会有BUG。 4、 删除然后重新创建 WinntSystem32WbemRepository 文件夹中的文件:在桌面上右击我的电脑,然后单击管理。在"服务和应用
程序
"下,单击服务,然后关闭并停止 Windows Management Instrumentation 服务。 删除 WinntSystem32WbemRepository 文件夹中的所有文件。(在删除前请创建这些文件的备份副本。)打开"服务和应用
程序
",单击服务,然后打开并启动 Windows Management Instrumentation 服务。当服务重新启动时,将基于以下注册表项中所提供的信息重新创建这些文件: HKEY_LOCAL_MACHINESOFTWAREMicrosoftWBEMCIMOMAutorecover MOFs 下面搜集几个例子给大家分析: 例一:IE浏览器出现“0x0a8ba9ef”指令引用的“0x03713644”
内存
,或者“0x70dcf39f”指令引用的“0x00000000”
内存
。该
内存
不能为“read”。要终止
程序
,请单击“确定”的信息框,单击“确定”后,又出现“发生内部错误,您正在使用的其中一个窗口即将关闭”的信息框,关闭该提示信息后,IE浏览器也被关闭。解决方法: 1、 开始-运行窗口,输入“regsvr32 actxprxy.dll”回车,接着会出现一个信息对话 框“DllRegisterServer in actxprxy.dll succeeded”,确定。再依次运行以下命令。(这个方法有人说没必要,但重新注册一下那些.dll对系统也没有坏处,反正多方下手,能解决
问题
就行。) regsvr32 shdocvw.dll regsvr32 oleaut32.dll regsvr32 actxprxy.dll regsvr32 mshtml.dll regsvr32 msjava.dll regsvr32 browseui.dll regsvr32 urlmon.dll 2、 修复或升级IE浏览器,同时打上系统补丁。看过其中一个修复方法是,把系统还原到系统初始的状态下。建议将IE升级到了6.0。 例二:有些应用
程序
错误: “0x7cd64998” 指令参考的 “0x14c96730”
内存
。该
内存
不能为 “read”。解决方法:Win XP的“预读取”技术这种最佳化技术也被用到了应用
程序
上,系统对每一个应用
程序
的前几次启动情况进行分析,然后新增一个描述套用需求的虚拟“
内存
映像”,并把这些信息储存到WindowsPrefetch文件夹。一旦建立了映像,应用软件的装入速度大大提高。XP的预读取数据储存了最近8次系统启动或应用软件启动的信息。建议将虚拟
内存
撤换,删除WindowsPrefetch目录下所有*.PF文件,让windows重新收集
程序
的物理地址。 例三:在XP下双击光盘里面的“AutoRun.exe”文件,显示“0x77f745cc”指令引用的“0x00000078”
内存
。该
内存
不能为“written”,要终止
程序
,请单击“确定”,而在Windows 98里运行却正常。解决方法:这可能是系统的兼容性
问题
,winXP的系统,右键“AutoRun.exe”文件,属性,兼容性,把“用兼容模式运行这个
程序
”项选择上,并选择“Windows 98/Me”。win2000如果打了SP的补丁后,只要开始,运行,输入:regsvr32 c:winntapppatchslayerui.dll。右键,属性,也会出现兼容性的选项。 例四:RealOne Gold关闭时出现错误,以前一直使用正常,最近却在每次关闭时出现“0xffffffff”指令引用的“0xffffffff”
内存
。该
内存
不能为 “read” 的提示。解决方法:当使用的输入法为微软拼音输入法2003,并且隐藏语言栏时(不隐藏时没
问题
)关闭RealOne就会出现这个
问题
,因此在关闭RealOne 之前可以显示语言栏或者将任意其他输入法作为当前输入法来解决这个
问题
。 例五:我的豪杰超级解霸自从上网后就不能播放了,每次都提示“0x060692f6”(每次变化)指令引用的“0xff000011”
内存
不能为 “read”,终止
程序
请按确定。解决方法:试试重装豪杰超级解霸,如果重装后还会,到官方网站下载相应版本的补丁试试。还不行,只好换就用别的播放器试试了。 例六:双击一个游戏的快捷方式,“0x77f5cd0”指令引用“0xffffffff”内 存,该
内存
不能为“read” ,并且提示Client.dat
程序
错误。解决方法:重装显卡的最新驱动
程序
,然后下载并且安装DirectX9.0。 例七:一个朋友发信息过来,我的电脑便出现了错误信息:“0x772b548f”指令引用的“0x00303033”
内存
,该
内存
不能为 “written”,然后QQ自动下线,而再打开QQ,发现了他发过来的十几条的信息。解决方法:这是对方利用QQ的BUG,发送特殊的代码,做QQ出错,只要打上补丁或升级到最新版本,就没事了。 该
内存
不能为read或written的解决方案关键词: 该
内存
不能为"read" 该
内存
不能为"written" 从网上搜索来的几篇相关文章. 【文章一】 使用Windows操作系统的人有时会遇到这样的错误信息: 「“0X????????”指令引用的“0x00000000”
内存
,该
内存
不能为“read”或“written”」,然后应用
程序
被关闭。 如果去
请教
一些「高手」,得到的回答往往是「Windows就是这样不稳定」之类的义愤和不屑。其实,这个错误并不一定是Windows不稳定造成的。本文就来简单分析这种错误的一般原因。 一、应用
程序
没有检查
内存
分配失败
程序
需要一块
内存
用以储存数据时,就需要使用操作系统提供的「功能函数」来申请,如果
内存
分配成功,函数就会将所新开辟的
内存
区地址返回给应用
程序
,应用
程序
就可以通过这个地址使用这块
内存
。这就是「动态
内存
分配」,
内存
地址也就是编程中的「光标」。
内存
不是永远都招之即来、用之不尽的,有时候
内存
分配也会失败。当分配失败时系统函数会返回一个0值,这时返回值「0」已不表示新启用的游标,而是系统向应用
程序
发出的一个通知,告知出现了错误。作为应用
程序
,在每一次申请
内存
后都应该检查返回值是否为0,如果是,则意味着出现了故障,应该采取一些措施挽救,这就增强了
程序
的「健壮性」。若应用
程序
没有检查这个错误,它就会按照「思维惯性」认为这个值是给它分配的可用游标,继续在之后的执行中使用这块
内存
。真正的0地址
内存
区储存的是计算机系统中最重要的「中断描述符表」,绝对不允许应用
程序
使用。在没有保护机制的操作系统下(如DOS),写数据到这个地址会导致立即当机,而在健壮的操作系统中,如 Windows等,这个操作会马上被系统的保护机制捕获,其结果就是由操作系统强行关闭出错的应用
程序
,以防止其错误扩大。这时候,就会出现上述的「写
内存
」错误,并指出被引用的
内存
地址为「0x00000000」。
内存
分配失败故障的原因很多,
内存
不够、系统函数的版本不匹配等都可能有影响。因此,这种分配失败多见于操作系统使用很长时间后,安装了多种应用
程序
(包括无意中「安装」的病毒
程序
),更改了大量的系统参数和系统档案之后。 二、应用
程序
由于自身BUG引用了不正常的
内存
光标 在使用动态分配的应用
程序
中,有时会有这样的情况出现:
程序
试突读写一块「应该可用」的
内存
,但不知为什么,这个预料中可用的光标已经失效了。有可能是「忘记了」向操作系统要求分配,也可能是
程序
自己在某个时候已经注销了这块
内存
而「没有留意」等等。注销了的
内存
被系统回收,其访问权已经不属于该应用
程序
,因此读写操作也同样会触发系统的保护机制,企图「违法」的
程序
唯一的下场就是被操作终止执行,回收全部资源。计算机世界的法律还是要比人类有效和严厉得多啊!像这样的情况都属于
程序
自身的BUG,你往往可在特定的操作顺序下重现错误。无效光标不一定总是0,因此错误提示中的
内存
地址也不一定为「0x00000000」,而是其它随机数字。如果系统经常有所提到的错误提示,下面的建议可能会有说明 : 1.检视系统中是否有木马或病毒。这类
程序
为了控制系统往往不负责任地修改系统, 从而导致操作系统异常。平常应加强信息安全意识,对来源不明的可执行
程序
绝不好奇。 2.更新操作系统,让操作系统的安装
程序
重新拷贝正确版本的系统档案、修正系统参数。 有时候操作系统本身也会有BUG,要注意安装官方发行的升级
程序
。 3.试用新版本的应用
程序
。 Mode: 将虚拟
内存
撤换 答案: 目前为止是肯定的,也就是如在下次冷天到来时亦没再发生,就代表这是主因 追加: 如果你用 Ghost 恢复 OS 后建议 删除WINDOWS\PREFETCH目录下所有*.PF文件因为需让windows重新收集
程序
的物理地址 有些应用
程序
错误 "0x7cd64998" 指令参考的 "0x14c96730"
内存
。该
内存
不能为 "read"推论是此原因 源由: Win XP的「预读取」技术 这种最佳化技术也被用到了应用软件上,系统对每一个应用软件的前几次启动情况进行分析,然后新增一个描述套用需求的虚拟「
内存
映像」,并把这些信息储存到 WINDOWSPREFETCH数据夹。一旦建立了映像,应用软件的装入速度大大提高。XP的预读取数据储存了最近8次系统启动或应用软件启动的信息。 后叙: 目前此方法亦是独步网络的(其码自己针对此
问题
查了许久),也是常见
问题
,原本几乎每天睡前关闭软件时一些
程序
都会发生...read... 现在就没发生了。 【文章二】 运行某些
程序
的时候,有时会出现
内存
错误的提示(0x后面内容有可能不一样),然后该
程序
就关闭。 “0x????????”指令引用的“0x????????”
内存
。该
内存
不能为“read”。 “0x????????”指令引用的“0x????????”
内存
,该
内存
不能为“written”。 不知你出现过类似这样的故障吗? 一般出现这个现象有方面的,一是硬件,即
内存
方面有
问题
,二是软件,这就有多方面的
问题
了。 下面先说说硬件: 一般来说,
内存
出现
问题
的可能性并不大,主要方面是:
内存
条坏了、
内存
质量有
问题
,还有就是2个不同牌子不同容量的
内存
混插,也比较容易出现不兼容的情况,同时还要注意散热
问题
,特别是超频后。你可以使用MemTest 这个软件来检测一下
内存
,它可以彻底的检测出
内存
的稳定度。 假如你是双
内存
,而且是不同品牌的
内存
条混插或者买了二手
内存
时,出现这个
问题
,这时,你就要检查是不是
内存
出
问题
了或者和其它硬件不兼容。 如果都没有,那就从软件方面排除故障了。 先简单说说原理:
内存
有个
存放
数据的地方叫缓冲区,当
程序
把数据放在其一位置时,因为没有足够空间,就会发生溢出现象。举个例子:一个桶子只能将一斤的水,当你放入两斤的水进入时,就会溢出来。而系统则是在屏幕上表现出来。这个
问题
,经常出现在windows2000和XP系统上,Windows 2000/XP对硬件的要求是很苛刻的,一旦遇到资源死锁、溢出或者类似Windows 98里的非法操作,系统为保持稳定,就会出现上述情况。另外也可能是硬件设备之间的兼容性不好造成的。 下面我从几个例子给大家分析: 例一:打开IE浏览器或者没过几分钟就会出现"0x70dcf39f"指令引用的"0x00000000"
内存
。该
内存
不能为“read”。要终止
程序
,请单击“确定”的信息框,单击“确定”后,又出现“发生内部错误,您正在使用的其中一个窗口即将关闭”的信息框,关闭该提示信息后,IE浏览器也被关闭。解决方法:修复或升级IE浏览器,同时打上补丁。看过其中一个修复方法是,Win2000自升级,也就是Win2000升级到Win2000,其实这种方法也就是把系统还原到系统初始的状态下。比如你的IE升级到了6.0,自升级后,会被IE5.0代替。 例二:在windows xp下双击光盘里面的“AutoRun.exe”文件,显示“0x77f745cc”指令引用的“0x00000078”
内存
。该
内存
不能为 “written”,要终止
程序
,请单击“确定”,而在Windows 98里运行却正常。解决方法:这可能是系统的兼容性
问题
,winXP的系统,右键“AutoRun.exe”文件,属性,兼容性,把“用兼容模式运行这个
程序
”项选择上,并选择“Windows 98/Me”。win2000如果打了SP的补丁后,只要开始,运行,输入:regsvr32 c:winntapppatchslayerui.dll。右键,属性,也会出现兼容性的选项。 例三:RealOne Gold关闭时出现错误,以前一直使用正常,最近却在每次关闭时出现“0xffffffff”指令引用的“0xffffffff”
内存
。该
内存
不能为 “read” 的提示。解决方法:当使用的输入法为微软拼音输入法2003,并且隐藏语言栏时(不隐藏时没
问题
)关闭RealOne就会出现这个
问题
,因此在关闭RealOne 之前可以显示语言栏或者将任意其他输入法作为当前输入法来解决这个
问题
。 例四:我的豪杰超级解霸自从上网后就不能播放了,每次都提示“0x060692f6”(每次变化)指令引用的“0xff000011”
内存
不能为 “read”,终止
程序
请按确定。解决方法:试试重装豪杰超级解霸,如果重装后还会,到官方网站下载相应版本的补丁试试。还不行,只好换就用别的播放器试试了。 例五:双击一个游戏的快捷方式,“0x77f5cd0”指令引用“0xffffffff”内 存,该
内存
不能为“read” ,并且提示Client.dat
程序
错误。 解决方法:重装显卡的最新驱动
程序
,然后下载并且安装DirectX9.0。 例六:一个朋友发信息过来,我的电脑便出现了错误信息:“0x772b548f”指令引用的“0x00303033”
内存
,该
内存
不能为 “written”,然后QQ自动下线,而再打开QQ,发现了他发过来的十几条的信息。解决方法:这是对方利用QQ的BUG,发送特殊的代码,做QQ出错,只要打上补丁或升级到最新版本,就没事了。 【原因 解决方法】 1
内存
条坏了 更换
内存
条 2 双
内存
不兼容 使用同品牌的
内存
或只要一条
内存
3
内存
质量
问题
更换
内存
条 4 散热
问题
加强机箱内部的散热 5
内存
和主板没插好或其他硬件不兼容 重插
内存
或换个插槽 6 硬件有
问题
更换硬盘 7 驱动
问题
重装驱动,如果是新系统,应先安装主板驱动 8 软件损坏 重装软件 9 软件有BUG 打补丁或更新到最新版本 10 软件和系统不兼容 给软件打上补丁或是试试系统的兼容模式 11 软件和软件之间有冲突 如果最近安装了什么新软件,卸载了试试 12 软件要使用其他相关的软件有
问题
重装相关软件,比如播放某一格式的文件时出错,可能是这个文件的解码器有
问题
13 病毒
问题
杀毒 14 杀毒软件与系统或软件相冲突 由于杀毒软件是进入底层监控系统的,可能与一些软件相冲突,卸载试试 15 系统本身有
问题
有时候操作系统本身也会有BUG,要注意安装官方发行的更新
程序
,象SP的补丁,最好打上.如果还不行,重装系统,或更换其他版本的系统。 〔又一说〕 在控制面板的添加/删除
程序
中看看你是否安装了微软NET.Framework,如果已经安装了,可以考虑卸载它,当然如果你以后在其它
程序
需要NET.Framework时候,可以再重新安装。 另外,如果你用的是ATI显卡并且你用的是SP2的补丁(一些ATI的显卡驱动需要在NET.Framework正常工作的环境下)。这种情况你可以找一款不需要NET.Framework支持的ATI显卡驱动。 如果以上两种方法并不能完全解决
问题
,你试着用一下“IE修复”软件,并可以查查是否有病毒之类的。 〔微软NET.Framework升级到1.1版应该没
问题
了〕 〔还有一说〕 方法一: 微软新闻组的朋友指点:开始--运行:regsvr32 jscript.dll 开始--运行:regsvr32 vbscript.dll 不过没解决---但提供了路子-----一次运行注册所有dll 搜索查找到方法如下: 运行 输入cmd 回车在命令提示符下输入 for %1 in (%windir%system32*.dll) do regsvr32.exe /s %1 这个命令老兄你慢慢输 输入正确的话会看到飞快地滚屏 否则……否则失败就是没这效果。回车后慢慢等(需要点时间1-2分钟) 都运行完再打开看 方法二: 这是个典型
问题
~~~~~引起这个
问题
的原因很多。一般来讲就是给系统打上补丁和更换
内存
、给
内存
换个插槽这3种方法来解决。[系统补丁只要到Microsoft Update网站在线更新就可以了] 造成这种
问题
的原因很多,不能单纯的下结论,尽量做到以下几点可能对你有帮助: 1。确保使用的是未修改过的软件(非汉化、破解版) 2。使用改软件时尽量不要运行其他软件。(这是个临时文件,可能某些软件也在使用临时文件夹,所以产生干扰) 3。把那些什么桌面工具,
内存
整理工具通通关掉(你至少有2个类似的工具在运行)” 处理方法: 运行regedit进入注册表, 在HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindowsCurrentVersionExplorerShellExecuteHooks 下,应该只有一个正常的键值"{AEB6717E-7E19-11d0-97EE-00C04FD91972}, 将其他的删除。 〔我个人的最后解决和看法〕 我今天尝试了多种办法,最后我发现
问题
出在微软的NET.Framework上面。我升级了这个软件,并打齐了补丁,短暂平安后,有出现“
内存
不能为read”的情况。后来我受上面文章的启发,卸载了微软的NET.Framework1.0和1.1,世界太平了。 另外:如果是打开“我的电脑”、“我的文档”等的时候出现上述情况,还有一种可能,就是你的右键菜单太臃肿了,此时只要清理右键菜单
问题
就解决了。 -------------------------------------------------------------------------------- 〔试验的结果〕 上面的方法,最管用、最彻底的方法是这个: 运行 输入cmd 回车在命令提示符下输入 for %1 in (%windir%system32*.dll) do regsvr32.exe /s %1 【技巧】如果怕输入错误的话,可以复制这条指令,然后在命令提示框点击左上角的c:,使用下面的“编辑-粘贴”功能就不容易输错了。在飞速滚屏完全静止之后,别着急启动其他
程序
,先耐心等一会儿,因为此时dll们还在找位置。直到你的指示灯不闪了再做别的。 其他建议 使用Windows操作系统的人有时会遇到这样的错误信息:“0X????????指令引用的0x00000000
内存
,该
内存
不能written”,然后应用
程序
被关闭。如果去
请教
一些“高手”,得到的回答往往是“Windows就是这样不稳定”之类的义愤和不屑。其实,这个错误并不一定是Windows不稳定造成的。本文就来简单分析这种错误的常见原因。 一、应用
程序
没有检查
内存
分配失败
程序
需要一块
内存
用以保存数据时,就需要调用操作系统提供的“功能函数”来申请,如果
内存
分配成功,函数就会将所新开辟的
内存
区地址返回给应用
程序
,应用
程序
就可以通过这个地址使用这块
内存
。这就是“动态
内存
分配”,
内存
地址也就是编程中的“指针”。
内存
不是永远都招之即来、用之不尽的,有时候
内存
分配也会失败。当分配失败时系统函数会返回一个0值,这时返回值“0”已不表示新启用的指针,而是系统向应用
程序
发出的一个通知,告知出现了错误。作为应用
程序
,在每一次申请
内存
后都应该检查返回值是否为0,如果是,则意味着出现了故障,应该采取一些措施挽救,这就增强了
程序
的“健壮性”。 若应用
程序
没有检查这个错误,它就会按照“思维惯性”认为这个值是给它分配的可用指针,继续在之后的运行中使用这块
内存
。真正的0地址
内存
区保存的是计算机系统中最重要的“中断描述符表”,绝对不允许应用
程序
使用。在没有保护机制的操作系统下(如DOS),写数据到这个地址会导致立即死机,而在健壮的操作系统中,如Windows等,这个操作会马上被系统的保护机制捕获,其结果就是由操作系统强行关闭出错的应用
程序
,以防止其错误扩大。这时候,就会出现上述的“写
内存
”错误,并指出被引用的
内存
地址为“0x00000000”。
内存
分配失败故障的原因很多,
内存
不够、系统函数的版本不匹配等都可能有影响。因此,这种分配失败多见于操作系统使用很长时间后,安装了多种应用
程序
(包括无意中“安装”的病毒
程序
),更改了大量的系统参数和系统文件之后。 二、应用
程序
由于自身BUG引用了不正常的
内存
指针 在使用动态分配的应用
程序
中,有时会有这样的情况出现:
程序
试图读写一块“应该可用”的
内存
,但不知为什么,这个预料中可用的指针已经失效了。有可能是“忘记了”向操作系统要求分配,也可能是
程序
自己
0x00000000
内存
不能为read修复工具
该
内存
不能为“read”或“written解决方案 运行某些
程序
的时候,有时会出现
内存
错误的提示,然后该
程序
就关闭。 “0x????????”指令引用的“0x????????”
内存
。该
内存
不能为“read”。 “0x????????”指令引用的“0x????????”
内存
,该
内存
不能为“written”。 一般出现这个现象有方面的,一是硬件,即
内存
方面有
问题
,二是软件,这就有多方面的
问题
了。 故障分析 硬件方面: 一般来说,
内存
出现
问题
的可能性并不大,主要方面是:
内存
条坏了、
内存
质量有
问题
,还有就是 2 个不 同牌子不同容量的
内存
混插,也比较容易出现不兼容的情况,同时还要注意散热
问题
,特别是超频后。你 可以使用MemTest 这个软件来检测一下
内存
,它可以彻底的检测出
内存
的稳定度。 假如是双
内存
,而且是不同品牌的
内存
条混插或者买了二手
内存
时,出现这个
问题
,这时,就要检查是不 是
内存
出
问题
了或者和其它硬件不兼容。 软件方面: 先简单说说原理:
内存
有个
存放
数据的地方叫缓冲区,当
程序
把数据放在其一位置时,因为没有足够空间, 就会发生溢出现象。举个例子:一个桶子只能将一斤的水,当放入两斤的水进入时,就会溢出来。而系统 则是在屏幕上表现出来。这个
问题
,经常出现在 windows2000 和 XP 系统上,Windows 2000/XP 对硬件的 要求是很苛刻的,一旦遇到资源死锁、溢出或者类似 Windows 98 里的非法操作,系统为保持稳定,就会出 现上述情况。另外也可能是硬件设备之间的兼容性不好造成的。 几个例子 例一:打开 IE 浏览器或者没过几分钟就会出现"0x70dcf39f"指令引用的"0x00000000"
内存
。该
内存
不能为 “read”。要终止
程序
,请单击“确定”的信息框,单击“确定”后,又出现“发生内部错误,您正在使用的其中 一个窗口即将关闭”的信息框,关闭该提示信息后,IE浏览器也被关闭。 解决方法:修复或升级 IE 浏览器,同时打上补丁。看过其中一个修复方法是,Win2000 自升级,也就是 Win2000升级到Win2000,其实这种方法也就是把系统还原到系统初始的状态下。比如你的IE升级到了6.0, 自升级后,会被IE5.0代替。 例二:在windows xp下双击光盘里面的“AutoRun.exe”文件,显示“0x77f745cc”指令引用的“0x00000078”内 存。该
内存
不能为“written”,要终止
程序
,请单击“确定”,而在Windows 98里运行却正常。 解决方法:这可能是系统的兼容性
问题
,winXP 的系统,右键“AutoRun.exe”文件,属性,兼容性,把“用 兼容模式运行这个
程序
”项选择上,并选择“Windows 98/Me”。win2000如果打了SP的补丁后,只要开始, 运行,输入:regsvr32 c:\winnt\apppatch\slayerui.dll。右键,属性,也会出现兼容性的选项。 例三:RealOne Gold关闭时出现错误,以前一直使用正常,最近却在每次关闭时出现“0xffffffff”指令引用的 “0xffffffff”
内存
。该
内存
不能为“read” 的提示。 解决方法:当使用的输入法为微软拼音输入法 2003,并且隐藏语言栏时(不隐藏时没
问题
)关闭 RealOne 就会出现这个
问题
,因此在关闭 RealOne 之前可以显示语言栏或者将任意其他输入法作为当前输入法来解 决这个
问题
。 例四:我的豪杰超级解霸自从上网后就不能播放了,每次都提示“Ox060692f6”(每次变化)指令引用的 “Oxff000011”
内存
不能为“read”,终止
程序
请按确定。 解决方法:试试重装豪杰超级解霸,如果重装后还会,到官方网站下载相应版本的补丁试试。还不行,只好 换就用别的播放器试试了。 例五:双击一个游戏的快捷方式,“Ox77f5cdO”指令引用“Oxffffffff”
内存
,该
内存
不能为“read” ,并且提示 Client.dat
程序
错误。 解决方法:重装显卡的最新驱动
程序
,然后下载并且安装DirectX9.0。 例六:一个朋友发信息过来,我的电脑便出现了错误信息:“0*772b548f”指令引用的“0*00303033”
内存
,该
内存
不能为“written”,然后QQ自动下线,而再打开QQ,发现了他发过来的十几条的信息。 解决方法:这是对方利用QQ的BUG,发送特殊的代码,做QQ出错,只要打上补丁或升级到最新版本, 就没事了。 例七:我的笔记本电脑用的XP系统,有时关闭网页时会弹出tbrowser.exe遇到
问题
需要关闭,然后有弹出 0x03e7c738指令引用的0x03e7c738
内存
,该
内存
不能为read,请问是怎么回事? 解决方法:先查杀一下病毒,另外如果你安装了浏
搭建一个简易的C语言平台
搭建这样一个简单的c语言学习环境,可以深入研究c语言的,如果将tc 2.0中的文件都放在一起,根本无法判别是哪些文件对
程序
的运行有影响,不利于研究c语言开发环境。搭建这样一个简单的c语言环境是为了更方便的了解
程序
的生成过程。这样做有这样的目的:研究过程清晰明了,有利于从本质上解决
问题
。
信令分析工具 V2.01
七号信令分析软件 2.0 一.实现功能及解决
问题
1.增加对ISUP消息的分析统计功能; 2.解决DISMSU执行出现非法操作的错误,主要是对ISUP的INF消息和TUP的GSM消息处理有误; 3.解决打开扩展名为大写的“TXT”当作二进制文件分析的错误; 4.更新用户手册,主要增加ISUP消息中的失败原因值的列表 5.解决七号信令分析软件判断跟踪消息的信令点编码为24位还是14位的
问题
,估计跟踪消息中的一个标志位判断。不需要用户配置。 6.增加打印功能; 7.统计结果的排序
问题
,可以按数字排序; 8.解决通过滚动条无法看到最后一条记录的
问题
; 9.主被叫号码长度超过29位导致“内部不正确”提示的
问题
。 10.可以对旧格式的信令文件进行处理后,用此软件进行分析。 具体使用方法见“UserMannua20.lwp”或从
程序
组中打开“用户手册”。 二.目前已经存在的
问题
,但难以解决的有: 1.相关信令的查询 当点击某个呼叫时,在出现相关的信令消息之前会有短时间的白屏现象。这是因为
程序
调用了一个DISMSU.EXE文件产生包含信令消息的文件。但是因为执行之间的同步
问题
,如果调用DISMSU.EXE结束后立刻打开信令消息文件显示,往往打开的是上一次的结果。所以在显示之前SLEEP 2秒钟。
请教
过UI的高手,通过在某一个文件中设置标志位来充当信号量,但在实现中发现仍然是老
问题
。 2.统计速度 对信令消息的统计速度比较慢,可能要忍受一下。我测试用的文件比较小,执行起来还比较快。主要原因可能在于以前的版本只支持TUP消息统计,消息参数都比较少,所以数组开了100个字节的空间。考虑到ISUP消息最长为272个,但转换为文本的字符表示,还要加空格,基本上是3倍的关系。所以目前的消息长度定位600。这样
内存
和写文件操作时间都会比较长。 3.不能统计自环消息 目前七号信令分析软件不支持对自环消息的统计,或者说自环统计中认为是成功的呼叫,在用此软件分析后会认为没有后向的应答消息而设置状态为不成功。 三.安装路径 setup目录下
存放
的是七号信令分析软件 2.0版本的安装盘。
单片机原理及接口技术课后习题答案 第三版 李朝青
单片机原理及接口技术课后习题答案 第三版 李朝青 如果有用就顶上去
C语言
70,035
社区成员
243,244
社区内容
发帖
与我相关
我的任务
C语言
C语言相关问题讨论
复制链接
扫一扫
分享
社区描述
C语言相关问题讨论
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章