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

image

open 函数

image
返回的是文件描述符,-1就是发生了错误
第二个函数多了一个mode,是文件的权限,就是chmod 777中的777,打开一个文件,这个文件没有,就可以设置权限打开,文件存在就用两个形参的open函数。
上面列出了使用open函数需要include的库,使用unistd.h可以代替这三个,O_RDONLY宏定义在fcntl.h里面
打开一个文件,如下图所示:
image
创建一个文件,如下图所示:
image
注意创建的文件的时候,最终的权限是与上umask,即mode&umask,umask为002
APPEMD是追加属性,不会将原来的内容清空
O_EXCL判断文件是否存在
O_TRUNC 将文件截断为0
image
如果这个文件存在就打开并且截断为0,说明文件是空的

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

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

还可以得到错误的原因

read函数

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

write

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

使用write和read实现复制粘贴

image

image
出错检查
image
image

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

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

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

posted @   蘑菇王国大聪明  阅读(327)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示