目录
进程终止
进程终止是什么
进程终止的情况
代码跑完,结果正确/不正确
提前知道结果
不知道结果
strerror
示例 -- echo $?
代码未跑完,程序崩溃
示例
进程退出方法
return+退出码
exit(status)
_exit(status)
exit()和_exit()的不同
示例
缓冲区位置
进程终止
进程终止是什么
指一个正在运行的进程,结束其执行并退出系统的过程
进程是程序运行起来后,os给他分配空间,载入它的数据结构,代码和数据
那么在终止的时候,就一定会释放掉它占有的内存资源,不然就是内存泄漏了
进程终止的情况
代码跑完,结果正确/不正确
提前知道结果
- 如果自己预先知道要达到的结果,可以通过判断返回特定的值,来知道结果正确/不正确
- eg:main函数的返回值(系统的概念),是一个进程的退出码
- 它可以报告给父进程自己的退出情况,父进程可以获得返回值来评判它的执行结果,但也可以忽略
- 0代表结果正确(我们之前写的程序一般都是返回0,因为之前不需要返回错误信息,只是单进程,并不涉及这些问题)
- 非0代表不正确(不同的返回值 标识了 错误的原因,方便定位不同的错误细节)
不知道结果
- 但如果我们并不清楚每个退出码代表的意思 ,就可以采取打印成字符串的形式
strerror
- 可以将退出码转换为对应代表的错误信息:
可以发现,linux下,提供的错误码有133个
除此之外,我们也可以自己定义错误码
示例 -- echo $?
每条指令都是一个进程,因此执行完毕后就会有对应的错误码
通过echo $?可以查看上一个进程的错误码
这样,我们在以后设计程序的时候,就可以根据不同的错误,让他返回对应的错误码,方便我们在出现错误之后查看
代码未跑完,程序崩溃
- 一旦程序崩溃,实际上它的退出码已经毫无意义了,退出码是用来看结果的
- 当你遇到异常退出的时候,你会在意它的结果正不正确吗?
- 不会的,你只会去想为什么会造成程序崩溃,而程序执行完后的"崩溃提醒"是比较有用的
- 因此,它返回的退出码是一个无效值
示例
当code发生异常后,拿到的错误码是139:
139没有对应的错误信息(也就是无效的错误码)
进程退出方法
return+退出码
- 只有main函数的return是退出码,其他函数的叫做函数返回
exit(status)
- c库函数,头文件:<stdlib.h>
- 在任何地方调用,都代表直接终止进程
- 它会清理进程的资源,包括关闭打开的文件描述符、释放分配的内存等,再将退出状态码status返回给操作系统
_exit(status)
- 系统调用接口,用于终止进程
- 它直接将控制权返回给操作系统,而不执行任何C库的清理操作
- exit()中就封装了这个接口,来实现终止进程的操作
exit()和_exit()的不同
示例
这样一份代码,printf由于是行刷新的,需要\n来将字符串内容从缓冲区刷新到显示器上,但是这里并没有加\n,所以数据还在缓冲区中:
- 如果用exit():
- 我们并没有显示的刷新缓冲区,却能看到内容,说明exit()中封装了刷新缓冲区的操作
- 若换成_exit():
- 会发现什么都没有输出,说明_exit中没有刷新缓冲
缓冲区位置
这里说的缓冲区,其实我们并不了解它到底在哪里
- 但是可以肯定它不在os内部!!!
- 因为,系统调用已经是os中最上层的部分了,如果是os维护的,那么一定可以通过调用_exit来刷新缓冲区
- 所以,其实我们平时所说的缓冲区是由c标准库维护的,所说的刷新缓冲区其实就是将c语言中残留的数据刷新到os中