面试官:什么是段错误(Segmentation Fault)?它是如何产生的?请列举常见的场景。
应聘者回答参考:
段错误(Segmentation Fault,简称 SegFault)是一种内存访问异常,表示程序试图访问未被允许的内存区域。操作系统为每个进程分配特定的内存段(代码段、数据段、堆、栈等),一旦程序越界访问或访问非法地址,系统将触发段错误并终止程序。
一、段错误的定义
段错误是由于访问了受保护、非法或未分配的内存区域所导致的错误,常见于访问空指针、野指针、数组越界、栈溢出等情况。
二、常见的段错误场景
- 访问空指针或未初始化的指针
int* ptr = NULL;
*ptr = 0; // 段错误,ptr 指向非法内存
- 访问受保护的系统地址
int* ptr = (int*)0x0;
*ptr = 100; // 操作系统禁止访问该地址
- 修改只读内存区域
char* str = "hello";
str[0] = 'H'; // 字符串常量存储在只读区,修改时报错
- 空指针解引用
int* p = NULL;
printf("%d\n", *p); // 解引用空指针
- 栈溢出
栈空间有限,递归层数过深或定义大数组都可能导致段错误:
void recurse() {
recurse(); // 无限递归导致栈溢出
}
- 数组越界访问
char test[10];
printf("%c\n", test[100000]); // 越界访问导致非法内存访问
三、小结
- 段错误是程序试图非法访问内存时由操作系统捕获的一种错误;
- 常见原因包括:空指针、非法指针、越界访问、栈溢出、只读区修改等;
- 为避免段错误,应始终初始化指针、检查数组边界、避免使用野指针,并使用工具如
gdb
进行调试排查。
😀 关注 @公众号 程序员陈子青,获取更多 C++ 技术支持。