格式控制符“%p”中的p是pointer(指针)的缩写。指针的值是语言实现(编译程序)相关的,但几乎所有实现中,指针的值都是一个表示地址空间中某个存储器单元的整数。printf函数族中对于%p一般以十六进制整数方式输出指针的值,附加前缀0x。
%p是打印地址的, %x是以十六进制形式打印, 完全不同!另外在64位下结果会不一样, 所以打印指针老老实实用%p 。
扩展资料:
%x同样输出16进制形式,不过%x对应的是int型,也就是说,其输出长度与系统int型占的字节数相等回。如32位编译器,int型占4位字节,那么%x输出的结果最多为16个16进制字符。
而%p输出宽度取决于系统地址总线位数,即16位最多输出4位16进制字符,32位最多输出8位16进制字符,64位最多输出16位16进制字符。
C语言中%p用来输出指针类型自身的值。
也就是说 %p用来输出地址。
一、使用方法:
%p一般仅用于printf及同类函数中。形式为
printf("%p", varp);
其中后续参数varp为某一个指针变量。如
int a,*p;这里输出的p和&a都是int*型。
二、功能:
%p格式符会输出指针本身的值,也就是指针指向的地址值。
该输出为16进制形式,具体输出值取决于指针指向的实际地址值。
三、与%x区别:
%x同样输出16进制形式,不过%x对应的是int型,也就是说,其输出长度与系统int型占的字节数相等。如32位编译器,int型占4位字节,那么%x输出的结果最多为16个16进制字符。
而%p输出宽度取决于系统地址总线位数,即16位最多输出4位16进制字符,32位最多输出8位16进制字符,64位最多输出16位16进制字符。
所以用%p输出地址,相对于用%x输出,可以有更好的移植型和适应性,不会因为更换平台而引起错误。