c内存读写越界
发表于:2024-11-24 作者:热门IT资讯网编辑
编辑最后更新 2024年11月24日,问题分析:这种情况是指:访问了你不应该/没有权限访问的内存地址空间,比如访问数组时越界;对动态内存访问时超出了申请的内存大小范围。下面的程序就是一个典型的数组越界问题。pt是一个局部数组变量,其大小为
问题分析:
这种情况是指:访问了你不应该/没有权限访问的内存地址空间,比如访问数组时越界;对动态内存访问时超出了申请的内存大小范围。下面的程序就是一个典型的数组越界问题。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 输出结果显示,在该程序的第15行,进行了非法的写操作;在第16行,进行了非法读操作。准确地发现了上述问题。