第14章 高级I/O
14.1 引言
非阻塞I/O、记录锁、系统V流机制、I/O多路转接(select和poll)、readv和writev函数以及存储映射I/O
14.2 非阻塞I/O
write read
14.3 记录锁
功能:当一个进程正在读或修改文件的某个部分时,它可以阻止其他进程修改同一个文件区。
cmd:F_GETLK, F_SETLK, F_SETLKW
#include <fcntl.h>
int fcntl( int filedes, int cmd, ... /* struct flock *flockptr */ );
struct flock{
short l_type; // F_RDLCK, F_WRLCK, or F_UNLCK
off_t l_start;
short l_whence; // SEEK_SET, SEEK_CUR, SEEK_END
off_t l_len;
pid_t l_pid;
};
命令:F_GETLK, F_SETLK, F_SETLKW(阻塞版,wait)
14.4 STREAMS
理解系统V的终端接口,I/O多路转接中的poll函数的使用,以及基于STREAMS的管道和命名管道的实现。
downstream和upstream
SVR3: getmsg, putmsg, poll; SVR4: getpmsg, putpmsg
struct strbuf{
int maxlen;
int len;
char *buf;
};
14.5 I/O多路转接
14.5.1 select和pselect函数
14.5.2 poll
#include <poll.h>
int poll( struct pollfd fdarray[], nfds_t nfds, int timeout );
struct pollfd{
int fd;
short events;
short revents;
};
14.6 异步I/O
14.6.1 系统V异步I/O
14.6.2 BSD异步I/O
14.7 readv和writev函数
#include <sys/uio.h>
ssize_t readv( int filedes, const struct iovec *iov, int iovcnt );
ssize_t writev( int filedes, const struct iovec *iov, int iovcnt );
struct iovec{
void *iov_base;
size_t iov_len;
};
14.8 readn和writen函数
14.9 存储映射I/O
#include <sys/mman.h>
void *mmap( void *addr, size_t len, int prot, int flag, int filedes, off_t off );