文件与IO

文件与IO
cat cp mv 之类的命令都需要读取文件的内容
读文件:

  1. 打开文件:open
    int open(const char *pathname, int flags);//打开文件用什么样的方式,返回文件描述符
    文件描述符:0:标准输入 1:标准输出 2:标准错误输出
    如果flag 包含 O_CREAT 并且文件不存在,会自动创建一个文件
    文件描述符永远返回最小未被使用的文件编号(用来看打开的文件数)
    默认情况下,会设置一个O_CLOEXEC选项(flag),并且有一个offset(文件偏移量)在文件的开始
    open打开新的文件,会创建一个新的文件描述符,记录文件偏移量,以及文件的状态

flag 必须包含以下权限之一:1. O_RDONLY(只读) 2. O_WRONLY(只写), 3. O_RDWR(可读可写)

O_TRUNC : 截断

O_DIRECT:直接I/O,文件以O_DIRECT形式打开,文件将直接写入磁盘,而不使用缓冲I/O,在printf中打印字符串,在计算机底层用字节处理,在往屏幕中打印,或者往文件中写,都是一个字节一个字节写,直到程序结束,或者遇到回车,在往BLOCK(磁盘)中写入,例如写一个a字符,程序不会直接写入磁盘,内核会持a字符,如果有其他也需要写,会攒一堆字符一起写到磁盘,或者是到一个时间周期才会写,如果此时断电,会掉电,产生数据丢失。

O_NONBLOCK:非阻塞I/O,输入a, b,数据不存在,返回-1, 然后重新返回输入
阻塞I/O :输入a ,b,在输出的过程中,不输入任何东西,程序在等待,如果没有合适的输入,程序会一直阻塞

阻塞:浪费资源
非阻塞:多次重复的过程中也浪费资源,可以用程序调成

O_TMPFILE:临时文件
当进程运行结束时,文件应该被删除,类比tmp文件夹

  1. 读文件 read
    ssize_t read(int fd, void *buf, size_t count);
    read的每次读取,会读到最高count字节的数据,读到buf中,如果没有数据,或者读到结尾,返回0
    如果count是0,将会返回错误,如果count大于SSIZE_MAX,读出来的结果将是不确定的

  2. 写文件 write
    ssize_t write(int fd, const void *buf, size_t count);//把buf写到fd中
    写入的字节数可能小于count
    原因 : 文件中没有足够的空间,或者系统资源限制, 或者调用被中断
    写文件时,文件的偏移量会增加写的那么多,如果文件选项O_APPEND(附加)文件先移动到末尾,再开始写,否则,会清除原先文件中的内容,再写入。
    函数的返回值是写入的数量,可能会小于count 原因同上

  3. close
    int close(int fd);
    如果不加,在程序结束的时候内核会自动关闭文件

代码演示:

头文件

#ifndef _HEAD_H
#define _HEAD_H
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#endif

#include 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值