Linux系统中操作文件有两种方式,一种是标准C的文件执行函数,一般以f开头,fopen,fread,fwrite等等,这种操作执行是带缓存的,一般系统会对它进行优化,另外一种是系统调用,open, close, read, write, lseek,也就是我们今天要分享的,这种不带缓存,直接读和写都是真实的数据,一般在驱动中需要用到这种方式,今天先来分享系统调用的几个函数,明天再分享标准C的文件操作函数。
1 open
所需头文件:
函数原型:int open(const char *pathname,flags,int perms)
pathname:被打开的文件名,可包含路径
flag :文件打开的方式,参数可以通过“|” 组合构成,但前3 个参数不能互相重合。
O_REONLY :只读方式打开文件
O_WRONLY :可写方式打开文件
O_RDWR :读写方式打开文件
O_CREAT :如果文件不存在时就创建一个新文件,并用第三个参数为其设置权限。
O_EXCL :如果使用O_CREAT 时文件存在,则可返回错误信息。这一参数可测试文件是否存在。
O_NOCTTY :使用本参数时,如文件为终端,那么终端不可以作为调用open ()系统调用的那个进程的控制终端。
O_TRUNC :如文件已经存在,并且以只读或只写成功打开,那么会先全部删除文件中原因数据。
O+APPEND :以添加方式打开文件,在打开文件的同时,文件指针指向文件末尾。
perms:权限,可以用数字表示
返回值,成功返回文件描述符,失败返回-1
2 close
函数原型:int close (int fd )
函数输入值:fd :文件描述符
函数返回值:成功:0 出错:-1
来看个例子:
先让用户输入一个文件,以可读可写的方式打开,如果不存在就创建,权限是0666
hello就是新创建的文件
我们看下hello的权限
并不是0666,而是0644,这是因为umask,umask我们前面总结过了
是相剪的结果,我们可以在代码中指定umask的值为0000,那么我们创建的这个hello就是正确的权限了
再来试下
我们看到现在hello的权限就是0666了
3 read
所需头文件:
函数原型:ssize_t read(int fd,void *buf,size_t count)
fd: 文件描述符
Buf :指定存储器读出数据的缓冲区
Count :指定读出的字节数
函数返回值:成功:读出的字节数 0 :已到达文件尾 -1 :出错
看例子:
我们先创建一个read.txt,随便写点内容
memset是分配内存空间
4 write
所需头文件
函数原型: ssize_t write(int fd,void *buf,size_t count)
函数传入值:
fd: 文件描述符
Buf :指定存储器写入数据的缓冲区
Count :指定读出的字节数
函数返回值:成功:已写的字节数 -1 :出错
例子:
5 lseek
所需头文件
函数原型:off_t lseek(int fd,off_t offset,int whence)
函数传入值:
fd: 文件描述符
Offset :偏移量,每一读写操作所需要移动的距离,单位是字节的数量,可正可负(向前移,向后移)
Whence :当前位置的基点:
SEEK_SET :当前位置为文件开头,新位置为偏移量的大小
SEEK_CUR :当前位置为文件指针位置,新位置为当前位置加上偏移量
SEEK_END :当前位置为文件的结尾,新位置为文件的大小加上偏移量大小
例子:
下面我们用一个大的例子把上面分享的东西串起来:
读一个文件的全部内容,写入到另外一个文件
先看看file.in的内容
6 perror
一般遇到错误的时候,系统会把错误报错在全局变量errorno中,我们可以用perror打印出具体的报错信息,perror函数中的字符串相当于标题,看个例子
好了,Linux 文件系统调用函数open close read write lseek perror就总结到这里,如有问题,欢迎指正,谢谢。