linux文件操作{open、write、read、close、creat}

open、write、read、close、creat

  1. open()函数

功能描述:用于打开或创建文件,在打开或创建文件时可以指定文件的属性及用户的权限等各种参数。

所需头文件:#include <sys/types.h>,#include <sys/stat.h>,#include <fcntl.h>

函数原型:int open(const char *pathname,int flags,int perms)

参数:

pathname:被打开的文件名(可包括路径名如"dev/ttyS0")

flags:文件打开方式,

O_RDONLY:以只读方式打开文件

O_WRONLY:以只写方式打开文件

O_RDWR:以读写方式打开文件

O_CREAT:如果改文件不存在,就创建一个新的文件,并用第三个参数为其设置权限
权限 :
可读: r 4
可写: w 2
可执行:x 1
列子: 0600 可读可写 r+w =4+2=6 第三个0是同组的,第四个0是其他组的。

O_EXCL:如果使用O_CREAT时文件存在,则返回错误消息。这一参数可测试文件是否存在。此时open是原子操作,防止多个进程同时创建同一个文件

O_NOCTTY:使用本参数时,若文件为终端,那么该终端不会成为调用open()的那个进程的控制终端
O_TRUNC:若文件已经存在,那么会删除文件中的全部原有数据,并且设置文件大小为0
O_APPEND:以添加方式打开文件,在打开文件的同时,文件指针指向文件的末尾,即将写入的数据添加到文件的末尾。若没加APPEND,写入进去会覆盖原先的内容的长度。,

O_NONBLOCK: 如果pathname指的是一个FIFO、一个块特殊文件或一个字符特殊文件,则此选择项为此文件的本次打开操作和后续的I/O操作设置非阻塞方式。

O_SYNC:使每次write都等到物理I/O操作完成。
O_RSYNC:read 等待所有写入同一区域的写操作完成后再进行
在open()函数中,falgs参数可以通过“|”组合构成,但前3个标准常量(O_RDONLY,O_WRONLY,和O_RDWR)不能互相组合。

perms:被打开文件的存取权限,可以用两种方法表示,可以用一组宏定义:S_I(R/W/X)(USR/GRP/OTH),其中R/W/X表示读写执行权限,

USR/GRP/OTH分别表示文件的所有者/文件所属组/其他用户,如S_IRUUR|S_IWUUR|S_IXUUR,(-rex------),也可用八进制800表示同样的权限

返回值:

成功:返回文件描述符

失败:返回-1

  1. close()函数

功能描述:用于关闭一个被打开的的文件

所需头文件: #include <unistd.h>

函数原型:int close(int fd)

参数:fd文件描述符

函数返回值:0成功,-1出错

  1. read()函数

功能描述: 从文件读取数据。
所需头文件: #include <unistd.h>

函数原型:ssize_t read(int fd, void *buf, size_t count);

参数:
fd: 将要读取数据的文件描述词。
buf:指缓冲区,即读取的数据会被放到这个缓冲区中去。
count: 表示调用一次read操作,应该读多少数量的字符。

返回值:返回所读取的字节数;0(读到EOF);-1(出错)。

以下几种情况会导致读取到的字节数小于 count :

A. 读取普通文件时,读到文件末尾还不够 count 字节。例如:如果文件只有 30 字节,而我们想读取 100

字节,那么实际读到的只有 30 字节,read 函数返回 30 。此时再使用 read 函数作用于这个文件会导致 read 返回 0 。
B. 从终端设备(terminal device)读取时,一般情况下每次只能读取一行。
C. 从网络读取时,网络缓存可能导致读取的字节数小于 count字节。
D. 读取 pipe 或者 FIFO 时,pipe 或 FIFO 里的字节数可能小于 count 。
E. 从面向记录(record-oriented)的设备读取时,某些面向记录的设备(如磁带)每次最多只能返回一个记录。
F. 在读取了部分数据时被信号中断。
读操作始于 cfo 。在成功返回之前,cfo 增加,增量为实际读取到的字节数。

  1. write()函数

功能描述: 向文件写入数据。
所需头文件: #include <unistd.h>

函数原型:ssize_t write(int fd, void *buf, size_t count);

返回值:写入文件的字节数(成功);-1(出错)

功能:write 函数向 filedes 中写入 count 字节数据,数据来源为 buf 。返回值一般总是等于 count,否则就是出错了。常见的出错原因是磁盘空间满了或者超过了文件大小限制。

对于普通文件,写操作始于 cfo 。如果打开文件时使用了 O_APPEND,则每次写操作都将数据写入文件末尾。成功写入后,cfo 增加,增量为实际写入的字节数。

  1. lseek()函数

功能描述: 用于在指定的文件描述符中将将文件指针定位到相应位置。
所需头文件: #include <unistd.h>,#include <sys/types.h>

函数原型:off_t lseek(int fd, off_t offset,int whence);
参数:LSEEK_STE //光标移到头
LSEEK_END //光标移到尾
LSEEK_CUR //光标当前位置
返回值:
成功:返回当前位移
失败:返回-1
参数:
fd;文件描述符
offset:偏移量,每一个读写操作所需要移动的距离,单位是字节,可正可负(向前移,向后移)
whence:
SEEK_SET:当前位置为文件的开头,新位置为偏移量的大小
SEEK_CUR:当前位置为指针的位置,新位置为当前位置加上偏移量
SEEK_END:当前位置为文件的结尾,新位置为文件大小加上偏移量的大小
可以巧用lseek函数计算文件大小。例如 int size =lseek(fd,0,LSEEK_END); lseek返回值返回的是字节数。注意(offset 偏移是负数是往前,正数是往后)。
6.CREAT函数
功能描述:创建文件
所需头文件: #include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
函数原型: int creat(const char *pathname, mode_t mode);
参数: const char *pathname 创建文件的路径名
mode_t mode 文件权限
mode_t mode 参数: S_IRUSR 00400 可读
S_IWUSR 00200 可写
S_IXUSR 00100 可执行
S_IRWXU 00700 可读可写可执行
7.返回值fd都是从3开始系统默认的0,1,2被标准输入输出错误占用
0 标准输入
1 标准输出
2 标准错误
例子:
#include<stdio.h>
#include <unistd.h>
#include<string.h>
int main()
{
char readbuf[128];
read(0,readbuf,5); //从标准输入(键盘)里获取键盘输入
write(1,readbuf,strlen(readbuf)); //把获取到的输入输出
printf("\nfail\n"); //换行提示
return 0;
}

8.函数实例1

#include<stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include<string.h>
#include<stdlib.h>
// int open(const char *pathname, int flags);
// int open(const char *pathname, int flags, mode_t mode);
//ssize_t write(int fd, const void *buf, size_t count);
// ssize_t read(int fd, void *buf, size_t count);


int main()
{
        int fd;
        char *writebuf="yl hen shuai !";
        char *readbuf;
        fd=open("./txt1",O_RDWR|O_CREAT|O_EXCL,0600);  	 // open wen jian
        if(fd==-1){
                perror("why");
        }
        printf("open  sucess\n");
        if(write(fd,writebuf,strlen(writebuf))==-1){  	  //write txt1
                perror("why");
        }
        printf("write sucess\n");
        int size=lseek(fd,0,SEEK_END);  //get size
        lseek(fd,0,SEEK_SET);
        readbuf=(char *)malloc(sizeof(char)*size);
        if(read(fd,readbuf,size)==-1){ 						 //read txt1
                perror("why");
        }
        printf("read sucess: %s",readbuf);
        printf("%d\n",size);
        close(fd);
        return 0;
}
结果如下:
open  sucess
write sucess
read sucess: yl hen shuai !14

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值