我正在尝试在其内部交换一个对象。它可以工作,但是当我添加一个析构函数时,它会给我一个双重免费错误。有没有办法防止这种情况?我说的方法是void swap(SimpleArray &object)。
(抱歉,如果您在我的帖子中有错误信息之前阅读了此内容...)
#include "TestType.h"
class SimpleArray {
    private: 
        TestType* pArray;
        //TestType* temp;
    public:
        SimpleArray(TestType *array)
        {
            this->pArray = array;
        }
        ~SimpleArray() { delete[] pArray; }
        SimpleArray() { pArray = 0;}
        SimpleArray(const SimpleArray& arg){ pArray = arg.pArray; }
        ~SimpleArray() { delete[] pArray; }
        TestType * get() const{ return pArray; }
        bool isNonNull() const { return pArray != 0; }
        //TestType* pArray;
        void reset(TestType*& p) {this->pArray = p; }
        void reset() { pArray = 0; }
        void swap(SimpleArray &object) { SimpleArray temp; temp = object; object = *this; *this = temp;}
        TestType * release() { pArray = 0; return pArray; }
        TestType& getReference(int a) { return *pArray; }
};
这可行,但是一旦我添加了析构函数,它就会给我一个“双重释放或损坏错误”。我该如何解决这个问题?这是 main 中的函数,它搞砸了。
bool testGetReleaseSwap() {
    SimpleArray array1;
    if (array1.get() != 0)
        return false;
    TestType* directArray1 = new TestType[100];
    array1.reset(directArray1);
    if (array1.get() != directArray1)
        return false;
    TestType* directArray2 = new TestType[50];
    SimpleArray array2(directArray2);
    array1.swap(array2);
    if (array1.get() != directArray2 || array2.get() != directArray1)
        return false;
    array2.swap(array1);
    if (array1.get() != directArray1 || array2.get() != directArray2)
        return false;
    array1.swap(array1);
    if (array1.get() != directArray1)
        return false;
    if (array1.release() != directArray1 || array2.release() != directArray2)
        return false;
    if (array1.get() != 0 || array2.get() != 0)
        return false;
    delete[] directArray1;
    delete[] directArray2;
    return true;
}