格式控制符“%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语言中int *p=G
这句话的作用是:
①声明一个指向整型数据的指针变量p(简称“指针p”);
②并把变量G的地址赋值给p(这个赋值的过程在更多的时候被称为“让指针p指向整型变量G”。
回答你的问题:
(1)p是一个特殊的变量;
(2)p中只能存放地址(又叫指针);
(3)p中只能存放整型变量的地址(也叫整型指针);
(4)所以,p是一个整型指针变量(或整型变量指针);
(5)p的值是变量G的地址,即p==G;
(6)我们可以用下面的运算得到与p相关的其他量值:
&p--得到变量p的地址;
p--得到变量G的地址;
*p--得到变量G的值,*p==G。
%p在 C 语言中用来是打印变量地址的。它是一个格式控制符,p即pointer(指针)的缩写。指针的值是一个表示地址空间中某个存储器单元的整数。%p输出的结果一般是一个十六进制的整数,代表指针的值,附加前缀0x。
扩展资料:
C语言是面向过程的、抽象化的程序开发设计语言,多用于底层开发。C语言可以用简易的方式来编译、处理低级存储器。C语言可以用少量的机器语言并且不需要任何运行环境支持就可以高效率的运行。
C语言具有很强的跨平台特性,可在包括类似嵌入式处理器以及超级计算机等作业平台的许多计算机平台上进行编译。它诞生于美国的贝尔实验室,由B语言发展而来,目前 C语言还在不断的完善。
参考资料:
百度百科-C语言