文件IO
文件IO遵循POSIX标准,文件IO实际上使用的是系统调用函数
POSIX:
可移植操作系统接口 Portable Operating System Interface of UNIX
/* 标准IO 适用于 操作普通文件 */
/* 文件IO 适用于 任意类型文件 */
// 标准IO中通过 标 准 流 唯一标识一个文件
// 文件IO中通过 文件描述符 唯一标识一个文件
1. 文件描述符
文件描述符是一个按顺序分配的最小的非负整数,当用户打开或者新建一个文件时,系统会向当前进程返回一个最小的可用的文件描述符。
/* 三个特殊的文件描述符 */
标准输入 - 0 - stdin(流)
标准输出 - 1 - stdout(流)
标准错误 - 2 - stderr(流)
2. 文件相关系统调用函数
open() / close() 打开/关闭文件
read() / write() 读写文件
lseek() 文件定位
1) 打开文件 open()
#include <sys/types.h>
#include <sys/stat.h>
#incldue <fcntl.h>
int open(const char *pathname, int flags);
int open(const char *pathname, int flags, mode_t mode);
int creat(const char *pathname, mode_t mode);
参数:
pathname: 打开文件的文件名(包含路径)
flags:<前三个必选一个> | <零个或多个其他选项>
O_RDONLY: 以只读方式打开文件
O_WRONLY: 以只写方式打开文件
O_RDWR: 以读写方式打开文件
-----------------------------------------------------------------
O_CREAT: 当打开文件不存在时创建文件,并用第三个参数为其设置权限
O_EXCL: 一般和O_CREAT联合使用,用于检测文件是否存在
O_APPEND: 以追加的方式打开文件,在文件末尾另起一行进行写入
O_TRUNC: 打开文件后,会将原文件清空
......
-----------------------------------------------------------------
mode:
当需要创建新文件时,需要用该参数给新建文件设置初始权限,一般设为0664
返回值:
成功返回文件描述符, 失败返回 -1;
creat("filename",0664);
相当于
open("filename",O_CREAT | O_WRONLY | O_TRUNC,0664);
2) 关闭文件 close()
#include <unistd.h>
int close(int fd);
参数:
fd: 要关闭的文件的文件描述符
返回值:
成功返回 0, 失败返回 -1;
3) 读写文件 read() / write()
#include <unistd.h>
ssize_t read(int fd, void *buf, size_t count);
返回值:
成功返回读取的字节数, 失败返回 -1, 返回0表示读到文件末尾
参数:
fd: 读取文件的文件描述符
buf: 用户自定义的缓冲区,用于存放读取的内容
count: 请求读取的字节数
#include <unixstd.h>
ssize_t write(int fd, const void *buf, size_t count);
返回值:
成功返回写入的字节数,没有写入返回 0, 失败返回 -1;
练习: 用文件IO 实现文件拷贝
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main(int argc,char *argv[])
{
if(argc != 3){
printf("Usage:%s src_filename dest_filename\n",argv[0]);
return -1;
}
int fp1 = open(argv[1],O_RDONLY);
int fp2 = open(argv[2],O_WRONLY);
if(-1 == fp1 || -1 == fp2){
perror("open");
return -1;
}
char buf[32] = {0};
while(read(fp1, buf, 32) > 0){
write(fp2, buf, 32);
memset(buf, 0,sizeof(buf));
}
return 0;
}
4) 文件定位 lseek()
#include <sys/type.h>
#include <unistd.h>
off_t lseek(int fd, off_t offset, int whence);
参数:
fd: 文件描述符
offset: 偏移量,可正可负
whence: 基准点
SEEK_SET: 定位在文件开头
SEEK_CUR: 定位在当前位置
SEEK_END: 定位在文件末尾
返回值:
成功返回当前定位位置相对于文件开头(初始0)的偏移量,失败返回 -1;