下面我寫(xiě)了一個(gè)hello world程序,一起看看吧:
// filename: main.c #include <stdio.h> int main(void) {   printf("hello wolrd!/n");   return(-);   }編譯執(zhí)行:gcc main.c && ./a.out
現(xiàn)在我們看看在當(dāng)前shell中返回上一個(gè)執(zhí)行過(guò)程的返回值是多少,是 “-1” 嗎?
inuyasha@inuyasha-Aspire-4741:~/桌面$ gcc main.c && ./a.out
hello world!
inuyasha@inuyasha-Aspire-4741:~/桌面$ echo $?
255
啊,結(jié)果為什么 "255"呢?調(diào)用一個(gè)程序, 程序退出-1, 得到結(jié)果不是“-1”嗎?
以下引用自:http://www.laruence.com/2012/02/01/2503.html
這個(gè)問(wèn)題簡(jiǎn)單的說(shuō), 是因?yàn)閑xit或者main函數(shù)中的return, 只能使用0~255之間的值. -1 的unsigned值就是255.
那么復(fù)雜點(diǎn)的說(shuō)呢?
我們知道, 在Shell中, 運(yùn)行一個(gè)命令, 一個(gè)程序, 都是fork一個(gè)子進(jìn)程(然后exec)來(lái)執(zhí)行的, 而這個(gè)程序的退出碼, 被Shell(父進(jìn)程), 通過(guò)wait來(lái)收集而后報(bào)告給我們的.
pid_twait(int *statloc);
而對(duì)于wait來(lái)說(shuō), 歷史上原因, 他將通過(guò)statloc返回一個(gè)16bit的interge(現(xiàn)在也有用32位表示的, 但是會(huì)兼容已有的設(shè)計(jì)). 這16bits的interge中, 高8位就是程序退出的值(exit, 或者return), 而低八位表示導(dǎo)致這個(gè)程序退出的信號(hào)(其中一位表示是否有Core文件產(chǎn)生), 如果程序是正常退出, 那么低八位為0[1].
所以, 如果我們返回-1, 并且因?yàn)槲覀兪钦M顺? 所以Shell通過(guò)wait收集到的子進(jìn)程退出狀態(tài)是:
11111111 00000000
而高八位作為unsigned, 就是255了.
另外, 補(bǔ)充一下, 在Linux的內(nèi)建Shell命令中, 很多都會(huì)遵守一個(gè)退出狀態(tài)碼的約定, 具體的值對(duì)應(yīng)的意思[2]: