作者:生死有命富贵在天999_275 | 来源:互联网 | 2023-05-18 14:12
指针赋值导致程序崩溃的奇怪现象
代码实例
结果程序崩溃。
原因:语法没有错,但指针flag赋了NULL,NULL一般为内存0地址,由于任何进程的0地址开始存储的都是系统关键地址,比如进程的退出,堆栈维护,键盘处理等系统控制程序的地址。以上代码直接修改0地址处内容,导致系统信息被修改导致崩溃。
正确实例
对()取址报错
注意有以下情况:
编译器报以下错误:
因为以上(unsigned)(-1)运算式为右值,单目‘&’的操作数必须是左值,可能原因是右值运算在汇编中一般送进寄存器运算,无地址可取。