~/.profile
私はBashを使うときにデバッグモードを目立つように使うのが好きなので、新しいマシンを取得するたびにコードの最後に追加しますset -x
。
eu
私はそれを追加することを検討しているので、set -eux
「ベストプラクティス」にしてください。
わかったらBRマニュアル正しく
e
結局、ゼロ以外(通常は間違った)出力を返すコードを実行しないという利点があります。u
-よく理解していませんが、その男はこう言いました。
設定されていない変数と特殊パラメータ「@」、「*」以外のパラメータは、パラメータ拡張時にエラーとして扱われます。エラーメッセージが標準エラーに書き込まれ、非対話型シェルが終了します。
私にはこのように聞こえますが、e
設定されていない変数もエラーを引き起こすと見なされ、ゼロ以外の値で終了します。
最高の「一般的な」デバッグを探している人の場合、ここで私が理解した内容は正確でset -eux
平均よりも優れていますか?set -x
答え1
これはコメントの問題ですが、set -eu
インタラクティブに使用するのは悪い考えだと思います。みんながすることは次のとおりです。
対話型シェルでは、これはコマンドにエラーがあるとシェルが終了することを意味します!たとえば、コマンド名に誤字が含まれているか、rm
ファイル名が正しくない、echo $blah
変数名が正しくありません。
set -e
シェルスクリプトを書くときに便利ですset -u
。特にset -e
複合エラーを防ぐことができます。コマンドが失敗するとスクリプトが終了するため、後続のコマンドが予想されるコンテキストで実行されない問題を回避できます。
説明とは異なり、ゼロ以外の-e
状態を返すコードの実行を防ぐことはできません。ゼロ以外の状態を返すには、コマンドを実行する必要があります。