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

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

新規登録して質問してみよう
ただいま回答率
85.34%
ポインタ

ポインタはアドレスを用いてメモリに格納された値を"参照する"変数です。

C++

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

Q&A

解決済

1回答

308閲覧

C++ でのポインターをメンバーに持つクラス・構造体のメモリー関連のエラー

Paalon

総合スコア266

ポインタ

ポインタはアドレスを用いてメモリに格納された値を"参照する"変数です。

C++

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

0グッド

0クリップ

投稿2024/10/19 04:46

C++ のポインター周辺の勉強をしています。以下のポインター型のメンバー変数を持つクラス・構造体を使ったプログラムがメモリー関連のエラー

  • './main' terminated by signal SIGSEGV (Address boundary error)
  • './main' terminated by signal SIGBUS (Misaligned address error)

になったりならなかったりするのですが、なぜなのか分かりません。

cpp

1#include <print> 2 3struct Point { 4 double * x; 5 double * y; 6 Point(double x, double y) { 7 *this->x = x; 8 *this->y = y; 9 } 10 ~Point() {} 11 void show() { 12 std::println("Point {{ x: {}, y: {} }}", *x, *y); 13 } 14}; 15 16int main() { 17 Point a = Point(1, 2); 18 a.show(); 19}

なにがまずいのでしょうか?

また、コンパイル時、以下の警告が出ます。

g++-14 -std=c++23 -Wall main.cpp -o main main.cpp: In constructor 'Point::Point(double, double)': main.cpp:7:16: warning: '*this.Point::x' is used uninitialized [-Wuninitialized] 7 | *this->x = x;

今の方法は良い初期化ではなさそうなのですが、普通はどうするのでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

ポインタはメモリ上のどこかにあるオブジェクトを指し示すものです。 初期化していないポインタがどこを指しているかは未規定ですし、どこだかわからないところを指しているポインタ経由でメモリに書き込んだ場合の結果は未定義です。

つまり、この場合で言えば this->xthis->y は初期化されていないためにデタラメな場所を指しているので、指している先が偶然にも致命的なクラッシュを引き起こすかもしれませんし、そうでもないかもしれないのです。

単にふたつの値を保持する役割を持つクラスということを意図しているのであればそもそもポインタを使う必要はありませんが、ポインタの練習ということであればおそらく意図しているのはいかのようなものなのではないかと思います。 (エラー処理などは省略しております。) イマドキならスマートポインタを使うとより良いでしょう。

cpp

1#include <print> 2 3struct Point { 4 double* x; 5 double* y; 6 Point(double x, double y) : x(new double(x)), y(new double(y)) {} 7 ~Point() { 8 delete x; 9 delete y; 10 } 11 void show() { 12 std::println("Point {{ x: {}, y: {} }}", *x, *y); 13 } 14}; 15 16int main() { 17 Point a = Point(1, 2); 18 a.show(); 19}

投稿2024/10/19 05:20

SaitoAtsushi

総合スコア5694

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

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

Paalon

2024/10/19 05:35

double * 型と double * 型のメモリーは確保されていても double 型と double 型のメモリーが確保されておらず、 this->x と this->y が適当なところを指しているので初期化しなければならないという訳ですね。よく分かりました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.34%

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

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

質問する

関連した質問