AIO in C
AIO, 即异步非阻塞I/O,允许了包括I/O与处理计算的重叠。在大量并发任务下,理论上可以提高相应的处理计算性能。在此简单记录一下C语言中的AIO,方便后续有需要时候查询。
AIO, 即异步非阻塞I/O,允许了包括I/O与处理计算的重叠。在大量并发任务下,理论上可以提高相应的处理计算性能。在此简单记录一下C语言中的AIO,方便后续有需要时候查询。
在Unix环境下,有5种基本的I/O模型:
对于一个操作I/O的程序来说,首先,程序会由用户态向内核发出请求,由内核态去对相关的硬件进行交互。在数据已经准备完毕后,再由内核拷贝到相应的进程中。这是一个两段执行的过程。
假设我们目前进行的是Network I/O,我们用Socket去进行数据的读取。首先,我们会等待数据达到我们的网络设备,当数据到达以后,它将会被存储在内核的缓存中。然后,这个数据会从内核的缓存中拷贝到程序的缓存中,以供使用。
经常能在各种地方看到这么一句话:
Everything in Unix is a file
当Unix程序做任何的I/O时,本质上他们也是通过读/写相应的文件的描述符(file descriptor)来进行操作。
在Unix系统中,文件描述符是一个泛化的概念,它是一个代表了某个打开的‘文件’的一个整型值(integer)。此处的‘文件’既可以是一个字面意义上存储在磁盘上的一个数据文件,也可以是一个网络通信,一个FIFO,一个Pipe…等。
本文中,我将研究一下基本的C语言下的Network I/O。
今天做了一个简单的测试,简单地探究了一下GCC下的Memory Layout。
笔者对C语言只是知道简单的使用方法,并不是非常精通。近日在Redis的 server.h 文件中发现了这样的代码:
1 | typedef void redisCommandProc(client *c); |
对于此处的 typedef 语句感到较为迷惑。就以前所知,C语言中的 typedef 就是用于创建一个数据类型的别名的关键字。此处的 typedef 语句应该是一个函数指针类型的别名. 而在结构体redisCommand中的 proc成员应该就是一个指向函数的指针,该函数接受一个client指针作为参数,返回为空。