以下内容是我从中国慕课大学翁恺老师的网课中整理出来的笔记,有兴趣的佳人们可以去看原课。
指针运算
1+1=2?
· 给指针加1表示要让指针指向下一个变量
int [10];
int *p=a;
*(p+1)-->a[1]
· 如果指针不是指向一片连续分配的空间,如数组,则这种运算没有意义。
指针运算
· 这些算数运算可以对指针做:
· 给指针加减一个整数(=,+=,-,-=)
· 递增递减(++、--)
递增是将指针移到下一个位置上
· 两个指针相减
两个指针相减的结果是这两个地址之间有多少单元
*p++
· 取出p所指的那个数据来,完事之后顺便把p移到下一个位置去
· *的优先级虽然高,但是没有++高
· 常用于数组类连续空间操作
· 在某些CPU上,这可以直接被翻译成一条汇编指令
指针比较
· <,<=,==,>,>=,!=都可以对指针做
· 比较它们在内存中的地址
· 数组中的单元的地址肯定是线性递增的
0地址
· 当然你的内存中有0地址,但是0地址通常是个不能随便碰的地址
· 所以你的指针不应该具有0值