系统调用-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 将文件截断为0image
如果这个文件存在就打开并且截断为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
出错检查imageimage

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

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值