在对文件进行读写操作前,需要先打开该文件。内核为每个进程维护了一个打开文件的列表,该表被称为文件表。该表由一些叫做文件描述符的非负整数进行索引。列表中的每项均包含一个打开文件的信息,其中包括一个指向文件备份inode内存拷贝的指针和元数据(例如文件位置和访问模式等)。用户空间和内核空间都把文件描述符作为每个进程的唯一cookies。打开一个文件返回一个文件描述符,而接下来的操作则把文件描述符作为基本参数。
每个进程按照惯例会至少有三个打开的文件描述符:0,1和2,除非进程显式地关闭它们。文件描述符0是标准输入,文件描述符1是标准输出,而文件描述符2是标准错误。
文件描述符不仅仅用于普通文件的访问,也用于访问设备文件、管道、目录以及快速用户空间锁、FIFOs和套接字。遵循一切皆文件的理念,任何你能读写的东西都可以用文件描述符来访问。
打开文件
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
int open(const char *path,int flag);
int open(const char *path,int flag,mode_t mode);
path:文件名的字符串地址flag:文件打开模式信息
mode:当文件创建时,mode参数提供新建文件的权限
返回值:成功时返回文件描述符,失败时返回-1创建文件
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
int creat(const char *name,mode_t mode);
name:文件名的字符地址
mode:当文件创建时,mode参数提供新建文件的权限
关闭文件
使用文件后必须关闭#include<unistd.h>
int close(int fd);
fd:需要关闭的文件或套接字的文件描述符返回值:成功时返回0,失败时返回-1
文件偏移量lseek
每个打开文件都有一个与其相关联的“当前文件偏移量”。它通常是一个非负整数,用以度量从文件开始处计算的字节数。通常,读写文件都从当前文件偏移量处开始,并使偏移量增加所读写的字节数。
#include<unistd.h>
off_t lseek(int fd,off_t offset,int whence)
fd:文件描述符
对参数offset的解释与参数whence的值有关。
- 若whence是SEEK_SET,则将该文件的偏移量设置为距文件开始处offset个字节。
- 若whence是SEEK_CUR,则将该文件的偏移量设置为其当前值加offset,offset可为正或负。
- 若whence是SEEK_END,则将该文件的偏移量设置为文件长度加offset,offset可正可负。
将数据写入文件
write函数用于向文件输出数据#include<unistd.h>
ssize_t write(int fd,const void *buf,size_t nbytes);
fd:显示数据传输对象的文件描述符buf:保存要传输数据的缓冲地址值
nbytes:要传输数据的字节数
返回值:成功时返回写入的字节数,失败时返回-1
#include
#include
#include
#include
void error_handling(char *message);
int main(void)
{
int fd;
char buf[]="Let's go!\n";
fd=open("data.txt",O_CREAT|O_WRONLY|O_TRUNC);
if(fd==-1)
error_handling("open() error");
printf("file descriptor:%d \n",fd);
if(write(fd,buf,sizeof(buf))==-1)
error_handling("write() error");
close(fd);
return 0;
}
void error_handling(char *message)
{
fputs(message,stderr);
fputc('\n',stderr);
exit(1);
}
读取文件中的数据
read函数与write函数相对应,用来读取输入数据
#include<unistd.h>
ssize_t read(int fd,void *buf,size_t nbytes);
fd:显示数据接收对象的文件描述符buf:要保存接收数据的缓冲地址值
nbytes:要接收数据的最大字节数
#include
#include
#include
#include
#define BUF_SIZE 100
void error_handling(char *message);
int main(void)
{
int fd;
char buf[100];
fd=open("data.txt",O_RDONLY);
if(fd==-1)
error_handling("open() error");
printf("file descriptor:%d \n",fd);
if(read(fd,buf,sizeof())==-1)
error_handling("read() error");
printf("file data:%s",buf);
close(fd);
return 0;
}
void error_handling(char *message)
{
fputs(message,stderr);
fputc('\n',stderr);
exit(1);
}