c内存读写越界

问题分析:

创新互联建站是一家专业提供牟定企业网站建设,专注与成都网站建设、成都做网站H5响应式网站、小程序制作等业务。10年已为牟定众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。

这种情况是指:访问了你不应该/没有权限访问的内存地址空间,比如访问数组时越界;对动态内存访问时超出了申请的内存大小范围。下面的程序就是一个典型的数组越界问题。pt是一个局部数组变量,其大小为4,p初始指向pt数组的起始地址,但在对p循环叠加后,p超出了pt数组的范围,如果此时再对p进行写操作,那么后果将不可预期。

#include

#include

int main(int argc,char *argv[])

{

int len = 4;

int* pt = (int*)malloc(len*sizeof(int));

int * p=pt;

for(int i=0;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

c内存读写越界

输出结果显示,在该程序的第15行,进行了非法的写操作;在第16行,进行了非法读操作。准确地发现了上述问题。


新闻名称:c内存读写越界
标题URL:http://hxwzsj.com/article/jsojgp.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 成都网站建设 成都网站设计 成都网站建设 企业网站设计 成都网站设计 定制网站设计 手机网站制作 成都网站制作 网站制作公司 成都网站建设 网站制作 网站建设方案 定制网站建设多少钱 成都网站制作公司 营销网站建设 成都网站设计 网站设计 广安网站设计 成都企业网站建设 温江网站设计 四川成都网站制作 成都网站制作