c内存读写越界

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c内存读写越界相关的知识,希望对你有一定的参考价值。

问题分析:

这种情况是指:访问了你不应该/没有权限访问的内存地址空间,比如访问数组时越界;对动态内存访问时超出了申请的内存大小范围。下面的程序就是一个典型的数组越界问题。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行,进行了非法读操作。准确地发现了上述问题。

本文出自 “我是程序我最大” 博客,请务必保留此出处http://skinglzw.blog.51cto.com/10729606/1923437

以上是关于c内存读写越界的主要内容,如果未能解决你的问题,请参考以下文章

在linux系统下使用内存技术,检测堆越界错误

内存越界一定会导致程序崩溃吗?详解内存越界

Linux程序Segmentation fault (core dumped)

CVE-2020-11100: HAProxy 内存越界写入漏洞通告

应用层内存溢出/越界/重复释放等问题检查工具

C语言 用sprintf时下标越界