目录
1. 标准 I/O
概念:c语言标准的一系列用来进行输入和输出的函数
1. 可以跨平台,既可以在Windows使用,也可以在Linux下使用
2. 标准I/O通过缓冲机制减少系统调用,实现更高效率
3. 文件流指针:通过结构体操作
特点:(1)通过FILE *来操作 (2)有缓冲机制
1.1 打开文件
FILE *fopen(const char *pathname,const char *mode);
功能:打开一个文件
参数1:要打开文件的路径
参数2:打开的方式
r | 只读,文件不存在则出错 |
r+ | 可读可写,文件不存在则出错 |
w | 只写,文件不存在,则新建;文件存在,则清空文件内容 |
w+ | 可读可写,文件不存在,则新建;文件存在,则清空文件内容 |
a | 只写,文件不存在,则新建;文件存在,则追加在文件末尾 |
a+ | 可读可写,文件不存在,则新建;文件存在,则追加在文件末尾 |
返回值:成功返回已经打开的文件流指针,失败返回NULL
1.2 读写文件
1.1.1 按字符读写
int fgetc(FILE *stream);
功能:从指定流中读取一个字符
参数:fopen的返回值,已经打开的流指针
返回值:成功返回读到的ASCII码值,失败返回-1
int fputc(int c,FILE *stream);
功能:向指定流中输出一个字符
参数1:要输出的字符
参数2:fopen的返回值,已经打开的流指针
返回值:成功返回写入的ASCII码值,失败返回-1
int feof(FILE *stream);
功能:判断文件是否到达文件末尾
参数:已经打开的文件流
返回值:为0表示没有到达文件末尾,到达文件末尾为非0值
1.1.2 按行读写
char *fgets(char *s,int size,FILE *stream);
功能:按行读取文件
参数1:存放读到内容空间的首地址
参数2:读取多大
参数3:已经打开的文件流指针
返回值:成功返回读到的字符串的首字母,失败返回NULL
int fputs(const char *s,FILE *stream);
功能:向指定流中输出字符串
参数1:要输出的内容空间的首地址
参数2:已经打开的文件流指针
返回值:成功返回非负数,失败返回-1
1.1.3 按块读写
size_t fread(void *ptr,size_t size,size_t nmemb,FILE *stream);
功能:按块读取文件
参数1:存放读到内容空间的首地址
参数2:一个块的大小、
参数3:块的个数
参数4:打开的流指针
返回值:成功返回读到的块数,失败返回-1
size_t fwrite(const void *ptr,size_t size,size_t nmemb,FILE *stream);
功能:向流中写入数据
参数1:内存空间的首地址
参数2:一个块的大小、
参数3:块的个数
参数4:要操作的流
返回值:成功返回写入的块数,失败返回-1
1.3 关闭文件
int fclose(FILE *stream);
功能:关闭流
参数:fopen的返回值,已经打开的文件流指针
返回值:成功返回0,失败返回-1(EOF)
注意:EOF只能判断是否到达文本文件的末尾,不能判断是否到达二进制文件的末尾
1.4 fseek
int fseek(FILE *stream,long offset,int whence);
功能:文件流的位置
参数1:要操作的流
参数2:偏移量
参数3:偏移的位置
SEEK_SET | 文件的开头 |
SEEK_CUR | 文件的当前位置 |
SEEK_END | 文件的末尾 |
2. 文件I/O
特点:
1.主要用于设备文件的操作,普通文件
2.不提供缓冲机制,每次读写都会引起系统调用
3.文件描述符(非负的整数):每打开一个文件,系统会分配一个文件描述符,文件描述符从0开始
4.可移植操作系统提供的一组函数
5.文件I/O通过文件描述符来进行操作
2.1 打开文件
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int open(const char *pathname, int flags);
int open(const char *pathname, int flags, mode_t mode);
参数1:文件路径
参数2:打开方式
以下三种必选其一
O_RDONLY 只读打开
O_WRONLY 只写打开
O_RDWR 可读可写打开
以下与上三种进行或运算
O_APPEND 以添加方式打开文件,如果文件存在则追加在文件的末尾
O_CREAT 如果文件不存在,则新建,但同时必须使用第三个参数
O_EXCL 如果同时指定了O_CREAT,并且文件已存在,则出错返回
O_TRUNC 如果文件已存在,那么打开文件时先删除文件中原有数据
O_NOCTTY 使用本参数时,如果文件为终端,那么终端不可以作为调用open()系统调用的那个进程的控制终端
参数3:被打开文件的权限
返回值:成功返回打开的文件描述符,失败返回-1
2.2 读写文件
2.2.1 读
#include<unistd.h>
ssize_t read(int fd, void *buf, size_t count);
参数1:文件描述符
参数2:读到的内容的首地址保存到buf中
参数3:要读的字节数
返回值:成功返回读到的字节数,失败返回-1,0表示读到文件末尾
2.2.2 写
#include<unistd.h>
ssize_t write(int fd, const void *buf, size_t count);
参数1:open的返回值,已经打开的文件描述符
参数2:要写的东西的首地址保存到buf中
参数3:要写的字节数
返回值:成功返回写入的字节数,失败返回-1
2.3 关闭文件
#include <unistd.h>
int close(int fd);
参数:open函数的返回值,已经打开的文件描述符
返回值:成功返回0,失败返回-1
2.4 其它函数
#include<sys/types.h>
#include<unistd.h>
off_t lseek(int fd, off_t offset, int whence);
参数1:文件描述符
参数2:偏移量
参数3:偏移的位置
SEEK_SET | 文件的开头 |
SEEK_CUR | 文件的当前位置 |
SEEK_END | 文件的末尾 |