【问题标题】:Why am I getting a "pointer being freed was not allocated" error for array of pointers in C++?为什么我在 C++ 中收到指针数组的“未分配指针”错误?
【发布时间】:2016-11-04 08:53:24
【问题描述】:

我正在使用一个动态的指针数组。该项目需要此设置。当我执行时,我收到一个错误,即未分配被释放的指针。

更新为添加动态代码。当我尝试访问数组时,函数会抛出错误的访问错误,并在删除动态数组时出现段错误。

class Person
{
private:
string firstName;
string lastName;
int age;
int telNum;
int numAddrs;
//Address* addrs[10];
Address* addrs;

public:
Person(string, string, int, int);
Person();
Person(const Person &p);

~Person();

void setFirstName(string);
void setLastName(string);
void setAge(int);
void setTelNum(int);
void setAddress(Address*);
void setNumAddrs(int);

string getFirstName();
string getLastName();
int getAge();
int getTelNum();
Address* getAddress();
int getNumAddrs();

void displayPerson();
void addAddress(Address &newAddr);

Person& operator =(const Person &RHS);


};

Person::Person()                                //default
{
firstName = "John";
lastName = "Doe";
age = -1;
telNum = -1;

numAddrs = 0;               //current number of addresses for this person

addrs = new Address*[10](); //throws error, won't compile
//new dynamic array of pointers, initialize to NULL

}

Person::Person(string first, string last, int y, int t)
{                                               //constructor to  initialize              Person
firstName = first;
lastName = last;
age = y;
telNum = t;

numAddrs = 0;                   //current number of addresses for this     person

addrs = new Address*[10](); throws error, won't compile
//new dynamic array of pointers, initialize to NULL

}


Person::Person(const Person &p)     //copy constructor
{
this->firstName = p.firstName;
this->lastName = p.lastName;
this->age = p.age;
this->telNum = p.telNum;
this->numAddrs = p.numAddrs;


delete [] addrs;        //delete previous dynamically allocated memory

addrs = new Address*[10](); //throws error, won't compile
//new dynamic array of pointers,     initialize to NULL

for (int i = 0; i<10; i++)    //copy addresses to new object
{
this->addrs[i] = p.addrs[i];
}

}

【问题讨论】:

  • addrs = *new Address*[10](); 它在您的代码中的实际显示方式,还是您添加了 *s 来强调?
  • for (int i=0; i &lt; 10; i++) delete [] addrs; 您正试图删除同一个指针 10 次。第一次工作,第二次表现出未定义的行为。
  • 请不要注释掉您询问的代码部分。 SO 代码高亮使 cmets 变暗,使您很难看到对您的问题最重要的代码。
  • @IgorTandetnik 第一次也不行,因为addrs 是一个数组,而不是一个指针。
  • 是的,*新地址*[10]();是它在代码中的样子。它抛出了一个错误并建议修复添加另一个 *

标签: c++ arrays pointers dynamic


【解决方案1】:

addrs 不是指针,而是数组。您不需要使用new 为其分配空间,因为它的内存是作为类对象的一部分分配的。它是一个指针数组,所以需要在构造函数中为每个元素分配内存:

for (int i = 0; i < 10; i++) {
    addrs[i] = new Address;
}

然后在析构函数中,你需要删除这些地址中的每一个。

for (int i = 0; i < 10; i++) {
    delete addrs[i];
}

但是,有一个问题。您的赋值运算符将所有 addrs[i] 从 src 复制到目标。所以现在你有两个 Person 对象,它们指向相同的 Address 对象。如果其中任何一个被破坏,它将释放所有Address 对象,然后另一个Person 将在其addrs 数组中包含无效指针。

不清楚为什么你需要一个指针数组而不是一个 Address 对象数组:

Address addrs[10];

那么你就不需要使用newdelete

此外,在现代 C++ 中,通常认为使用 std::vector 之类的容器会更好。您还可以使用智能指针类来处理在多个容器之间共享同一个指针。

【讨论】:

  • //地址* addrs;是指针,对吗?这就是我在程序的动态版本中使用的。赋值指定我们必须使用一个指针数组。没有它们,程序可以正常运行,但我正在尝试为这个特定的任务实现它们。
  • 在问题中你有Address * addrs[10]。这是一个包含 10 个指针的数组。
  • 如果你需要一个动态的指针数组,它应该是Address **addrs
  • 正确。这就是我在这里的意图。但是当我尝试动态分配时遇到了问题。
  • 你需要做addrs = new Address*[10]然后一个循环设置addrs[i] = new Address
猜你喜欢
  • 2018-01-03
  • 1970-01-01
  • 2015-03-20
  • 1970-01-01
  • 2016-01-02
  • 1970-01-01
  • 2018-07-29
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多