std::fstreamを閉じる必要がありますか?重複
質問
重複の可能性があります。
ifstreamを手動で閉じる必要がありますか?
を呼び出す必要がありますか?
fstream.close()
を呼び出す必要があるのでしょうか?
fstream
は、破壊時にストリームを閉じる適切な RAII オブジェクトですか?
私はローカルな
std::ofstream
オブジェクトがあります。このメソッドを終了した後、closeを呼び出さずに常にファイルを閉じていると考えてよいでしょうか?私はデストラクタのドキュメントを見つけることができませんでした。
どのように解決するのですか?
前の回答は誤解を招くと思います。
fstream
は
が適切なRAIIオブジェクトである場合、それは
は
はスコープの終わりで自動的に閉じられ、そこには絶対に
は一切必要ありません。
を呼び出す必要は全くありません。
close
を手動で呼び出す必要はありません。
特に、「ベストプラクティス」ではないので、出力をフラッシュする必要はありません。
また、Drakosha の言うとおり
close
を呼び出すことで、ストリームのフェイルビットをチェックできる可能性があるのはDrakoshaの言うとおりですが、とにかくそんなことをする人はいません。
理想的な世界では、単に
stream.exceptions(ios::failbit)
を呼び出し、投げられた例外を
fstream
のデストラクタで投げられる例外を処理します。しかし残念ながら、デストラクタでの例外はC++では壊れた概念なので、それは良いアイデアではありません。
そこで であれば の場合、ファイルのクローズが成功したかどうかをチェックしたい場合は、手動で行ってください(ただし、その場合のみ)。
関連
-
[解決済み】C++エラー。アーキテクチャ x86_64 に対して未定義のシンボル
-
[解決済み】識別子 "string "は未定義?
-
[解決済み】C++コンパイルタイムエラー:数値定数の前に期待される識別子
-
[解決済み】Visual Studio 2013および2015でC++コンパイラーエラーC2280「削除された関数を参照しようとした」が発生する
-
[解決済み] 非静的データメンバの無効な使用
-
[解決済み】エラー:不完全な型へのメンバーアクセス:前方宣言の
-
[解決済み] std::string を const char* または char* に変換する方法
-
[解決済み] using namespace std;」はなぜバッドプラクティスだと言われるのですか?
-
[解決済み] C++で仮想関数が必要な理由とは?
-
[解決済み] std::vector にある項目が存在するかどうかを調べるには?
最新
-
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++でユーザー入力を待つ【重複あり
-
[解決済み】C++エラーです。"配列は中括弧で囲まれたイニシャライザーで初期化する必要がある"
-
[解決済み] クラスにデフォルトコンストラクタが存在しない。
-
[解決済み】C++プログラムでのコンソールの一時停止
-
[解決済み】「Expected '(' for function-style cast or type construction」エラーの意味とは?
-
[解決済み】C++ - ステートメントがオーバーロードされた関数のアドレスを解決できない。
-
[解決済み】 while(cin) と while(cin >> num) の違いは何ですか?)
-
[解決済み】演算子のオーバーロード C++; <<操作のパラメータが多すぎる
-
[解決済み】ifstreamを手動で閉じる必要がありますか?