1.野指针(Wild Pointer)的危害?
野指针,即指向一个错误位置的指针。一旦程序中存在野指针,存放在堆中的数据可能会被破坏,用来处理堆的数据结构也可能会被破坏,甚至操作系统的数据也可能会被破坏。
2.从语法的角度判断指针的类型和指针所指向的类型
把指针声明语句中指针的名字去掉就是指针的类型,而把指针的名字及名字前的指针声明符“*”去掉,就是指针所指向的类型。
3.一个指针最多可以包含几层间接引用?
至少可以有12层。
ANSI C标准要求所有的编译程序都必须能处理至少12层间接引用。
4.指针常量和常量指针的区别?
(1)const char* p
(2)char* const p
语句(1)定义了一个常量指针,指向的内容是常量,不可修改,但指针本身可以修改,即“*p=b”是非法的,“p=&q”是可以的。
语句(2)定义了一个指针常量,指针本身是一个常量,不可修改,但指针所指向的内容可以修改。“*p=b”是可以的,而“p=&b”是非法的。
5.空指针的使用注意
绝对不能间接引用一个空指针,否则可能会得到毫无意义的结果,或者得到一个全部是0的值,或者会忽然停止运行。
6.指针数组与数组指针
指针数组“typename *p[n]”,数组的元素都是指针。
数组指针 “typename (*p)[n]”,指针存放着一个数组的首地址。
7、指针的类型:
int *ptr; //指针类型是int*
char *ptr; //指针类型是char*
int **ptr; //指针类型是int**
int (*ptr)[3]; //指针类型是int(*)[3]
int *(*ptr)[4]; //指针类型是int*(*)[4]
8、指针的值的含义:
指针的值也叫做指针所指向的内存区域或地址。指针的值是指针本身存储的数值,这个值将被编译器当作一个地址,而不是一个一般的数值。在32位程序里,所有类型的指针的值都是一个32位整数,因为32位程序里内存地址全都是32位长。指针所指向的内存区域就是从指针值所代表的那个内存地址开始,长度为sizeof的一片内存区。以后,我们说一个指针的值是XX,就相当于说该指针指向了以XX位首地址的一片内存区域;我们说一个指针指向了某块内存区域,就相当于说该指针的值是这块内存区域的首地址。
9、指针的值的含义:
指针的值也叫做指针所指向的内存区域或地址。指针的值是指针本身存储的数值,这个值将被编译器当作一个地址,而不是一个一般的数值。在32位程序里,所有类型的指针的值都是一个32位整数,因为32位程序里内存地址全都是32位长。指针所指向的内存区域就是从指针值所代表的那个内存地址开始,长度为sizeof的一片内存区。以后,我们说一个指针的值是XX,就相当于说该指针指向了以XX位首地址的一片内存区域;我们说一个指针指向了某块内存区域,就相当于说该指针的值是这块内存区域的首地址。
10、指针的值的含义:
指针的值也叫做指针所指向的内存区域或地址。指针的值是指针本身存储的数值,这个值将被编译器当作一个地址,而不是一个一般的数值。在32位程序里,所有类型的指针的值都是一个32位整数,因为32位程序里内存地址全都是32位长。指针所指向的内存区域就是从指针值所代表的那个内存地址开始,长度为sizeof的一片内存区。以后,我们说一个指针的值是XX,就相当于说该指针指向了以XX位首地址的一片内存区域;我们说一个指针指向了某块内存区域,就相当于说该指针的值是这块内存区域的首地址。