我创建了一个双链表类,并尝试将它与我创建的Vector类一起使用,以便创建链接列表的向量,但是在程序结束时,我似乎收到错误
malloc: *** error for object 0x100100be0: pointer being freed was not allocated
我假设它与析构函数有关,也就是Xcode指向我的地方。我该如何规避这个?我认为我的析构函数工作正常,但我想我错了。
测试文件:
#include <iostream>
#include <string>
#include "Vector.h"
#include "doubleLL.h"
using namespace std;
int main (int argc, const char * argv[])
{
Vector<double_llist<string> > listWords(27);
double_llist<string> numbers;
numbers.push_back("one");
numbers.push_back("two");
numbers.push_back("three");
listWords[0] = numbers;
listWords[0].print();
}
doubleLL.h:
#ifndef DOUBLELL_H
#define DOUBLELL_H
#include <iostream>
using namespace std;
template <class T>
class double_llist {
private:
struct node {
T data;
node* prev;
node* next;
node(T t, node* p, node* n) : data(t), prev(p), next(n) {}
int count;
};
node* head;
node* tail;
public:
double_llist() : head( NULL ), tail ( NULL ) {}
template<int N>
double_llist( T (&arr) [N]) : head( NULL ), tail ( NULL )
{
for( int i(0); i != N; ++i)
push_back(arr[i]);
}
bool empty() const { return ( !head || !tail ); }
operator bool() const { return !empty(); }
void push_back(T);
void push_front(T);
T pop_back();
void removeNode(node *);
void print();
node* search(T data) {
node *tempNode;
if (head == NULL) {
// List is empty
return NULL;
} else {
tempNode = head;
while (tempNode != NULL) {
if (tempNode->data == data) {
tempNode->count += 1;
if (tempNode->count >= 4) {
// Push tempNode to front of linked list
push_front(tempNode->data);
head->count = tempNode->count;
removeNode(tempNode);
}
return tempNode;
} else {
tempNode = tempNode->next;
}
}
}
return NULL;
}
~double_llist()
{
while(head)
{
node *temp(head);
head = head->next;
delete temp;
}
}
double_llist& operator = ( const double_llist& other )
{
if (this == &other) {
return *this;
}
while (!empty()) {
pop_back();
}
for (node *itr = other.head->next; itr != other.tail; ++itr) {
tail = new node(other.head->data, itr, NULL);
}
return *this;
}
double_llist(const double_llist& other)
{
head = new node;
tail = new node;
head->tail = tail;
tail->prev = head;
*this = other;
}
};
template <class T>
void double_llist<T>::push_back(T data)
{
tail = new node(data, tail, NULL);
if( tail->prev )
tail->prev->next = tail;
if( empty() )
head = tail;
}
template <class T>
void double_llist<T>::push_front(T data) {
head = new node(data, NULL, head);
if( head->next )
head->next->prev = head;
if( empty() )
tail = head;
}
template <class T>
T double_llist<T>::pop_back()
{
node* temp(tail);
T data( tail->data );
tail = tail->prev ;
if( tail )
tail->next = NULL;
else
head = NULL ;
delete temp;
return data;
}
template <class T>
void double_llist<T>::removeNode(node *n) {
if(n == this->head) {
this->head=this->head->next;
this->head->prev = NULL;
} else if (n==this->tail) {
this->tail=this->tail->prev;
this->tail->next = NULL ;
} else {
n->prev->next = n->next;
n->next->prev = n->prev;
}
}
template <class T>
void double_llist<T>::print() {
node* temp;
temp = this->head;
int i = 0;
while(temp != NULL)
{
if (i < 3) {
cout << temp->data << endl;
temp=temp->next;
++i;
} else {
return;
}
}
cout << endl;
return;
}
#endif
错误似乎来自doubleLL,因此未包含Vector.h。如果需要帮助我指出正确的方向,请告诉我。
谢谢!
答案 0 :(得分:8)
你不遵守3的规则:If you have either of a destructor, a copy constructor or an assignment operator implemented, you should implement all three.
我介入了你的代码,似乎有很多对象副本被创建然后被销毁,但由于复制没有正确完成,已经破坏了内存再次删除。
正确实施这些问题将不复存在。
编辑:
我刚刚完成了这些的基本实现:
double_llist& operator = ( const double_llist& other )
{
head = NULL;
tail = NULL;
return *this;
}
double_llist(const double_llist& other)
{
head = NULL;
tail = NULL;
}
代码不再崩溃。
第二次编辑:
double_llist& operator = ( const double_llist& other )
{
head = NULL;
tail = NULL;
node* otherNode = other.head;
while ( otherNode )
{
push_back(otherNode->data);
if ( otherNode == other.tail )
break;
otherNode = otherNode->next;
}
return *this;
}
double_llist(const double_llist& other)
{
head = NULL;
tail = NULL;
node* otherNode = other.head;
while ( otherNode )
{
push_back(otherNode->data);
if ( otherNode == other.tail )
break;
otherNode = otherNode->next;
}
}