指针就是地址,我想这句话,目前来说没有多大的毛病!
指针变量就是用来存放地址的,地址是唯一的内存单元
指针的大小在32位平台上是4字节,在64位平台上是8字节!
因此:
各指针所占字节,sizeof()所得结果是一样的,对于将信将疑的读者,下面请看笔者代码:
#include <stdio.h> int main() { int a = 10; int* pa = &a; char ch = "abc"; char* pc = &ch; float fl = 9.0; float* pf = &fl; double dl = 5.0; double* pb = &dl; short so = 1; short* ps = &so; printf("%d\n", sizeof(pa)); printf("%d\n", sizeof(pc)); printf("%d\n", sizeof(pf)); printf("%d\n", sizeof(pb)); printf("%d\n", sizeof(ps)); }
笔者运转出来的代码为: 注意这里是64位平台所以显示的结果为8(需要注意不是所有的平台都是8,在32位平台结果是4)
但是我们需要注意:
对于; char*的指针解引用访问1个字节
int*的指针解引用访问4个字节
double*的指针解引用访问8个字节
下面来看用代码的分析情况:
#include <stdio.h> int main() { int a = 0x11223344; //十六位进制数字 int* pa = &a; char* pc = &a; printf("pa=%p\n", pa); //用%p来打印地址 printf("pa=%p\n", pc); printf("\n"); //移动1个位地址,看看移动几个字节 printf("pa=%p\n", pa+1); printf("pa=%p\n", pc+1); return 0; }
在这里pa与pa+1; pc与pc+1; 分别指地址往后移动一位!
大家看代码的运行结果就可以知道:
char*的指针解引用访问1个字节 int*的指针解引用访问4个字节
指针类型决定了指针的步长(向前或者向后走一步,走多大的距离)
因此,可以得出以下结论:
int*指针+1: 意思是跳过1个整型,也就是向后走4个字节;
char*指针 +1: 意思是跳过1个字符,也就是向后走1个字节;
double指针+1:意思是跳过1个double,也就是向后走8个字节;
short指针+1: 意思是跳过1个short,也就是向后走2个字节;
本文章具体想表达的内容到此已经结束,读者要是有想要表达的思维逻辑,请联系笔者!