私はこのことが正しい理由に困惑しています。戻り値は参照型int&
, ですが、h()
関数は文return x
に値int
を返します。したがって、int
の返品はどのようにint &
に変更されますか?コードスニペットの戻り値の型を理解できません
これはコードスニペットであり、C++コンパイラで正常にコンパイルされます。
int& h() {
int q;
static int x;
return x;
}
私はこのことが正しい理由に困惑しています。戻り値は参照型int&
, ですが、h()
関数は文return x
に値int
を返します。したがって、int
の返品はどのようにint &
に変更されますか?コードスニペットの戻り値の型を理解できません
これはコードスニペットであり、C++コンパイラで正常にコンパイルされます。
int& h() {
int q;
static int x;
return x;
}
これは、スタティックint
への参照を返します。 x
は、初めて関数h
が呼び出されたときに初期化されます。このようにそれを使用します。
int& href = h();
++href; // increments the static variable
int& href2 = h(); // another reference to the same static variable
変数q
は効果がありません必要があり、私はそれは疑わしい検討します。
参照は、あなたが実際にコードをwritttenされていた場合はそう返されたものの値を変更すると、直接x
の値を変更します効果的に同じ変数を返していることを意味します
int h()
{
int q;
static int x;
return x;
}
(すなわちではありません)の値のコピーを返すことになります(ただし、公正なチェックアウトはReturn Value Optimizationである必要があります)。しかし、リファレンスを返すことは効率的ですが、時間がかかります(マルチスレッドは明白な例です)。それは望ましくなく混乱することがあります。
int&
はintへの参照です。 x
はintです。したがって、int&
を返す関数からのreturn x;
は、x
への参照を返します。また
:関数が終了したときに、ローカル変数が破壊されているのでローカル変数への参照を返す
は、危険です。参照を取得するまでに、参照するものは存在しません。これはダングリングリファレンスと呼ばれ、何も指していないポインタのようなものです。
静的変数はローカル変数ではなく、関数が終了すると破棄されません。したがって、参照が有効なオブジェクトを取得した時点でそのオブジェクトを指し示しています。
少しわかります – user1279988