问题分析:
这种情况是指:访问了你不应该/没有权限访问的内存地址空间,比如访问数组时越界;对动态内存访问时超出了申请的内存大小范围。下面的程序就是一个典型的数组越界问题。pt是一个局部数组变量,其大小为4,p初始指向pt数组的起始地址,但在对p循环叠加后,p超出了pt数组的范围,如果此时再对p进行写操作,那么后果将不可预期。
#include <stdlib.h>
#include <stdio.h>
int main(int argc,char *argv[])
{
int len = 4;
int* pt = (int*)malloc(len*sizeof(int));
int * p=pt;
for(int i=0;i<len;i++)
{
p++;
}
*p=5;
printf("the value of equal:%d",*p);
return 0;
}
gcc -Wall test.c -g -o test
valgrind --tool=memcheck --leak-check=full ./test
输出结果显示,在该程序的第15行,进行了非法的写操作;在第16行,进行了非法读操作。准确地发现了上述问题。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享题目:c内存读写越界-创新互联
网页网址:https://www.cdcxhl.com/article2/dgcpic.html
成都网站建设公司_创新互联,为您提供品牌网站设计、电子商务、网站排名、企业网站制作、自适应网站、外贸网站建设
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联