系统调用-open、close、write、read


open 函数


返回的是文件描述符,-1就是发生了错误
第二个函数多了一个mode,是文件的权限,就是chmod 777中的777,打开一个文件,这个文件没有,就可以设置权限打开,文件存在就用两个形参的open函数。
上面列出了使用open函数需要include的库,使用unistd.h可以代替这三个,O_RDONLY宏定义在fcntl.h里面
打开一个文件,如下图所示:

创建一个文件,如下图所示:

注意创建的文件的时候,最终的权限是与上umask,即mode&umask,umask为002
APPEMD是追加属性,不会将原来的内容清空
O_EXCL判断文件是否存在
O_TRUNC 将文件截断为0

如果这个文件存在就打开并且截断为0,说明文件是空的

errno:系统的错误函数,系统给得,引入errno.h就使用

printf("fd = %d, errno = %d, %s", fd, errno, strerror(errno));

还可以得到错误的原因

read函数


参数:
fd: 文件描述符
buf:缓冲区
count:缓冲区大小
返回值:
成功:读到的字节数
失败:-1和失败原因errno

write


注意write函数中的buf是const的,为了防止在写的过程中误操作,第三个count是实际要写入的数据大小
返回值:
成功:写到的字节数
失败:-1和失败原因errno

使用write和read实现复制粘贴


出错检查

系统调用与库函数比较——预读入缓输出

strace可以追踪可执行函数里面的函数调用情况
对于一个4.7M的文本,两方都是一个字节一个字节的拷贝
系统调用:

库函数:


正常从Kernel到磁盘的操作是有一个缓冲区的,当缓冲区达到1024个字节之后一起写到磁盘里,这里可以节约时间
从用户空间到内核空间的切换是需要时间的,使用系统调用的话,复制1024个字节相当于从用户空间到内核空间切换1024次
fputc函数其实也是这样的操作,但是这个函数在用户控件自带1024个缓冲区,一次一个字节是往这个缓冲区里面写的,当写满了之后一次性发给kernel
系统调用也可以自定义缓冲区大小
这就是预读入缓输出机制。
所以我们学会了系统调用,还是能使用库函数就用库函数,但是并不是绝对使用库函数就好,驱动开发是和系统调用对应的;库函数由于在用户空间的缓存机制,有时候需要等待缓存满了才能发送。