次のような類似のコード スニペットをいくつか見てきました。
struct MyExcept : std::exception {
explicit MyExcept(const char* m) noexcept : message{m} {}
const char* what() const noexcept override {
return message;
}
const char* message;
};
void foo() {
std::string error;
error += "Some";
error += " Error";
throw MyExcept{error.c_str()};
}
int main() {
try {
foo();
} catch (const MyExcept& e) {
// Is this okay?
std::cout << e.message << std::endl;
}
}
コメント の次の行では、を使用して関数Is this okay?
に割り当てられた C スタイルの文字列を読み取ります。スタックの巻き戻しで文字列が破壊されるため、これは未定義の動作ですか?foo
std::string
それが実際に未定義の動作である場合、main
関数をこれに置き換えたらどうなるでしょうか?
int main() {
foo();
}
キャッチがないため、コンパイラは強制的にスタックをアンワインドしませんが、結果をwhat()
コンソールに出力してプログラムを中止します。それで、それはまだ未定義の動作ですか?