我们知道指针指向的是内存中的地址,那么我们先看看变量在内存中的地址是什么样的(选择解决方案平台为x86/32位系统,内存地址占4个字节,在x64系统中,内存地址占8个字节)
按F10进行逐过程调试,当调试走过定义int a;后,在调试>窗口>打开内存和监视窗口,在地址中输入&a取地址a。
此时可以看到a在内存中的地址,整型a占4个字节,指针拿到的是第一个字节的内存地址,地址0x0050FDF0,值0a为16进制转换为10进制为10,后面三个地址末尾分别为F1,F2,F3,都被int a;占用。这就是指针取地址的流程。
下面展示指针的使用方法,&a取地址,%p专门用来打印地址,int* pa = &a;定义了指针指向a,然后把a的地址赋值给pa,此时打印pa即为a的内存地址。int用来说明指向对象的类型。
*pa是通过pa存储的地址找到a,对*pa操作,等同于对a操作。
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
//指针(x86平台32位,指针指向内存地址占4个字节,x64占8个字节)
int main()
{
int a = 10;
printf("%p\n", &a);//%p专门用来打印地址的,&a取地址
int* pa = &a;//pa是用来存放地址的,在C语言中pa是指针变量
//*说明pa是指针变量
//int说明pa执行的对象是int类型的
printf("%p\n", pa);
//通过地址找到存储的变量
*pa = 20;//*解引用操作,*pa通过pa里的地址找到a,并操作a
printf("%d\n", a);
printf("%d\n", *pa);
char ch = 'w';
char* pc = &ch;//*说明pc是指针变量
//char说明pc执行的对象是char类型的
printf("%p\n", pc);
return 0;
}