c语言中%p是什么意思?

还有%hd ?

格式控制符“%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进制字符。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2017-06-12

C语言中%p用来输出指针类型自身的值。

也就是说 %p用来输出地址。 

一、使用方法:

%p一般仅用于printf及同类函数中。形式为

printf("%p", varp);

其中后续参数varp为某一个指针变量。如

int a,*p;
p=&a;
printf("%p %p", p, &a);

这里输出的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输出,可以有更好的移植型和适应性,不会因为更换平台而引起错误。 

第2个回答  2016-04-15
以16进制输出指针内存储的地址

%hd: 输出short类型变量本回答被提问者采纳
第3个回答  2020-01-13
相似回答