在学习
Linux
的过程中,尤其是使用C语言进行编程的过程中,常常会发现Linux
系统中喜欢用int
类型的0或者非0值作为返回值表示该调用函数操作的成功或者失败。而我们在算法编程或者使用C++
编程的过程中,往往喜欢使用bool
值表示一个操作的成功或者失败这样减去了隐式的类型转换,尤其是对于一些类型安全的语言,这样的类型转换是很麻烦。那么C语言为什么要这么做呢?
查阅了一些资料,主要可能有一下几点原因:
1. C语言本身的历史遗留问题
C
语言特别早期的版本并没有内置布尔类型,C99时期引入了_Bool
类型和stdbool.h
头文件,所以在Unix/Linux
这些早起操作系统编写的时候布尔值通常通过整型(int
)表示,其中0表示false
,非0表示true
。因此,使用0作为成功的返回值是与C语言的这一传统兼容的。
2. 可以表示多种错误状态
使用非0值表示失败允许程序区分不同类型的错误。如果一个操作可以因多种原因失败(如文件打开失败可以是因为文件不存在、权限不足或路径错误),返回不同的非0值可以指示发生了哪种错误。
3. 兼容性问题
因为早起Unix
系统是这么做的,所以后来Linux
和一系列Unix-like
系统也选择了这样的做法,有助于保证不同系统之间脚本和程序的兼容性。这就类似于网上的一些讨论,为什么xxx没有被淘汰,明明已经有更好的了,很多时候是因为xxx留下了大量的历史包袱包括兼容性等问题,就导致了许多虽然不如最新的东西先进但却一直在使用。
最后给大家推荐一个LinuxC/C++高级架构系统教程的学习资源与课程,可以帮助你有方向、更细致地学习C/C++后端开发,具体内容请见 https://xxetb.xetslk.com/s/1o04uB link