質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.04%

シェルスクリプトの特殊変数「$?」について

解決済

回答 3

投稿

  • 評価
  • クリップ 1
  • VIEW 10K+

hide09090909

score 59

件名の通りシェルスクリプトの特殊変数「$?」について質問があります。
「$?」は直前実行したコマンドの終了値(0は成功、1は失敗)という認識なのですが、
インターネットでは場合によっては他の値もあると書いてありました。
下記がその、URLです。
http://shellscript.sunone.me/exit_status.html#%E7%B5%82%E4%BA%86%E3%82%B9%E3%83%86%E3%83%BC%E3%82%BF%E3%82%B9%E3%81%A8%E3%81%AF

また、以前シェルスクリプトで下記の様な書き方をしていたのを見た記憶があります。

if [ $? -eq 2 ]

この2はどのような意味を持っているのでしょうか。
どなたか分かる方教えてください。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+4

終了ステータスはコマンド(プログラム)ごとに意味を自由に設定できます。
伝統的に、0が「成功」、0以外が「失敗など」です。
それを前提にshの文法が出来ています(if while until && ||)。

例えば、man grepを見ると、

       通常、パターンにマッチした行が見つかった場合は 0 を、見つからなかった場
合 は 1 を返します。(ただし、 -v オプションを指定した場合は、逆になりま
す。) パターンに文法エラーが存在したり、入力ファイルにアクセスできな い
などのシステムエラーが発生した場合は、2 を返します。

と書いてあります。
つまり、
0:見つかった
1:見つからない
2:検索失敗
ですね。

「今の時刻の秒を終了ステータスとして返す」というコマンドを作るのも自由です。

#!/bin/bash
exit `date +%S`

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+2

Wikipediaの終了ステータス記事を元に回答するよ

 「$?」は直前実行したコマンドの終了値(0は成功、1は失敗)という認識なのですが

  • 成功: 0
  • 失敗: 0以外全て(1 〜 255)

 Unix系

Unix系の終了ステータスの値は0から255まで(8ビット符号なし整数)に限られている
慣習的に正常終了時はゼロ、異常終了時はゼロ以外を返すのが一般的である[5]。


 この2はどのような意味を持っているのでしょうか。

1 - 255の終了ステータスは、プログラムの製作者が勝手に決めていい。
だからこの1や2という数字自体に意味はない。
(1は0の次の数字だから出現頻度が多いかもしれないけどね)

あくまでもそのプログラムの作者が決めたエラーコードってわけ。
例えば作者がファイルが見つからなければ1、
不正なパラメータであれば2って決めればそれが終了ステータスの意味になる。

ただし、みんなが好き勝手に決めちゃうと利用者が混乱するから、一定のガイドラインが定義されているみたいだね。

 Unix系

各種エラーコードの意味について規約を定めようとした例もある。
例えばGNUは上位ビットを深刻なエラーを示すために予約することを推奨している[2]。
BSDではさらに細かく推奨される解釈を文書化している[6][7][8]。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+1

ご提示のURLで示される情報を拝見しましたが、「直前に実行したコマンドの終了値」と言う意味では
一貫していました。「他の値もある」と言うのは、「0は成功、1は失敗」を前提とした場合です。

この2はどのような意味を持っているのでしょうか。

直前に実行したプログラムが終了コード=2を返した場合、と言う状況です。恐らくそのプログラムは0,1,その他の値を終了コードとして返す場合があって、2はその中でまた特別な意味があってそれをスクリプトでの処理対象としたい、と言うことだと思います。

直前に実行したコマンド終了値、と言うのは、C言語のプログラムで言うところのexit 関数への引数です。

#include <stdlib.h>
int main(void) {
    exit(2);
    return 0; // 実質、意味無し
}

上記のようなプログラム hoge を実行した場合、

./hoge
if [ $? eq 2 ]; then
    echo "HOGE!"
else
    echo "Not HOGE."
fi

"HOGE!"と表示されます。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.04%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる