質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
オブジェクト指向

オブジェクト指向プログラミング(Object-oriented programming;OOP)は「オブジェクト」を使用するプログラミングの概念です。オブジェクト指向プログラムは、カプセル化(情報隠蔽)とポリモーフィズム(多態性)で構成されています。

コンストラクタ

オブジェクト指向言語において、オブジェクトを生成時に呼び出され、データの初期化などを行なう関数・メソッドのことである。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

834閲覧

C++ core dumped のエラーの改善方法

fere

総合スコア1

オブジェクト指向

オブジェクト指向プログラミング(Object-oriented programming;OOP)は「オブジェクト」を使用するプログラミングの概念です。オブジェクト指向プログラムは、カプセル化(情報隠蔽)とポリモーフィズム(多態性)で構成されています。

コンストラクタ

オブジェクト指向言語において、オブジェクトを生成時に呼び出され、データの初期化などを行なう関数・メソッドのことである。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2022/05/09 01:08

編集2022/05/09 02:50

イメージ説明1. 前提、実現させたいこと

add 命令でsizeを超えたときにsizeを二倍にした配列を確保しそこにデータをコピーする。
その後元のデータを削除しdataに新しい配列を登録するというものです

2,発生している問題

Aborted(core dumped) というエラーが出てしまう

3, 該当のソースコード

#include<iostream>
using namespace std;
class DoubleArray{
public:
int size;
double *data;
int pos;
DoubleArray(){
size = 8;
pos = 0;
data = new double[size];
}
DoubleArray(int sz){
size = sz;
pos = 0;
data = new double[sz];
}
void add(double d){
if(pos < size){
data[pos] = d;
pos++;
}else{
double *newdata;
newdata = new double[size * 2];
for(int i = 0; i < pos; i++){
newdata[i] = data[i];
}
delete[] data;
data = newdata;
data[pos] = d;
pos++;
}
}
void print(){
cout << data[0];
for(int i = 1; i < pos; i++){
cout << ", " << data[i];
}
cout << endl;
}
DoubleArray(const DoubleArray& orig){
pos = orig.pos;
size = orig.size;
data = new double[size];
for(int i = 0; i < pos; i++){
data[i] = orig.data[i];
}
}
~DoubleArray(){
delete[] data;
}
};
int main(){
DoubleArray d1;
cout << d1.size << "," << d1.pos << endl;
for(int i = 0; i < 20; i++){
d1.add(i);
}
cout << d1.size << "," << d1.pos << endl;
DoubleArray d2 = d1;
d2.add(100.0);
cout << d2.size << "," << d2.pos << endl;
d1.print();
d2.print();
}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

episteme

2022/05/09 01:31

これコンパイル通ります? newdataが未定義なんだけど...
guest

回答1

0

ベストアンサー

  • DoubleArray::add()newdata が未宣言。コンパイルできないはず
  • DoubleArray::add()data に対して delete[] ではなく delete が使われている
  • DoubleArray コピーコンストラクタで、this->size が未初期化で参照されている

追記:

  • DoubleArray::add() でバッファが足りないときに size を更新していないため、pos が16以上になると範囲外アクセスを起こす

投稿2022/05/09 01:43

編集2022/05/09 03:07
int32_t

総合スコア21695

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

episteme

2022/05/09 02:13

+ 要素数0のとき、print() は正しく動かない
fere

2022/05/09 02:23

回答を参考に修正したのですが結局同じエラーが出てしまいます。 sizeを二倍にしたnewdataを作るところの書き方が悪いのかなとも思うのですがどう書けばいいのかよくわからないです...
int32_t

2022/05/09 02:35

> 回答を参考に修正したのですが結局同じエラーが出てしまいます。 修正が間違っているかもしれないので、修正後のコードを質問文に追記してください。 今更ですけども、「コードのどこで core dump するのか」を調べるのが先決ですね。コンパイルするときに -g フラグをつけて、デバッガ上で実行してみてください。
fere

2022/05/09 02:53

本文を編集しているのでそちらを見てくださると幸いです cygwin上で画像のように打ったのですが特に何も出てこないのですが何か間違っているのでしょうか...?
int32_t

2022/05/09 03:05

gdb q2_1.exe で起動して、 run で実行、停止したら bt するとよいでしょう。 残りのバグについては回答に追記します。
fere

2022/05/09 03:15

解決しました。 ご丁寧にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問