代码编织梦想

Linux下对文件操作有两种方式:

  • 系统调用(system call)
  • 库函数调用(Library functions)
C语言中IO函数工作流程

库函数由两类函数组成:

  • 1)不需要调用系统调用:不需要切换到内核空间即可完成函数全部功能,并且将结果反馈给应用程序,如strcpy、bzero 等字符串操作函数。
  • 2)需要调用系统调用:需要切换到内核空间,这类函数通过封装系统调用去实现相应功能,如 printf、fread等。

系统调用是需要时间的,程序中频繁的使用系统调用会降低程序的运行效率。

当运行内核代码时,CPU工作在内核态,在系统调用发生前需要保存用户态的栈和内存环境,然后转入内核态工作。系统调用结束后,又要切换回用户态。这种环境的切换会消耗掉许多时间 。

库函数访问文件的时候根据需要,设置不同类型的缓冲区,从而减少了直接调用 IO 系统调用的次数,提高了访问效率。

这个过程类似于快递员给某个区域(内核空间)送快递一样,快递员有两种方式送:

  • 1)来一件快递就马上送到目的地,来一件送一件,这样导致来回走比较频繁(系统调用)
  • 2)等快递攒着差不多后(缓冲区),才一次性送到目的地(库函数调用)
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/u013250861/article/details/127002190