NULL字符
NULL指针
#define NULL
#define __cplusplus
#define NULL 0
#else
#define NULL ((void *)0)
#endif
#endif
#interface NULL 0
NULL的出现是一种约定俗成,事实上它不是C语言中的关键字;把一个
指针
赋值为NULL,通常的说法是“将指针悬空”。这样,
指针
就无法再进行任何数据访问了。编程工作中有一类比较容易犯的错误--
指针
地址未进行正确的更新赋值就加以使用,这往往会造成很严重的后果(对内存区进行错误的涂抹)。所以一个良好的习惯是,当一个
指针
的工作稍事休息,先把它赋值为NULL,待到再度使用时,重新对其赋值以及进行指针类型转化。
前面说到“NULL
指针
无法再进行任何数据访问”,其实是视
编译器
功能而定的。0位置指向的是程序起始,对于不同的
编译器
,NULL
指针
的操作结果是不同的:有些是不准读写,有些是只读,甚至读写都允许。
编译器
是人定的。引用网友win_hate在话题“关于NULL的不严谨”中的话来说:“如果说有谁不严谨了,那必定是读取0位置的程序员,而不是C。C的设计哲学之一是:‘程序员知道自己在干什么--没有安全带’”。
用NULL的话,很多系统都是对NULL内存单元保护的,你根本不能改写,甚至都不可以读取
你在初始化去指定指针指向特定的内存单元虽然也可以,但是你知道那个内存单元有没有被其他程序占用么?又没有可能是操作系统在占用,这样话,万一改写,很可能会导致系统崩溃,所以最安全的话,还是指向一个自己已知的某个相关类型的变量,或者是干脆用mallco申请一个相关类型的变量的空间
你在初始化去指定指针指向特定的内存单元虽然也可以,但是你知道那个内存单元有没有被其他程序占用么?又没有可能是操作系统在占用,这样话,万一改写,很可能会导致系统崩溃,所以最安全的话,还是指向一个自己已知的某个相关类型的变量,或者是干脆用mallco申请一个相关类型的变量的空间