什么是分段错误?C和C++有区别吗?分段错误和悬空指针有什么关系?
分段错误是由于访问“不属于您”的内存而导致的一种特定错误。它是一种帮助机制,可防止您破坏内存并引入难以调试的内存错误。每当您遇到段错误时,您就知道您在内存方面做错了——访问已被释放的变量、写入内存的只读部分等。在大多数允许您使用的语言中,分段错误基本上是相同的内存管理混乱,C 和 C++ 中的段错误之间没有主要区别。
有很多方法可以获得段错误,至少在 C(++) 等低级语言中是这样。获得段错误的常见方法是取消引用空指针:
int *p = NULL; *p = 1;
当您尝试写入标记为只读的内存部分时,会发生另一个段错误:
char *str = "Foo"; // Compiler marks the constant string as read-only *str = 'b'; // Which means this is illegal and results in a segfault
悬空指针指向一个不再存在的东西,就像这里:
char *p = NULL; { char c; p = &c; } // Now p is dangling
指针悬空是因为它指向在块结束后不再存在p的字符变量。c当您尝试取消引用悬空指针(如*p='A')时,您可能会遇到段错误。
p
c
*p='A'