欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

exit(-1)或者return(-1)shell得到的退出码为什么是255

程序员文章站 2023-02-13 22:29:01
下面我写了一个hello world程序,一起看看吧: // filename: main.c #include int...

下面我写了一个hello world程序,一起看看吧:

// filename: main.c
 #include <stdio.h>
 int main(void)
 {
   printf("hello wolrd!\n");
   return(-);  
 }

编译执行:gcc main.c && ./a.out

现在我们看看在当前shell中返回上一个执行过程的返回值是多少,是 “-1” 吗?

inuyasha@inuyasha-aspire-4741:~/桌面$ gcc main.c && ./a.out

hello world!

inuyasha@inuyasha-aspire-4741:~/桌面$ echo $?

255

啊,结果为什么 "255"呢?调用一个程序, 程序退出-1, 得到结果不是“-1”吗?

以下引用自:

这个问题简单的说, 是因为exit或者main函数中的return, 只能使用0~255之间的值. -1 的unsigned值就是255.

那么复杂点的说呢?

我们知道, 在shell中, 运行一个命令, 一个程序, 都是fork一个子进程(然后exec)来执行的, 而这个程序的退出码, 被shell(父进程), 通过wait来收集而后报告给我们的.

pid_twait(int *statloc);

而对于wait来说, 历史上原因, 他将通过statloc返回一个16bit的interge(现在也有用32位表示的, 但是会兼容已有的设计). 这16bits的interge中, 高8位就是程序退出的值(exit, 或者return), 而低八位表示导致这个程序退出的信号(其中一位表示是否有core文件产生), 如果程序是正常退出, 那么低八位为0[1].

所以, 如果我们返回-1, 并且因为我们是正常退出, 所以shell通过wait收集到的子进程退出状态是:

11111111 00000000

而高八位作为unsigned, 就是255了.

另外, 补充一下, 在linux的内建shell命令中, 很多都会遵守一个退出状态码的约定, 具体的值对应的意思[2]:

exit code number meaning example comments
1 catchall for general errors let “var1 = 1/0″ miscellaneous errors, such as ”divide by zero” and other impermissible operations
2 misuse of shell builtins (according to bash documentation) empty_function() {} seldom seen, usually defaults to exit code 1
126 command invoked cannot execute   permission problem or command is not an executable
127 “command not found” illegal_command possible problem with $path or a typo
128 invalid argument to exit exit 3.14159 exit takes only integer args in the range 0 – 255 (see first footnote)
128+n fatal error signal ”n” kill -9 $ppid of script $? returns 137 (128 + 9)
130 script terminated by control-c   control-c is fatal error signal 2, (130 = 128 + 2, see above)
255* exit status out of range exit -1 exit takes only integer args in the range 0 – 255