是否使用索引括号取消引用它?
为指针使用索引括号是否也取消引用它? 为什么打印这个指针的第0个索引两次最终打印两个不同的东西?
#include #include #include using namespace std; int *p; void fn() { int num[1]; num[0]=99; p = num; } int main() { fn(); cout << p[0] << " " << p[0]; }
使用索引括号指针也取消引用它吗?
正确,指针算术相当于数组索引。 p[index]
与*(p+index)
。
为什么打印这个指针的第0个索引两次最终打印两个不同的东西?
因为您使用p
指向局部变量( num
),其范围在fn()
函数结束时结束。 你观察到的是未定义的行为 。 返回指向局部变量的指针是不好的做法,必须避免。
顺便说一句,只是为了看范围效果,如果你将num
数组的定义移到fn()
函数之外,那么你会看到一致的cout
行为。
或者,正如@ Marc.2377建议的那样,为避免全局变量(这是不好的做法),您可以在堆中分配变量( int* num = new int[1];
)。 然后可以从fn()
返回指针p
,但不要忘记在main()
之后调用delete[] p
。
数组被分配连续的内存位置(所有元素都是连续存储的),因此A [i](存在于数组的第i个索引处的元素)将是远离数组A的基地址的内存单元。
因此A [i]相当于*(A + i)。
指针存储地址而不是内容。 因此,局部变量不再存在于函数外部(局部范围),从而在函数外部给出不同的结果。
使用索引括号指针也取消引用它吗?
是的,它确实。 ptr[i]
相当于*(ptr + i)
。
访问超出范围的局部变量num
是未定义的行为。 基本上p
指向局部变量num
。 从fn()
返回后, num
超出范围,因此任何东西都可以存储在其地址中。