标签:内存越界 main 内存地址 scanf 运行 print 错误 内存管理 编译
段错误应该就是访问了不可访问的内存,这个内存要么是不存在的,要么是受系统保护的。
SIGSEGV在很多时候是由于指针越界引起的,但并不是所有的指针越界都会引发SIGSEGV。一个越界的指针,如果不引用它,是不会引起SIGSEGV的。而即使引用了一个越界的指针,也不一定引起SIGSEGV。
#include <stdio.h>
#include <stdlib.h>
int main()
{
char* ch = "hello world";
ch[1] = ‘H‘;
return 0;
}
上述程序编译没有问题,但是运行时弹出SIGSEGV。此例中,”hello world”作为一个常量字符串,在编译后会被放在.rodata
节(GCC),最后链接生成目标程序时.rodata
节会被合并到text segment与代码段放在一起,故其所处内存区域是只读的。这就是错误的访问类型引起的SIGSEGV。
#include <stdio.h>
#include <stdlib.h>
int main()
{
int* p = (int*)0xC0000fff;
*p = 10;
return 0;
}
还有一种可能,往受到系统保护的内存地址写数据,最常见的就是给一个指针以0地址:
#include <stdio.h>
#include <stdlib.h>
int main()
{
int i = 0;
scanf ("%d", i); /* should be used &i */
printf ("%d\n", i);
return 0;
}
#include <stdio.h>
#include <stdlib.h>
int main()
{
int *p = NULL;
*p = 1;
return 0;
}
在实际情况中,此例中的空指针可能指向用户态地址空间,但其所指向的页面实际不存在。
#include <stdio.h>
#include <stdlib.h>
int main()
{
char test[1];
printf("%c", test[10]);
return 0;
}
#include <stdio.h>
#include <stdlib.h>
int main()
{
int b = 10;
printf("%s\n", b);
return 0;
}
标签:内存越界 main 内存地址 scanf 运行 print 错误 内存管理 编译
原文地址:https://www.cnblogs.com/xiaojianliu/p/13384145.html