这一周以来一直与Linux的文件操作相关系统调用打交道,其与C语言中的文件操作函数有些许相似但又千差万别.尤其是open()函数的参数,相当复杂,因此作以记录便于查阅.
对于用Linux系统调用进行文件的常用操作作以总结
主要是关于open()系统调用的各个参数做记录.
简述:open是UNIX系统(包括LINUX、Mac等)的系统调用函数,区别于C语言库函数fopen。
#include<fcntl.h>
int open(constchar*pathname,intflags);
int open(constchar*pathname,intflags,mode_tmode);
返回值:成功则返回文件描述符,否则返回-1
对于open函数来说,第三个参数仅当创建新文件时(即 使用了O_CREAT 时)才使用,用于指定文件的访问权限位(access permission bits)。pathname 是待打开/创建文件的POSIX路径名(如/home/user/a.cpp);flags 用于指定文件的打开/创建模式,这个参数可由以下常量(定义于fcntl.h)通过逻辑位或逻辑构成。
O_RDONLY只读模式
O_WRONLY只写模式
O_RDWR读写模式
打开/创建文件时,至少得使用上述三个常量中的一个。以下常量是选用的:
O_APPEND每次写操作都写入文件的末尾
O_CREAT如果指定文件不存在,则创建这个文件
O_EXCL如果要创建的文件已存在,则返回-1,并且修改errno的值
O_TRUNC如果文件存在,并且以只写/读写方式打开,则清空文件全部内容(即将其长度截短为0)
O_NOCTTY如果路径名指向终端设备,不要把这个设备用作控制终端。
O_NONBLOCK如果路径名指向FIFO/块文件/字符文件,则把文件的打开和后继I/O
设置为非阻塞模式
(nonblockingmode)
以下三个常量同样是选用的,它们用于同步输入输出
O_DSYNC等待物理I/O结束后再write。在不影响读取新写入的数据的前提下,不等待文件属性更新。
O_RSYNCread等待所有写入同一区域的写操作完成后再进行
O_SYNC等待物理I/O结束后再write,包括更新文件属性的I/O
以下是简单的一个创建/打开并写入和读取文件的例子
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<fcntl.h>
#include<unistd.h>
/*
*以上两个头文件包含了open(),close()等
*函数的声明,以及相关的一些宏
*/
#include<errno.h>
void my_err(const char *err_string , int line){
//错误处理函数
fprintf(stderr,"line: %d",line);
perror(err_string);
exit(0);
}
int my_read(int fd){
//通过文件描述符来读取文件
int len,ret;
char read_buf[64];
if(lseek(fd,0,SEEK_END) == -1){
//先将文件内部指针从任意位置移到结尾
my_err("lseek",__LINE__);
}
if((len=lseek(fd,0,SEEK_CUR)) == -1){
//返回当前位置(结尾)距离文件开头的偏移值,即就是文件大小
my_err("lseek",__LINE__);
}
if(lseek(fd,0,SEEK_SET) == -1){
//将文件内部指针已到文件开头以便于后面读取
my_err("lseek",__LINE__);
}
printf("文件长度: %d\n",len);
if((ret=read(fd,read_buf,sizeof(read_buf))) == -1){
//从文件中读取一条数据
my_err("read",__LINE__);
}
for(int i=0;i<len;i++){
printf("%c",read_buf[i]);
}
printf("\n");
return ret;
}
int main(){
int fd;
char write_buf[32] = "97520";
if((fd=open("test.t",O_RDWR|O_CREAT|O_TRUNC,S_IRWXU)) == -1){
//这里一系列宏即表示文件打开方式
my_err("open",__LINE__);
}else{
printf("文件创建成功!\n");
}
if(write(fd,write_buf,strlen(write_buf)) != strlen(write_buf)){
//向文件中写入一条数据
my_err("open",__LINE__);
}
my_read(fd);
}