搜索
bottom↓
回复: 17

VC++6.0为何自动向内存里填充0xCC字节信息?

[复制链接]

出0入0汤圆

发表于 2015-6-24 18:23:00 | 显示全部楼层 |阅读模式
本帖最后由 gracialee 于 2015-6-24 18:25 编辑


自行填充了3个0XCC.



把字符串加了一个字符,填充变成了2个。



再次把字符串加一个字符,填充变成了1个。



继续增加一个字符,填充不再增加。



再加长一次字符,又开始填充3个了。。。。。。


编辑原因,便于坛友观察。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

你熬了10碗粥,别人一桶水倒进去,淘走90碗,剩下10碗给你,你看似没亏,其实你那10碗已经没有之前的裹腹了,人家的一桶水换90碗,继续卖。说白了,通货膨胀就是,你的钱是挣来的,他的钱是印来的,掺和在一起,你的钱就贬值了。

出0入0汤圆

发表于 2015-6-24 18:32:23 | 显示全部楼层
烫烫烫烫烫烫

出0入0汤圆

发表于 2015-6-24 19:26:28 | 显示全部楼层

是啊,我也经常搞出一大堆的烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫 却不知道为什么

出0入54汤圆

发表于 2015-6-24 19:29:41 | 显示全部楼层
看起来跟4字节对齐有关。。会不会和UTF8有关系

出0入0汤圆

发表于 2015-6-24 19:32:03 | 显示全部楼层
估计是字节对齐的原因吧。

出0入0汤圆

发表于 2015-6-24 19:46:53 | 显示全部楼层
本帖最后由 337zhang 于 2015-6-24 19:48 编辑

应该是str0[]没有指定长度,你指定下长度再试试效果~
第二次编辑,补充内容

出0入0汤圆

发表于 2015-6-24 19:47:54 | 显示全部楼层
lz是debug版的吧,你用release就不会有这个了

出0入0汤圆

发表于 2015-6-24 19:47:55 来自手机 | 显示全部楼层
简单啊,因为你用的是调试版。发行版没有这个问题。

出0入0汤圆

发表于 2015-6-24 20:00:44 | 显示全部楼层
烫烫烫烫烫烫

出350入477汤圆

发表于 2015-6-24 20:06:18 | 显示全部楼层
主要原因是:0xCC是INT3指令,也就是调试器断点。
没用的空间用INT3填充可以保证万一程序跑飞了把这里当代码执行,立刻中断到调试器。

出350入477汤圆

发表于 2015-6-24 20:09:55 | 显示全部楼层
局部变量的缓冲区溢出也是常见的把数据当作代码执行的错误,所以没用的缓冲区后面填INT3也是正确做法。

出0入0汤圆

 楼主| 发表于 2015-6-24 20:43:38 | 显示全部楼层
tabing 发表于 2015-6-24 19:47
lz是debug版的吧,你用release就不会有这个了

谢谢,假如弄发行版,在VC++里如何测试出里面没有了“烫烫。。。。”

出0入0汤圆

发表于 2015-6-24 20:44:11 | 显示全部楼层
烫烫烫烫屯屯屯屯

出350入477汤圆

发表于 2015-6-24 20:58:52 来自手机 | 显示全部楼层
turf456 发表于 2015-6-24 20:44
烫烫烫烫屯屯屯屯

屯是0xcd,用于动态内存。你申请的没初值的动态内存里面都是这个。
原因是它是intN的操作码
也是防止程序错误的执行它

出350入477汤圆

发表于 2015-6-24 21:02:49 来自手机 | 显示全部楼层
gracialee 发表于 2015-6-24 20:43
谢谢,假如弄发行版,在VC++里如何测试出里面没有了“烫烫。。。。”  ...

不需要测试,这是为了调试而故意这样设计的。

出0入0汤圆

发表于 2015-6-24 21:17:44 | 显示全部楼层
redroof 发表于 2015-6-24 20:06
主要原因是:0xCC是INT3指令,也就是调试器断点。
没用的空间用INT3填充可以保证万一程序跑飞了把这里当代 ...

这才是正解               

出0入0汤圆

 楼主| 发表于 2015-6-24 21:20:31 | 显示全部楼层
redroof 发表于 2015-6-24 21:02
不需要测试,这是为了调试而故意这样设计的。

掘地三尺也要挖出来,还得用当年的老古董“debug testpointer.exe”。。。。。。

出350入477汤圆

发表于 2015-6-24 21:30:48 来自手机 | 显示全部楼层
sj1125055001 发表于 2015-6-24 21:17
这才是正解

其实如果仅仅当作调试用的标记,拿什么东西来填充没初始化的内存都无所谓。用12也好,34也好,都没区别。
但除了做标记还想有别的作用,例如在错误执行到这里的时候能中断到调试器,那么单字节的cc就是最佳选择,设计x86的时候给int3单独一个操作码就是方便这样用。如果是多字节,不从第一字节来解码,就全乱套了。
从很早的VC就这么干了,微软的那一批人绝对不笨,能想的都想过了。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-10-3 01:15

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表