文件与IO
cat cp mv 之类的命令都需要读取文件的内容
读文件:
- 打开文件: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文件夹
-
读文件 read
ssize_t read(int fd, void *buf, size_t count);
read的每次读取,会读到最高count字节的数据,读到buf中,如果没有数据,或者读到结尾,返回0
如果count是0,将会返回错误,如果count大于SSIZE_MAX,读出来的结果将是不确定的 -
写文件 write
ssize_t write(int fd, const void *buf, size_t count);//把buf写到fd中
写入的字节数可能小于count
原因 : 文件中没有足够的空间,或者系统资源限制, 或者调用被中断
写文件时,文件的偏移量会增加写的那么多,如果文件选项O_APPEND(附加)文件先移动到末尾,再开始写,否则,会清除原先文件中的内容,再写入。
函数的返回值是写入的数量,可能会小于count 原因同上 -
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