我知道保存数组的变量存储数组的地址,对其进行任何索引操作都在同一数组上执行指针算术。在修读基础知识的过程中,我发现了这一点。
int main() {
int equal;
char c[] = {'a', 'b', 'c'};
char* p = c;
char* q = &c[0];
cout<<*p<<endl;
cout<<*q<<endl;
cout<<&p<<endl;
cout<<&q<<endl;
if (c==q) {
equal=1;
}
cout<<equal<<endl;
}
//output
a
a
0x7ffda22e0a60
0x7ffda22e0a68
1
取消引用p,q给我相同的值,但是p,q的地址不同。这怎么可能? 最佳答案
分配数组时,该变量会将数组分配给指向该数组开头的位置。该数组的开头是内存中的地址。
数组开头的地址是其第一个元素的地址,因此无论您使用char *x = arr;
还是char *y = &arr[0]
都无关紧要;他们将是相同的。
现在x
和y
已分配在堆栈上,并且是两个不同的变量,因此它们显然具有不同的地址。因此
&x == &y // false
编写T* x
时,您要声明一个指向T
类型的对象的指针。该指针x
本质上是一个整数值,其中包含代表内存中地址的数字。关于c++ - C++数组指针如何具有不同的位置,但指向相同的元素?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/64204001/