gpt4 book ai didi

c++ - 复制构造函数不是深度复制,错误返回数组为空

转载 作者:行者123 更新时间:2023-11-30 04:48:21 26 4
gpt4 key购买 nike

我正在为学校做一个项目,它需要复制构造函数、析构函数等。当我使用复制构造函数时抛出一个错误,提示数组为空,我认为复制构造函数不工作。

当我删除复制构造函数时,程序可以运行,这意味着问题可能发生在该函数中。

template<class T>
class DynArray {
public:

DynArray<T>(){
ptr = new T[Capacity];
this->Capacity = 2;
this->Size = 0;
}

DynArray<T>(T n) {
ptr = new T[Capacity];
this->Capacity = n;
this->Size = 0;
}

DynArray<T>(const DynArray& orig) {
cout << "Copy" << endl;
ptr = new T[Size];
*ptr = *(orig.ptr);
}

DynArray<T>& operator=(const DynArray<T>& orig) {
if(this != &orig) {
delete[] ptr;
ptr = new T[Size];
*ptr = *(orig.ptr);
}
return *this;
}

void push_back(const T& n) {
if (Size >= Capacity) {
adjust(Capacity * 2);
}
ptr[Size] = n;
Size++;
}

void adjust(T a) {
cout << "grow" << endl;
T* arr = new T[a];
for (int i = 0; i < Capacity; ++i) {
arr[i] = ptr[i];
}
Capacity = a;
ptr = arr;
}

T& back() {
if(Size == 0) {
throw runtime_error("Array is empty");
}
return ptr[Size - 1];
}

T& front() {
if(Size == 0) {
throw runtime_error("Array is empty");
}
return ptr[0];
}

private:
T* ptr = nullptr;
int Capacity;
int Size;

主要内容:

#include <iostream>
#include "dynarray.h"
using namespace std;

int main( )
{
const char START = 'A';
const int MAX = 12;

// create a vector of chars
DynArray<char> vectD;

// push some values into the vector
for (int i = 0; i < MAX; i++)
{
vectD.push_back(START + i);
}

// remove the last element
vectD.pop_back();

// add another value
vectD.push_back('Z');

// test memory management
DynArray<char> vectD2 = vectD;
// display the contents
cout << "\n[";
for (int i = 0; i < vectD2.size() - 1; i++)
{
cout << vectD2.at(i) << ", ";
}

cout << "..., " << vectD2.back() << "]\n";

DynArray<char> vectD3;
vectD3 = vectD2;
cout << "\n[";
for (int i = 0; i < vectD3.size() - 1; i++)
{
cout << vectD3.at(i) << ", ";
}
cout << "..., " << vectD3.back() << "]\n";

vectD3.front() = '{';
vectD3.back() = '}';
cout << vectD3.front();
for (int i = 1; i < vectD3.size() - 2; i++)
{
cout << vectD3.at(i) << ", ";
}
cout << vectD3.at(vectD3.size()-2) << vectD3.back() << endl;
}

稍后在我的代码中,如果 Size == 0,我将其设置为抛出 runtime_error,它确实抛出错误,表示数组为空。复制构造函数是否正确复制? Main 不能更改,它是教授给的。

更新:我更改了复制构造函数以复制数组的所有元素,但运行时错误仍然返回说数组为空。

template<class T>
class DynArray {
public:

DynArray<T>(){
ptr = new T[Capacity];
this->Capacity = 2;
this->Size = 0;
}

DynArray<T>(T n) {
ptr = new T[Capacity];
this->Capacity = n;
this->Size = 0;
}

DynArray<T>(const DynArray& orig) {
cout << "Copy" << endl;
ptr = new T[Size];
for (int i = 0; i < Size; i++) {
ptr[i] = orig.ptr[i];
}
}

DynArray<T>& operator=(const DynArray<T>& orig) {
if(this != &orig) {
delete[] ptr;
ptr = new T[Size];
for (int i = 0; i < Size; i++) {
ptr[i] = orig.ptr[i];
}
}
return *this;
}

void push_back(const T& n) {
if (Size >= Capacity) {
adjust(Capacity * 2);
}
ptr[Size] = n;
Size++;
}

void adjust(T a) {
cout << "grow" << endl;
T* arr = new T[a];
for (int i = 0; i < Capacity; ++i) {
arr[i] = ptr[i];
}
Capacity = a;
ptr = arr;
}

T& back() {
if(Size == 0) {
throw runtime_error("Array is empty");
}
return ptr[Size - 1];
}

T& front() {
if(Size == 0) {
throw runtime_error("Array is empty");
}
return ptr[0];
}

private:
T* ptr = nullptr;
int Capacity;
int Size;

最佳答案

你的课上有不少错误。

在初始化Capacity 之前,默认构造函数使用Capacity 分配数组。

您的保留构造函数声明错误。它的输入参数应该是 int 而不是 T。并且它会遇到与默认构造函数相同的 Capacity 错误。

您的复制构造函数也遇到了同样的初始化错误,只是 Size 代替了。而且它根本不执行深拷贝。它只是将 ptr 指针从一个类实例复制到另一个类实例,而不考虑所指向的内容。与您的复制赋值运算符相同。

您的 adjust() 方法也被声明为错误,它正在泄漏内存。

话虽如此,请尝试更像这样的方法:

#include <algorithm>
#include <utility>

template<class T>
class DynArray
{
public:

DynArray(int n = 2)
: ptr(new T[n]), Capacity(n), Size(0)
{
}

DynArray(const DynArray& orig)
: DynArray(orig.Size)
{
std::cout << "Copy" << std::endl;
std::copy(orig.ptr, orig.ptr + orig.Size, ptr);
Size = orig.Size;
}

DynArray(DynArray&& orig)
: ptr(nullptr), Size(0), Capacity(0)
{
orig.swap(*this);
}

~DynArray()
{
delete[] ptr;
}

DynArray& operator=(const DynArray& orig)
{
if (this != &orig) {
DynArray(orig).swap(*this);
}
return *this;
}

DynArray& operator=(DynArray&& orig)
{
DynArray(std::move(orig)).swap(*this);
return *this;
}

void swap(DynArray &other)
{
std::swap(other.ptr, ptr);
std::swap(other.Capacity, Capacity);
std::swap(other.Size, Size);
}

void push_back(const T& n)
{
if (Size >= Capacity) {
grow();
}
ptr[Size] = n;
++Size;
}

void pop_back()
{
if (Size <= 0) {
throw std::runtime_error("Array is empty");
}
ptr[Size - 1] = T();
--Size;
}

T& front()
{
if (Size <= 0) {
throw std::runtime_error("Array is empty");
}
return ptr[0];
}

T& back()
{
if (Size <= 0) {
throw std::runtime_error("Array is empty");
}
return ptr[Size - 1];
}

T& at(int i)
{
if ((i < 0) || (i >= Size)) {
throw std::out_of_range("Index out of range");
}
return ptr[i];
}

T& operator[](int i)
{
return ptr[i];
}

int size() const {
return Size;
}

int capacity() const {
return Capacity;
}

private:
T* ptr = nullptr;
int Capacity = 0;
int Size = 0;

void grow()
{
std::cout << "grow" << std::endl;
DynArray newArr(Capacity * 2);
std::copy(ptr, ptr + Size, newArr.ptr);
newArr.Size = Size;
newArr.swap(*this);
}
};

然后,你应该考虑扔掉所有这些,只使用 std::vector相反,它会为您处理所有这些细节:

#include <vector>

template<class T>
class DynArray
{
public:

DynArray(int n = 2)
{
vec.reserve(n);
}

void push_back(const T& n)
{
vec.push_back(n);
}

void pop_back()
{
vec.pop_back();
}

T& front()
{
return vec.front();
}

T& back()
{
return vec.back();
}

T& at(int i)
{
return vec.at(i);
}

T& operator[](int i)
{
return vec[i];
}

int size() const {
return vec.size();
}

int capacity() const {
return vec.capacity();
}

private:
std::vector<T> vec;
};

关于c++ - 复制构造函数不是深度复制,错误返回数组为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55874108/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com