详解:指针和指针类型
【摘要】 详解:指针和指针类型
指针和指针类型!
指针就是地址,我想这句话,目前来说没有多大的毛病!
指针变量就是用来存放地址的,地址是唯一的内存单元
指针的大小在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个字节;
本文章具体想表达的内容到此已经结束,读者要是有想要表达的思维逻辑,请联系笔者!
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)