你只分配的item *
指针数组,你需要分配的内存每个item
也,如:
struct item // naming it 'items' might be confusing, and was used inconsistently
// in your code sample
{
int member1;
int member2;
};
int N=5;
item **ptr=new item *[N];
for(int i = 0; i < N; ++i)
{
ptr[i] = new item();
}
访问您的结构成员如下:
ptr[2]->member1 = 42; // Sets member1 of the 3rd item element to 42
注意,你需要在某个地方释放分配的内存如下:
for(int i = 0; i < N; ++i)
{
delete ptr[i];
}
delete [] ptr;
我一般用于c++你会更好使用C++标准的容器,如:
#include <vector>
int N = 5;
std::vector<item> myItems;
myItems.resize(N,item());
myItems[2].member1 = 42; // Sets member1 of the 3rd item element to 42
这将为您在内部完成所有内存管理。
如果您使用c++11,并在所有使用std::array
不需要动态大小的数组,你甚至能够避免堆分配的内存:
#include <array>
std::array<item,5> myItems; // Size is fixed to 5, you can't use a variable here
myItems[2].member1 = 42; // Sets member1 of the 3rd item element to 42
理想的解决方案可能是一个'的std ::矢量- '或'STD: :vector
>'。 –
chris