波奇学Linux:进程终止

本文讨论了子进程调度、进程退出的不同情况,如代码成功/失败的返回值、errno的作用、exit和_exit函数的区别,以及缓存区在exit和_exit中的行为。重点介绍了信号和Segmentationfault机制。
摘要由CSDN通过智能技术生成

写时拷贝底层原理图 

 子进程谁先运行,由调度器决定

进程退出场景

代码运行完毕,结果正确:有返回值,返回0

代码运行完毕,结果不正确:有返回值,返回非0

代码异常终止。没有返回值

return 0的含义

0 表示进程的退出码,表示进程运行结果是否正确,0->success

0会给父进程拿到,父进程可以根据退出码,提醒用户出错原因

可以用不同的返回值数字,表示不同的出错原因

echo $? 打印最近一次执行程序的退出码

?像变量一样保存退出码,$?表示取这个变量?的值  

C语言的全局变量errno:保存最新错误的库函数退出码(当有几个库函数发生错误时)

 当代码运行完毕,结果不正确,可以通过查看errno码查询原因

当进程异常终止,我们不关心退出码

进程出现异常,本质时进程收到对应的信号

进程异常会触发硬件层面的错误,硬件层面错误会给操作系统发出信号。

如野指针错误

查表可知Segmentation fault的信号编号是11 

发生11信号编号给系统,普通进程会得到同样的运行的结果,说明进程的异常终止可能存在类似发生信号编号的机制。

退出进程函数exit(库函数)和_exit(系统函数)

exit的参数status就是进程的退出码,在main函数return的值也是退出码

exit函数在任意地方被调用,都表示进程终止,return只在main函数中表示进程结束,在其他函数中表示函数返回。

_exit

_exit同样能终止进程

由图可见,当调用_exit()函数时,hello linux并没有被打印。已知printf的内容会先被保存在缓存区,所有可得exit()退出进程时,刷新的缓存区而_exit退出进程时没有刷新缓存区。

exit()会看到缓存区的结果(printf的内容如果还在缓存区,没有刷新exit()会把缓存区的内容刷新后再退出),_exit()直接终止进程,exit()相当于最后再调用系统函数_exit()。

由此可知缓存区绝对不在内核区。

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值