私は分かりませんが、コピーコンストラクタや演算子=が正しくありません。 2つの "墓"でテストしたところ、プリンタは動作していましたが、プログラムの終わりにコンパイラは "デバッグアサーションが失敗しました"と言っていました。コメントを1としてVectorクラスのoperator =を作る方法は?
#pragma once
#include <cstdio>
#include <cmath>
#include <iostream>
#include <cstdlib>
class tomb {
private:
double *adat;
int szam;
public:
tomb(){
adat = NULL;
szam = 0;
}
tomb(const tomb &u) {
adat = u.adat;
szam = u.szam;
};
int meret()const {
return szam;
}
~tomb() {
delete[] adat;
}
double & operator[](int n) {
return adat[n];
}
const double & operator[](int n)const {
return adat[n];
}
const tomb &operator=(const tomb &a) {
adat = a.adat;
szam = a.szam;
return *this;
}
tomb elso_valahany(int n) {
}
void push_back(const double &a) {
double *tmp;
tmp = new double[szam+1];
for (int i = 0; i < szam; i++)
{
tmp[i] = adat[i];
}
tmp[szam] = a;
delete[] adat;
adat = tmp;
++szam;
}
void Kiir()const {
for (int i = 0; i < szam; i++)
{
std::cout << adat[i] << "\n";
}
}
};
どちらも間違っています。 –
なぜ動的割り当てを使用していますか? –
両方のデストラクタが 'delete []'をしようとすると、 'tomb'からポインタをコピーするのは間違いです。これは、同じポインタの明らかな二重削除です。 –