[解決済み] C++の関数が特定の変数の値を変更するかどうかを判断できるコンパイラを構築することが不可能なのはなぜですか?
疑問点
ある本でこのような一節を読みました。
C++の関数が値を変更するかどうかを実際に判断できるコンパイラを構築することは、証明不可能である。 C++関数が特定の変数の値を変更するかどうかを決定できるコンパイラを構築することは、証明不可能である。 を変更するかどうかを決定できるコンパイラを構築することは証明不可能です。
このパラグラフでは、なぜコンパイラがconst-nessをチェックするときに保守的になるのかについて話していました。
なぜそのようなコンパイラを作ることは不可能なのでしょうか?
コンパイラは、変数が再代入されているか、その変数に対して非定数関数が呼び出されているか、非定数パラメータとして渡されているか...を常にチェックすることができます。
どのように解決するのですか?
なぜそのようなコンパイラを作ることができないのですか?
任意のプログラムが終了するかどうかを決定するプログラムを書くことができないのと同じ理由です。これは 停止問題 と呼ばれ、計算不可能なものの1つです。
はっきり言って、ある関数が変数を変更すると判断できるコンパイラを書くことはできます。 いくつかの場合において しかし、可能性のあるすべての関数について、関数が変数を変更するかしないか (または停止するか) を確実に伝えるものを書くことはできないのです。
簡単な例を挙げます。
void foo() {
if (bar() == 0) this->a = 1;
}
コンパイラは、このコードを見ただけで、どのようにして
foo
が変更されるかどうか
a
? 変更するかしないかは、この関数の外部条件、すなわち
bar
. ハルティング問題が計算可能でないことの証明にはそれ以上のものがありますが、それはリンク先のWikipediaの記事で(そしてすべての計算理論の教科書で)すでにうまく説明されているので、ここで正しく説明しようとするのはやめておきます。
関連
-
[解決済み】Visual Studio 2015で「非標準の構文。'&'を使用してメンバーへのポインターを作成します」エラー
-
[解決済み] [Solved] Error C1083: Cannot open include file: 'stdafx.h'
-
[解決済み】C++エラーです。"配列は中括弧で囲まれたイニシャライザーで初期化する必要がある"
-
[解決済み】C++ 式はポインタからオブジェクトへの型を持っている必要があります。
-
[解決済み] クラスにデフォルトコンストラクタが存在しない。
-
[解決済み】浮動小数点例外エラーが発生する: 8
-
[解決済み] to_string は std のメンバーではない、と g++ が言っている (mingw)
-
[解決済み】エラー。引数リストに一致するコンストラクタのインスタンスがない
-
[解決済み] Intel CPU の _mm_popcnt_u64 で、32 ビットのループカウンターを 64 ビットに置き換えると、パフォーマンスが著しく低下します。
-
[解決済み] メンバアクセス演算子 ->, .* のオーバーロード
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] テスト
-
[解決済み】C++ 非推奨の文字列定数から「char*」への変換について
-
[解決済み】クラステンプレートの引数リストがない
-
[解決済み】識別子 "string "は未定義?
-
[解決済み] error: 'ostream' does not name a type.
-
[解決済み] error: 'if' の前に unqualified-id を期待した。
-
[解決済み] クラスにデフォルトコンストラクタが存在しない。
-
[解決済み】IntelliSense:オブジェクトに、メンバー関数と互換性のない型修飾子がある
-
[解決済み】 while(cin) と while(cin >> num) の違いは何ですか?)
-
[解決済み] 警告:暗黙の定数変換でのオーバーフロー