都是二进制有啥不能转? 编译器才无论呢,你说这4Bytes 是地址就是地址,你说是数值就是数值函数
int a = 66; //66 = 0x42 printf("该平台指针类型大小是%ld\n",sizeof(&a)); printf("该平台INT类型大小是%ld\n",sizeof(a)); printf("%p\n",&a);//输出整形变量a的地址,0x7ffeefbff5fc, 0x7ffeefbff5fc 0x7ffeefbff5fb 0x7ffeefbff5fa 0x7ffeefbff5f9 这4个字节一块儿存储了ox42. 由于C语言的栈空间的分配是方向从高地址到低地址的
int a = 10; spa
int *p = &a;操作系统
当咱们定义一个变量的时候到底发生了什么?指针
操做系统会在内存堆(malloc)或者栈分配必定大小的连续空间来存储变量的值(对于指针变量就是存储另一个变量的地址)code
这里的变量a和p 就是这一块连续地址的首地址的别名,就像ip地址和域名的关系,域名只是ip地址的别名而已.ip
a存储是10,p存储的是a的地址.内存
在函数内部如何改变外部普通变量(非指针变量)的值?编译器
int a = 66; //从0x7ffeefbff5fc开始分配了连续4个字节的内存空间,存储66(十进制表示),0x7ffeefbff5fc是首地址 int *addr1 = &a; //二级指针 int **addr2 = &addr1; printf("%p\n", &addr2); //输出0x7ffeefbff5e8,这是addr2的内存地址(酒店房间的门牌号,房间里面放着addr1的地址) printf("%p\n", *addr2); //输出0x7ffeefbff5fc,addr2存储的是addr1的内存地址(*就是取房间里放的地址牌) printf("%p\n", **addr2);//输出0x42
&变量名
就是取变量在内存中的首地址(普通变量和指针变量都是如此)域名
*指针变量的变量名
就是取这个指针变量所存储的内容(多是地址,也多是值)编译
指针变量才有 取* 操做,普通变量是没有的, 能够屡次进行 取*操做,顺藤摸瓜 !
在函数内部改变 外部指针变量 的“指向”? 答案就是二级指针.
int x = 5; int y = 10; void change_addr_value(int **p) { *p = &y; } int *addr3 ; addr3 = &x; printf("value=%d\n",*addr3); change_addr3_value(&addr3); printf("value=%d\n",*addr3);