博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
exit和_exit的区别
阅读量:6295 次
发布时间:2019-06-22

本文共 1130 字,大约阅读时间需要 3 分钟。

参考 http://www.cnblogs.com/hnrainll/archive/2011/08/17/2142001.html

 

在Linux中进程退出分为了正常退出和异常退出两种。

1>正常退出 

 

a. 在main()函数中执行return 。 

 

b.调用exit()函数 

 

c.调用_exit()函数 

 

2>异常退出 

 

a.调用about函数 

 

b.进程收到某个信号,而该信号使程序终止。

 

 

 

3>比较以上几种退出方式的不同点 

 

(1)exit和return 的区别: 

 

a.exit是一个函数,有参数。exit执行完后把控制权交给系统 

 

b.return是函数执行完后的返回。renturn执行完后把控制权交给调用函数。 

 

(2)exit和abort的区别: 

 

a.exit是正常终止进程 

 

b.about是异常终止。 

 

 

2.exit()和_exit()的学习 

 

1>exit和_exit函数都是用来终止进程的。 

 

当程序执行到exit或_exit时,系统无条件的停止剩下所有操作,清除包括PCB在内的各种数据结构,并终止本进程的运行。 

 

2>exit在头文件stdlib.h中声明,而_exit()声明在头文件unistd.h中声明。 exit中的参数exit_code为0代表进程正常终止,若为其他值表示程序执行过程中有错误发生。 

 

 

 

3>exit()和_exit()的区别: 

 

 

a._exit()执行后立即返回给内核,而exit()要先执行一些清除操作,然后将控制权交给内核。 

 

b. 调用_exit函数时,其会关闭进程所有的文件描述符,清理内存以及其他一些内核清理函数,但不会刷新流(stdin, stdout, stderr ...). exit函数是在_exit函数之上的一个封装,其会调用_exit,并在调用之前先刷新流。 

 

 

exit()函数与_exit()函数最大区别就在于exit()函数在调用exit系统之前要检查文件的打开情况,把文件缓冲区的内容写回文件。由于Linux的标准函数库中,有一种被称作“缓冲I/O”的操作,其特征就是对应每一个打开的文件,在内存中都有一片缓冲区。每次读文件时,会连续的读出若干条记录,这样在下次读文件时就可以直接从内存的缓冲区读取;同样,每次写文件的时候也仅仅是写入内存的缓冲区,等满足了一定的条件(如达到了一定数量或遇到特定字符等),再将缓冲区中的内容一次性写入文件。这种技术大大增加了文件读写的速度,但也给编程代来了一点儿麻烦。比如有一些数据,认为已经写入了文件,实际上因为没有满足特定的条件,它们还只是保存在缓冲区内,这时用_exit()函数直接将进程关闭,缓冲区的数据就会丢失。因此,要想保证数据的完整性,就一定要使用exit()函数。 

你可能感兴趣的文章
spring batch中用到的表
查看>>
资源文件夹res/raw和assets的使用
查看>>
UINode扩展
查看>>
LINUX常用命令
查看>>
百度云盘demo
查看>>
概率论与数理统计习题
查看>>
初学structs2,简单配置
查看>>
Laravel5.0学习--01 入门
查看>>
时间戳解读
查看>>
sbin/hadoop-daemon.sh: line 165: /tmp/hadoop-hxsyl-journalnode.pid: Permission denied
查看>>
@RequestMapping 用法详解之地址映射
查看>>
254页PPT!这是一份写给NLP研究者的编程指南
查看>>
《Data Warehouse in Action》
查看>>
String 源码浅析(一)
查看>>
Spring Boot 最佳实践(三)模板引擎FreeMarker集成
查看>>
Fescar 发布 0.2.3 版本,支持 Redis 和 Apollo
查看>>
Google MapReduce到底解决什么问题?
查看>>
CCNP-6 OSPF试验2(BSCI)
查看>>
Excel 2013 全新的图表体验
查看>>
openstack 制作大于2TB根分区自动扩容的CENTOS镜像
查看>>