该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
指针
定义:是一种保存变量地址的变量。(禁止套娃)
声明:标准形式是 int *p;
1.这个形式容易搞混,是定义了指针p而不是定义了指针指向的那个值;
2.还有搞混的一点是int *p=&x并没有错误,本质上是p=&x 。而直接*p=&x才是错的;
3.注意指针在访问前必须初始化(即赋于一个变量,让p有合法的指向),否则会程序崩溃;
两大元素:指针的值(地址)+对应指向的值
指针数组:int *p[10]; 是一个数组,数组中的每一个元素都是同类型的指针
数组指针:int (*p)[10]; 是一个指针,它指向一个数组
函数指针:int (*p)(int *,int *); 该指针指向一个函数,函数具有两个 int * 类型的参数,返回值类型为 int,
且指针指向函数的入口地址。
NULL指针:int *p=NULL; 用NULL指令给指针赋一个零值,表示不指向任何东西;
指针与数组关系:
int *p=&a[0]=a; 因为a数组名所代表的的就是该数组第 1 个元素a[0]的地址
引出它们之间的对应特性:数组下标与指针运算之间的关系是一一对应的,
对指针进行自增操作会让指针指向与当前元素相邻的下一个元素,即 *(p + 1) 将表示 a[1],以此类推。
以下代码是通过使用指针变量的移动来遍历输出数组中的每个元素的典例:
int *p,a[10];
p=a;
for (p=a;p
printf ("%d\t",*p);
指针的运算:
一般意义上仅限定于对指针变量p的+-整数操作,或者是两同类型同数组指向的指针相减求差值。
在C中,对指针加i:
所得结果也是一个指针,但这种运算并不会改变指针变量 p 自身的地址,只是改变了它所指向的地址,
即指针所指向的内存地址相比于 p 所指的内存地址前进了 i 个操作数,指向了下i个元素的存储单元,
地址跳跃的字节数取决于指针所指向变量数据类型长度,比如 int 是 4 个字节,
那么举个例子,p指向地址为1000的整形变量,则p+1指向1004。
在C中,两指针相减:
所得的值是两个指针在内存中的距离,其差值是以数组元素的长度为单位,而不是以字节为单位,比如结果为2就是两个int的数值