- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我现在很迷茫。我做了一个 vector 类。一切都按照我希望的方式工作,直到最后。当调用析构函数时,我收到一条错误消息:调试断言失败 BLOCK_TYPE_IS_VALID(pHead->nblockuse)。我在 SO 上看到了很多这样的问题,但我尝试过的方法没有奏效。
.h 的一部分
private:
int* _myArray;
int _size;
int _capacity;
#include "File.h"
const string RETURN_CARRIAGE_STR = "\n";
const string SIZE_STR = "Size ";
const string CAPACITY_STR = "Capacity ";
const int INITIAL_CAPACITY = 2;
int main(void)
{
cout << "\nCreating a vector Sam of size 4.";
MyVector sam( 4 );
cout << "\nPush 12 values into the vector.";
for (int i = 0; i < 12; i++)
sam.push_back(i);
cout << "\nHere is sam: ";
cout << sam;
cout << "\n---------------\n";
cout << "\nCreating a vector Joe of size 4.";
MyVector joe( 4 );
cout << "\nPush 6 values into the vector.";
for (int i = 0; i < 6; i++)
joe.push_back(i * 3);
cout << "\nHere is joe: ";
cout << joe;
cout << "\n---------------\n";
cout << "\nTest the overloaded assignment operator \"joe = sam\": ";
joe = sam;
cout << "\nHere is sam: ";
cout << sam;
cout << "\n---------------\n";
cout << "\nHere is joe: ";
cout << joe;
cout << "\n---------------\n";
// pass a copy of sam by value
PrintV(sam);
cout << endl;
system("PAUSE");
}
void PrintV(MyVector v)
{
cout << "\n--------------------\n";
cout << "Printing a copy of a vector\n";
cout << v;
}
// Default Constructor
MyVector::MyVector()
{
_myArray = new int[INITIAL_CAPACITY];
_size = 0;
_capacity = INITIAL_CAPACITY;
//cout << "Default Constructor" << endl;
}
MyVector::MyVector(int aSize)
{
_myArray = new int[aSize];
_size = 0;
_capacity = aSize;
//cout << "Parameterized Constructor" << endl;
}
MyVector::~MyVector()
{
if(_myArray != NULL)
{
delete[] this->_myArray; // --------------This is where I get an error
this->_myArray = NULL;
}
//cout << "Destructor" << endl;
}
int MyVector::GetSize()
{
return _size;
//cout << " size";
}
int MyVector::GetCapacity()
{
return _capacity;
//cout << _capacity << " capacity" << endl;
}
void MyVector::Clear()
{
int* resize_arr = new int[INITIAL_CAPACITY];
delete[] _myArray;
_myArray = resize_arr;
_capacity = INITIAL_CAPACITY - 1;
_size = 0;
}
void MyVector::push_back(int newValue)
{
if(_size < _capacity)
{
_myArray[_size] = newValue;
}
else {
int* resize_arr = new int[_capacity*2];
for(int i = 0; i <= _size; i++)
resize_arr[i] = _myArray[i];
resize_arr[_size] = newValue;
delete[] _myArray;
_myArray = resize_arr;
_capacity = _capacity * 2;
}
_size++;
//cout << _size << " size" << endl;
}
int MyVector::at(int idx)
{
return _myArray[idx];
//cout << _myArray[idx] << " value at index" << endl;
}
ostream& operator<<(ostream& os, MyVector& vec)
{
ostringstream convert;
ostringstream convertCap;
convert << vec.GetSize();
string sizeConverted = convert.str();
convertCap << vec.GetCapacity();
string capConverted = convertCap.str();
string firstTemp = "";
firstTemp = SIZE_STR + sizeConverted + RETURN_CARRIAGE_STR + CAPACITY_STR + capConverted + RETURN_CARRIAGE_STR;
for(int idx = 0; idx < vec.GetSize(); idx++)
{
string secondTemp = "";
ostringstream convertSize;
convertSize << vec.at(idx);
string vecAtIdx = convertSize.str();
secondTemp = vecAtIdx + RETURN_CARRIAGE_STR;
cout << secondTemp;
}
os << firstTemp;
return os;
}
MyVector& MyVector::operator=(MyVector& setterVect)
{
delete [] _myArray;
//MyVector* mPtr = new MyVector();
_myArray = setterVect._myArray;
_capacity = setterVect._capacity;
_size = setterVect._size;
return *this;
}
最佳答案
_myArray = setterVect._myArray;
您的复制赋值运算符已损坏。在该运算符之后,两个实例都具有相同的 _myArray
值。因此,一旦一个被破坏,另一个就会留下一个指向不再存在的东西的指针。
故事的寓意——使用 std::vector
。
关于c++ - Deconstructor 的调试断言失败 BLOCK_TYPE_IS_VALID(pHead->nblockuse),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13812718/
我正在阅读 C# 7.0 new stuff ,至少从给出的示例来看,我无法理解“解构函数”的用法。 它只是语法糖吗? 如果有人能阐明它,那就太好了。 最佳答案 它是新元组语法的一部分 - 与 Tup
这个问题在这里已经有了答案: What is The Rule of Three? (8 个答案) 关闭 3 年前。 我正在尝试使用 STL 学习 C++,我注意到 deconstruct 调用比
我是一名计算机科学专业的学生,任务是创建一个动态数据结构,链表。我目前正在研究单向链表,并已成功构建添加、删除和转储所有节点数据的功能。 但是,记得我的“高级编程”讲师说过,为了避免混淆和其他问题
我现在很迷茫。我做了一个 vector 类。一切都按照我希望的方式工作,直到最后。当调用析构函数时,我收到一条错误消息:调试断言失败 BLOCK_TYPE_IS_VALID(pHead->nblock
我有一个类型 resultType的 Context.this.type#c#universe#Type .我需要将它与 Unit 匹配类型。我试过 resultType match { case
我有一个私有(private)成员(member) std::list myclass_list; 它是 OtherClass 的一部分。 当我关闭控制台应用程序时,会调用 OtherClass 的空
我是一名优秀的程序员,十分优秀!