我完全犹豫要不要发布这个,但我希望它不会造成问题。
迂腐:大多数其他答案都是错误的:您创建的是不是指向数组的指针。它是一个指向 int 的指针,它指向数组的初始元素。
我犹豫是否发布它,原因很简单,这几乎肯定只是在您的问题中使用了错误的措辞——指向int 的指针几乎肯定是您认为想要的,它就是你真的得到了。
但是,有诸如指向数组的指针之类的东西。它很少有用,因为当/如果你对它进行指针数学运算(包括下标),指向数组的指针会增加它指向的数组的大小。在您的情况下,您分配了 10 个ints。您可以使用指针下标来引用数组中的ints,因此theName[0] 引用第一个int,theName[1] 引用第二个int,依此类推——这正是您通常的做法想要。
如果您正在使用(例如)一个数组数组,并且想要一个可以遍历整行的指针,那么您可能能够真正使用指向数组的指针一次,所以ptr[0] 是第一行,ptr[1] 是第二行,依此类推。例如:
#include <iostream>
static const int x = 20;
static const int y = 10;
int main() {
char data[y][x];
auto ptr_array = &data[0];
char *ptr_char = &data[0][0];
std::cout << "Address of entire array: " << (void *)data << "\n";
std::cout << "char *[0] = " << (void *)ptr_char << "\n";
std::cout << "char *[1] = " << (void *)(ptr_char+1) << "\n";
std::cout << "array *[0] = " << (void *)ptr_array << "\n";
std::cout << "array *[1] = " << (void *)(ptr_array+1) << "\n";
return 0;
}
我已将其更改为使用 char(而不是 int)的数组,以使数学更加明显——sizeof(char) == 1(根据定义),所以它更容易工作出数学。当我在我的机器上运行这段代码时,我得到的地址是:
Address of entire array: 0047FD2C
char *[0] = 0047FD2C
char *[1] = 0047FD2D
array *[0] = 0047FD2C
array *[1] = 0047FD40
如您所见,ptr[0] 将数组的地址作为一个整体保存。然而,使用指向char 的指针,ptr[1] 拥有一个更大的地址。然而,指向数组的指针拥有一个大于 0x40 - 0x2C = 0x14 = 20 的地址——这符合我们给数组 (20) 的 X 维度。换句话说,我们确实有一个指向数组的指针,并且该指针上的指针算术(或等效地,下标)一次只针对整个数组起作用。
我会重复一遍:至少如果我们忽略您几乎肯定应该使用std::vector这一事实,那么您想要的类型和您获得的类型都是pointer to int .有pointer to array 这样的类型,但几乎可以肯定不是想要你真正想要的。