printf("%p\n",变量);这里变量有几点需要注意,当使用%p个式控制符时,变量必须是地址值(非常关键的一句话)
int a=10;
int *p = &a;
printf("输出指针p代表的地址%p\n",p);
printf("输出变量a的地址%p",&a);
对应的有以下两种常见错误的方式,本人使用GUNgcc编译器,均不会报错,但是却会输出错误值,所以需要非常注意:
正确格式 | 打印结果 | 错误格式 | 打印结果 |
printf("输出指针p代表的地址%p\n",p); | 打印结果就是p存储的地址值 | printf("输出指针p代表的地址%p\n",&p); | 打印结果其实是指针变量P的地址 (注意这个语句本身没有任何错误,只是不能实现我们希望打印p所包含的地址,这个目的) |
printf("输出变量a的地址%p",&a) | 打印结果为变量a的地址 | printf("输出变量a的地址%p",a) | 此情况下,本人编译器会报出一个错误(纤细看下文),且打印出的是a的值,如此语句之前,已经给a赋值 int a =5;则打印出来的就是“输出变量a的地址为5” |
编译器会报一下错误:warning:format ‘%p’expects argument of type ‘void*’,but argument 2 has typeof ‘int’(警告:格式“%p”使用类型为“void*”的参数,但参数2的类型为“int”),也就是格式不匹配错误。
还有一种特殊情况就是字符常量,和指向字符常量的指针,如下
char *p_str = "xixihaha";
printf("输出变量char *p_str的地址%p",p_str);
printf("输出符号常量的地址%p","xixihaha");
以上两种特殊情况,本质上就是c中字符串常量在表达式中会直接将其首地址赋值给指针变量的缘故。