https://juejin.cn/post/6892199770106888199
你对指针的掌握程度甚至直接决定了你C语言的编程能力!!!
请看图:
如果需要获取某个变量的地址,可以使用取地址运算符(&):char *pa=&a;int *pb =&f;如果需要获取某个变量的地址,可以使用取地址运算符(&),也可称为间接运算符:printf("%c,%dn",*pa,*pb);
理解指针:
- 在定义指针时,(*)表示定义指针。如:char *a=b;、char* a=b而在输出时,表示取值。如:printf("a=%cn",*pa);
格式控制符“%p”中的p是pointer(指针)的缩写。指针的值是语言实现(编译程序)相关的,但几乎所有实现中,指针的值都是一个表示地址空间中某个存储器单元的整数。printf函数族中对于%p一般以十六进制整数方式输出指针的值,附加前缀0x。
%p是打印地址的, %x是以十六进制形式打印, 完全不同!另外在64位下结果会不一样, 所以打印指针老老实实用%p 。
%p和%x的不同:%x同样输出16进制形式,不过%x对应的是int型,也就是说,其输出长度与系统int型占的字节数相等回。如32位编译器,int型占4位字节,那么%x输出的结果最多为16个16进制字符。
而%p输出宽度取决于系统地址总线位数,即16位最多输出4位16进制字符,32位最多输出8位16进制字符,64位最多输出16位16进制字符。
1 #include注意(难以排查的bug):2 int main() 3 { 4 char a='f'; 5 int i=123; 6 7 char *pa=&a;//这里表示把a的地址赋予给指针pa 8 int *pi=&i; 9 10 printf("a=%cn",*pa); 11 //这里表示用取值运算符(*)间接取出pa表示地址的值 12 //为什么是间接运算符(*):取出地址,然后通过地址取值变量a 13 printf("i=%dn",*pi); 14 15 *pa='g'; 16 *pi+=1; 17 18 printf("now,a=%cn",*pa); 19 printf("now,i=%dn",*pi); 20 21 printf("sizeof pa=%dn",sizeof(pa)); 22 //编译器通过sizeof输出的字节数不一定相同,这源于编译器的规定 23 //我这里规定指针都是八个字节,指针字节数与数据类型无关 24 printf("sizeof pa=%dn",sizeof(pi)); 25 26 printf("the addr of a is:%pn",pa); 27 //这里未加间接运算符,所以取出的是pa(指针),指针对应的值是一个地址(a的地址) 28 //故取出一个地址 29 //输出地址用%p来表示 30 printf("the addr of i is:%pn",pi); 31 32 return 0; 33 }
避免访问野指针(未初始化的指针)。如:
#includeint main() { int *a; *a=123; return 0; }
这里没有赋予指针a变量地址,所以指针a会随机指向一个变量地址。如果指向的是系统关键代码的变量,后果不堪设想,当然一般情况下系统会自动中断程序运行并报错



