C语言里面的指针可以指向任何有效的数据,也可以 不指向任何东西;这后者即所谓的NULL指针。 当指向有效数据的时候,对它使用*做dereference操 作就可以取出数据来了;但是对不指向任何数据的指针 来进行*操作肯定就没什么意义了,对吧?所以对不指 向任何数据的指针做提领其实是个bug。 在现代的操作系统设计中,为了消除程序里面的这种 bug,故意分配一些专门的不能访问的内存页,然后 将NULL指针安排在里面。这样当程序员不小心在自己 的程序中写下对NULL指针的提领操作后,系统运行时 就会报错。 在windows和linux中,这些内存页被设计者安排在 0地址开始对应的那几个页上。实际上,这些页面里面 的任何地址都是不能被提领的。*((char *)0) 不可以, *((char *)0x12)之类的地址也不可以。 很多人认为NULL指针其实就是指向0地址的指针,实际 上这是不准确的。虽然很少见,但也有处理器架构将 NULL指针安排在非零地址起始的页面内。所以为了程 序的可移植性,在需要使用NULL指针的时候,用NULL 宏而来不用0值来初始化指针变量。
关于C程序中空指针(null指针)的设计哲学
最新推荐文章于 2023-04-11 00:08:05 发布