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