-2
template <class T>
List<T>::~List()
{                
   ListItem<T> *temp,*temp1;
   temp=head;         
   while (temp->next!=NULL)         
   {
          temp1=temp;
          temp=temp->next;
          delete [] temp1;
   }        
}

/* This class just holds a single data item. */ 
template <class T>
struct ListItem
{
vector<string> words;
T value;
ListItem<T> *next;
ListItem<T> *prev;

ListItem(T theVal)
{
    this->value = theVal;
    this->next = NULL;
    this->prev = NULL;
}
};

template <class T>
void List<T>::insertAtHead(T item)
{
 ListItem<T> *node=new ListItem<T>(item);
 if (head==NULL)
 {
     head=node;
 }
 else
 {
     node->next=head;
     head->prev=node;
     head=node;
 }           
}
int main()
{
List<int> Mylist;
for (int i=20;i>0;--i)
{
    Mylist.insertSorted(i);
}
cout<<Mylist.getTail()->value<<endl;
system("PAUSE");
return 0;

}

我正在使用类和模板制作链接列表。当我运行此代码时,它运行良好,但是当我按下一个键退出时,出现以下错误:“main.exe 已停止工作”我正在使用 Dev c++。我有添加了析构函数代码。我没有看到任何问题。

4

1 回答 1

1

您必须始终newdeletenew[]配对delete[],但您有不匹配

ListItem<T> *node=new ListItem<T>(item);
//                ^^^

delete [] temp1;
//^^^^^^^         
于 2013-02-18T11:54:15.973 回答