指针所占大小由计算机位数决定,与其指向的数据类型无关,P++是指针偏移到其指向位置的下一个内存单元。假如我定义int arr[]={0,1,2,3,4,5,6,7,8,};int *p=arr;那么对利用p++可以遍历数组,p占四个字节,int也占4个字节。但是假如double arr={0,1,2,3,4,5,6,7,8,},按照我的理解,应该会出错呀,double占8个字节,而p++只偏移了四个字节呀。
Comments
登录后评论
Sign In你要是想知道代码到底干了什么可以用Compiler Explorer (godbolt.org)查看反汇编的结果
int的p++:add QWORD PTR [rbp-8], 4
double的p++:add QWORD PTR [rbp-16], 8
在64位机上用32位gcc编译指针大小是4个字节,而64位gcc编译指针大小是8个字节。
指针的加减操作和它指向的类型有关。比如他如果指向一个一字节的数据,那么加减操作是以一字节为单位的,比如如下代码输出是99
#include <iostream>
int main() {
char a[100];
char *p1 = a;
char *p2 = &a[99];
std::cout << p2 - p1;
return 0;
}
而下面代码输出是24
#include <iostream>
int main() {
char a[100];
char *p1 = a;
char *p2 = &a[99];
std::cout << (int *)p2 - (int *)p1;
return 0;
}