小何讲进程: 终止进程函数 exit()和_exit()
2016-05-03 19:31
162 查看
1. exit()和_exit()函数说明
exit()和_exit()函数都是用来终止进程的。当程序执行到exit()或_exit()时,进程会无条件地停止剩下的所有操作,清除包括PCB在内的各种数据结构,并终止本进程的运行。
exit()和_exit()函数的区别:这两个函数的调用过程和差别如下图所示。
从上图中可以看出,
_exit()函数的作用是:直接使进程停止运行,清除其使用的内存空间,并清除其在内核中的各种数据结构;
exit()函数则在这些基础上做了一些包装,在执行退出之前加了若干道工序。
exit()函数与_exit()函数最大的区别就在于exit()函数在调用exit系统调用之前要检查文件的打开情况,把文件缓冲区中的内容写回文件,就是上图中的“清理I/O缓冲”一项。
由于在Linux的标准函数库中,有一种被称作“缓冲I/O(buffered I/O)”操作,其特征就是对应每一个打开的文件,在内存中都有一片缓冲区。
每次读文件时,会连续读出若干条记录,这样在下次读文件时就可以直接从内存的缓冲区中读取;
每次写文件的时候,也仅仅是写入内存中的缓冲区,等满足了一定的条件(如达到一定数量或遇到特定字符等),再将缓冲区中的内容一次性写入文件。
这种技术大大增加了文件读写的速度,但也为编程带来了一些麻烦。
比如有些数据,以为已经被写入文件中了,实际上因为没有满足特定的条件,它们还只是被保存在缓冲区内,这时用_exit()函数直接将进程关闭,缓冲区中的数据就会丢失。
因此,若想保证数据的完整性,就一定要使用exit()函数。
2. exit()和_exit()使用实例
exit()函数使用实例:
_exit()函数使用实例:
运行截图如下:
3. 关于僵尸进程
一个已经终止、但是其父进程尚未对其进行善后处理(获取终止子进程的有关信息、释放它仍占用的资源)的进程被称为僵死进程,也就是处于TASK_ZOMIBE状态的进程。
TASK_ZOMIBE状态是进程结束前过渡状态(僵死状态),在一个进程调用了exit()之后,该进程并不会立刻完全消失,而是留下一个称为僵尸进程(Zombie)的数据结构 。
僵尸进程是一种非常特殊的进程,它已经释放了几乎所有的内存空间,没有任何可执行代码,也不能被调度,仅仅在进程列表中保留一个位置,记载该进程的退出状态等信息供其他进程收集,除此之外,僵尸进程不再占有任何内存空间。
exit()和_exit()函数都是用来终止进程的。当程序执行到exit()或_exit()时,进程会无条件地停止剩下的所有操作,清除包括PCB在内的各种数据结构,并终止本进程的运行。
exit()和_exit()函数的区别:这两个函数的调用过程和差别如下图所示。
从上图中可以看出,
_exit()函数的作用是:直接使进程停止运行,清除其使用的内存空间,并清除其在内核中的各种数据结构;
exit()函数则在这些基础上做了一些包装,在执行退出之前加了若干道工序。
exit()函数与_exit()函数最大的区别就在于exit()函数在调用exit系统调用之前要检查文件的打开情况,把文件缓冲区中的内容写回文件,就是上图中的“清理I/O缓冲”一项。
由于在Linux的标准函数库中,有一种被称作“缓冲I/O(buffered I/O)”操作,其特征就是对应每一个打开的文件,在内存中都有一片缓冲区。
每次读文件时,会连续读出若干条记录,这样在下次读文件时就可以直接从内存的缓冲区中读取;
每次写文件的时候,也仅仅是写入内存中的缓冲区,等满足了一定的条件(如达到一定数量或遇到特定字符等),再将缓冲区中的内容一次性写入文件。
这种技术大大增加了文件读写的速度,但也为编程带来了一些麻烦。
比如有些数据,以为已经被写入文件中了,实际上因为没有满足特定的条件,它们还只是被保存在缓冲区内,这时用_exit()函数直接将进程关闭,缓冲区中的数据就会丢失。
因此,若想保证数据的完整性,就一定要使用exit()函数。
2. exit()和_exit()使用实例
exit()函数使用实例:
/* exit.c */ #include<stdio.h> #include<stdlib.h> int main() { printf("Using exit...\n"); printf("This is the content in buffer "); exit(0); return 0; }运行截图如下:
_exit()函数使用实例:
/* _exit.c */ #include<stdio.h> #include<stdlib.h> #include<unistd.h> int main() { printf("Using exit...\n"); printf("This is the content in buffer "); _exit(0); return 0; }
运行截图如下:
3. 关于僵尸进程
一个已经终止、但是其父进程尚未对其进行善后处理(获取终止子进程的有关信息、释放它仍占用的资源)的进程被称为僵死进程,也就是处于TASK_ZOMIBE状态的进程。
TASK_ZOMIBE状态是进程结束前过渡状态(僵死状态),在一个进程调用了exit()之后,该进程并不会立刻完全消失,而是留下一个称为僵尸进程(Zombie)的数据结构 。
僵尸进程是一种非常特殊的进程,它已经释放了几乎所有的内存空间,没有任何可执行代码,也不能被调度,仅仅在进程列表中保留一个位置,记载该进程的退出状态等信息供其他进程收集,除此之外,僵尸进程不再占有任何内存空间。
相关文章推荐
- require.js的用法
- Idea erlang文件模板注释
- 在(MRv1)中JobTracker工作方式
- 手动安装m4, autoconf, automake, libtool
- JavaWeb学习笔记——servlet
- POJ 1422 Air Raid
- Asynctask的解析
- Android monkey auto test
- 根据两行或多列值,实时计算另一列得
- iOS button学习
- FFT
- 将图片进行压缩
- Linux使用备忘录
- UVA 11584 Partitioning by Palindromes 区间dp
- 欢迎使用CSDN-markdown编辑器
- nginx历程??
- Codeforces 246A-Buggy Sorting【模拟】
- 足底筋膜炎
- POJ 3249-Test for Job(拓扑排序&&DP)
- TextView属性大全【转】