系统调用-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
系统调用也可以自定义缓冲区大小
这就是预读入缓输出机制。
所以我们学会了系统调用,还是能使用库函数就用库函数,但是并不是绝对使用库函数就好,驱动开发是和系统调用对应的;库函数由于在用户空间的缓存机制,有时候需要等待缓存满了才能发送。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理