首页 > 其他 > 详细

关于VS中未经处理的异常的梳理

时间:2020-04-10 16:43:36      阅读:107      评论:0      收藏:0      [点我收藏+]

一.真正有用的内存地址

实际上真正有用的地址是写入位置,在VS的内存窗口中去查看该位置,可以看到具体出现的问题.

技术分享图片

 

二.发生访问冲突的可能原因

1.访问了0x00位置的数据

2.对内存中常量进行修改.

char * pcontent = "  abcdef  "; //待去掉前后空格的字符串(共10字节)
char * p = NULL;

/* 1去除后面的空格 */
p = pcontent + strlen( pcontent ) - 1;  //指针p指向字符串的末尾
while( *p == 0x20 )
{
    p--;
}
*(p+1) = 0x00;  //此处就是对常量进行修改,因为p指向的是常量区.解决办法是,把pcontent声明为数组.
printf( "Line=[%d], pcontent=[%s]\n", __LINE__, pcontent );

参考文章:未经处理的异常:0xC0000005:读取/写入位置冲突——从去掉字符串所有空格说起

 

关于VS中未经处理的异常的梳理

原文:https://www.cnblogs.com/Stephen-Qin/p/12674366.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!