#include<stdio.h>
void main()
{
int number=0;
int *pointer=NULL;
number=10;
printf("number's address:%p\n",&number);
printf("number's value:%d\n",number);
pointer=&number;
printf("pointer's address:%p\n",&pointer);
printf("pointer's value:%p\n",pointer);
printf("value pointed to:%d\n ",*pointer);
}
这里用%p输出各个变量的地址,我想问一下各位程序高手,这里的%p的含义到底是什么,是什么格式的,是不是和%x相同的,谢谢了
格式控制符“%p”中的p是pointer(指针)的缩写。指针的值是语言实现(编译程序)相关的,但几乎所有实现中,指针的值都是一个表示地址空间中某个存储器单元的整数。printf函数族中对于%p一般以十六进制整数方式输出指针的值,附加前缀0x。
%p是打印地址的, %x是以十六进制形式打印, 完全不同!另外在64位下结果会不一样, 所以打印指针老老实实用%p .
测试代码 :
#include<stdio.h>
int main()
{
int arr[5] = {10,20,30,40,50};
int i = 0;
printf("数据:\n\n");
printf("十进制表示的数据:\n");
for(i = 0 ; i < 5 ; i++)
{
printf("%d\t",arr[i]);
}
printf("\n\n指针形式十六进制表示的数据:\n");
for(i = 0 ; i < 5 ; i++)
{
printf("%p\t",arr[i]);
}
printf("\n\n普通十六进制表示的数据:\n");
for(i = 0 ; i < 5 ; i++)
{
printf("%x\t",arr[i]);
}
printf("\n\n\n地址:\n");
printf("\n\n十进制表示的地址:\n");
for(i = 0 ; i < 5 ; i++)
{
printf("%d\t",&arr[i]);
}
printf("\n\n指针形式十六进制表示的地址:\n");
for(i = 0 ; i < 5 ; i++)
{
printf("%p\t",&arr[i]);
}
printf("\n\n普通十六进制表示的地址:\n");
for(i = 0 ; i < 5 ; i++)
{
printf("%x\t",&arr[i]);
}
printf("\n");
}
输出结果
C是一种通用的编程语言,广泛用于系统软件与应用软件的开发。于1969年至1973年间,为了移植与开发UNIX操作系统,由丹尼斯·里奇与肯·汤普逊,以B语言为基础,在贝尔实验室设计、开发出来。
C语言具有高效、灵活、功能丰富、表达力强和较高的可移植性等特点,在程序设计中备受青睐,成为最近25年使用最为广泛的编程语言[2]。目前,C语言编译器普遍存在于各种不同的操作系统中,例如Microsoft Windows、macOS、Linux、Unix等。C语言的设计影响了众多后来的编程语言,例如C++、Objective-C、Java、C#等。
二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言订定了一套完整的国际标准语法,称为ANSI C,作为C语言的标准。二十世纪八十年代至今的有关程序开发工具,一般都支持匹配ANSI C的语法。