eof() は悪い習慣ですか?理由を紐解く
eof() 関数は、ファイル入力手順を伴うプログラムでよく使用されてきました。これを懸念すべき慣行として認識していない人もいるかもしれませんが、特定の情報源によって不適切であることが強調されています。この問題の複雑さを掘り下げて、この観点の背後にある理由を解明します。
eof() の定義に従って、これはファイルの範囲を超えて読み取ろうとしたかどうかを判断するのに役立ちます。ただし、他の一般的なシナリオとは対照的に、その機能はこの特定のシナリオに限定されています。
間違った使用法:
たとえば、次のコード フラグメントは間違った使用法の例です。 of eof():
while (!cin.eof()) { cin >> foo; }
このスニペットでは、eof() がループ条件内で使用されています。さらなるインプットが利用可能かどうかを確認するつもりです。ただし、このアプローチは誤りです。
適切な使用法:
この問題を修正するには、コードは次の構造を採用する必要があります:
if (!(cin >> foo)) { if (cin.eof()) { cout << "read failed due to EOF\n"; } else { cout << "read failed due to something other than EOF\n"; } }
この例では、コードはまずデータを foo 変数に読み取ろうとし、次に操作が成功したかどうかを調べます。これにより、EOF と読み取り失敗のその他の潜在的な原因が区別され、より包括的なエラー処理が提供されます。
以上が入力ループで「eof()」を使用するのは悪い習慣ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。