c语言中return,eixt()和_exit()函数

2024-06-08 13:48
文章标签 语言 函数 return exit eixt

本文主要是介绍c语言中return,eixt()和_exit()函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

自己写的程序中倒是经常使用到return,读程序的时候偶尔也会“邂逅”exit(),隐隐约约的记得自己在学习Linux应用程序设计的时候好像见过exit()和_exit(),只知道这几个东西都是用来结束一些东西的,但是对他们之间的区别却是一无所知,今天在看代码的时候忽然心血来潮准备把他们之间的区别总结一下,从此以后让他们清晰的存在于我深深的脑海里

这些东西主要参考下面几篇文档,然后根据我自己的理解写出来,特此申明:

百度百科:exit()

http://www.cnblogs.com/likebeta/archive/2013/02/20/2919219.html

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

http://blog.sina.com.cn/s/blog_8c5b746601013r55.html

 

首先来看一下exit和return之间的区别,他们之间的肯定还是有去呗的嘛。为什么呢?很明显,因为两个名字都不一样嘛

 

先总结一下两者的区别:

1、首先return是一个关键字,exit()包括后面的_exit()都是一个函数

2、retrun 是语言级别的,C语言。表示了调用堆栈的返回,这个在调用子函数的时候很明显。而exit()是系统调用级别的,操作系统。表示一个进程的结束

3、Return表示的是函数的退出,exit是进程的退出

4、return用来结束一个函数,将函数结束返回的信息给其他的函数使用,exit函数的用来结束一个进程,删除进程使用的内存空间。将进程的状态返回给操作系统,这些状态信息标识了应用应用程序的一些状态,一般0标识正常退出,非0表示的是正常退出

5、如果在非猪函数中两者区别很明显,在main()主函数中两者区别很模糊。因为main()函数的返回值也是给操作系统的吧

 

再来看一下exit()和_exit()之间的区别:

 

我觉得在有个博客中说得很好:进程就和人一样都是有生命的东西。

既然和人一样,那么进程也有正常的挂了和异常的挂,在操作系统中就叫进程正常退出和异常退出。

 

正常退出:mian()函数中使用return、调用exit()函数和_exit()函数

异常退出:使用about()函数、收到某个信号

 

在有一篇博客中高手下面有这样一段话:不管是哪种方式的退出,系统最后都会执行内核中的额同一段代码,关闭进程打开的文件描述符,释放它占用的内存和其他的资源。想想也是呀,人也是呀,不管哪种方式挂了,正常不正常,最后都是一场空呀,都是哇,看来Linux还真是一门哲学呀

 

 

下面再看一下exit()和_exit()函数的区别

总的来说_exit()执行后会立即返回给内核,而exit()会先执行一些清除操作然后将控制权交给内核,这个在Linux编程中遇到过了,就是说在调用_exit函数的时候它会关闭所有的文件描述符,清理内存和其他的一些内核清理函数,但是不会刷新(stdin,stdout,stderr...),而exit就是在调用_exit()函数的前面先刷新流。

 

高手又说了:

exit()函数与_exit()函数最大的区别是exit()函数在调用_exit()之前先会检查文件的打开情况,把文件缓冲区的内容写回去文件。在Linux的标准函数库中,有一种被称作“缓冲区I/O”的操作,其特征就是对应每一个打开的文件,在内存中都有一片缓冲区。每次读文件的时候,就会连续的独处若干条记录,这样在下次读文件的时候就可以直接从内存的缓冲区中读取,同样,每次写文件的时候也仅仅是写入内存的缓冲区,等满足了一定的条件(比如达到一定的数量或者特定的字符的时候),再将缓冲区的中的内容一次性写入文件,这样做的好处就是大大增加了文件的读写速度,但是对编程来说会带来一定的麻烦。有些数据,我们认为已经写入了文件,实际上并没有瞒住特定的条件,这时候如果调用_exit()函数的话将会直接丢失数据。

这篇关于c语言中return,eixt()和_exit()函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1042360

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

MySQL中REPLACE函数与语句举例详解

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函... 目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

python中update()函数的用法和一些例子

《python中update()函数的用法和一些例子》update()方法是字典对象的方法,用于将一个字典中的键值对更新到另一个字典中,:本文主要介绍python中update()函数的用法和一些... 目录前言用法注意事项示例示例 1: 使用另一个字典来更新示例 2: 使用可迭代对象来更新示例 3: 使用

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据