2014-02-09 87 views
0

雙重空閒或損壞(fasttop)錯誤。自定義矢量類的解構器

我正在努力從頭開始構建矢量類,並與解構器混淆。

類是:

template <class T> 
class Vector 
{ 
public: 
    typedef T * iterator; //pointer to type T 

    Vector();        
    ~Vector();      

    void reserve(unsigned int capacity); 
    void resize(unsigned int size);  

private: 
    unsigned int my_size; 
    unsigned int my_capacity; 
    T * buffer; 
}; 

template <class T> 
Vector<T>::Vector() 
{ 
my_size = 0; 
my_capacity = 0; 
buffer = 0; 
} 

template <class T> 
Vector<T>::~Vector(){ 
    delete [] buffer; 
    my_size = my_capacity = 0; 
} 

template <class T> 
void Vector<T>::reserve(unsigned int new_capacity){ 
    int * new_buffer = new T[new_capacity]; 
    for(int i=0; i<my_size;i++){ 
     new_buffer[i] = buffer[i]; 
    } 
    my_size += new_capacity; 
    my_capacity += new_capacity; 
    buffer = new_buffer; 
    delete new_buffer; 
} 

template <class T> 
void Vector<T>::resize(unsigned int new_size){ 
    //if new_size < size, change size. 
    if(new_size < size) 
    { 
     size = new_size; 
    } else { 
     if(new_size > my_capacity){ //increase capacity for larget size 
      while(my_capacity < new_size){ 
       reserve(my_capacity+5); 
      } 
     } 
     for(int i = my_size; i < new_size; i++){ 
      buffer[i] = T(); 
     } 
     my_size = new_size; 
    } 
} 

調用代碼:

int main() 
{ 
    Vector<int> v; 
    v.reserve(2); 
    assert(v.capacity() == 2); 
    cout << "SUCCESSFUL!!!\n"; 
} 

我得到了成功的輸出,但它是在解構叫,我越來越相信錯誤。

+1

我們需要更多的代碼來確定問題。向我們展示課程並告訴我們你如何使用課堂。 – 0x499602D2

+0

更好的是,展示一個完整的代碼示例(包括一個主函數),用於編譯和演示問題。 –

+0

對不起,我爲了學習而這樣做。如果錯誤不在解構器中,那麼不想發佈太多的代碼,那麼我需要繼續尋找。 –

回答

0

由於多種原因,您的儲備功能不正確。相反,在buffer = new_buffer之前移動該函數的最後一行,並將其更改爲delete [] buffer。在分配新數據之前,您需要刪除向量中以前的內容。寫入的方式是分配一個新緩衝區(丟失舊緩衝區的軌道),然後從新緩衝區中刪除所有數據。所以,當解構器命中時,你正在刪除一個沒有任何內容的指針。