博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
linux c文件操作接口
阅读量:6624 次
发布时间:2019-06-25

本文共 2451 字,大约阅读时间需要 8 分钟。

文章转载自: http://blog.sina.com.cn/s/blog_71d1a98701010s0v.html

1. open 函数

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

    2). 所需头文件:

    #include<sys/types.h>

    #include<sys/stat.h>

    #include<fcntl.h>

    3). 函数原型: int open(const char *pathname, intflags, int perms)

    4). 返回值: 成功返回文件描述符,失败返回-1

         -1: 打开失败

         0~255: 打开成功

    5). 参数:

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

         b. flags:文件打开方式,

             O_RDONLY:以只读方式打开文件

             O_WRONLY:以只写方式打开文件

             O_RDWR:以读写方式打开文件

             O_CREAT:如果改文件不存在,就创建一个新的文件,并用第三个参数为其设置权限

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

             O_NOCTTY:使用本参数时,若文件为终端,那么该终端不会成为调用open()的那个进程的控制终端

             O_TRUNC:若文件已经存在,那么会删除文件中的全部原有数据,并且设置文件大小为0
             O_APPEND:以添加方式打开文件,在打开文件的同时,文件指针指向文件的末尾,即将写入的数据添加到文件的末尾

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

             O_SYNC:使每次write都等到物理I/O操作完成。

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

        c. perms:被打开文件的存取权限,可以用两种方法表示,可以用一组宏定义:S_I(R/W/X)(USR/GRP/OTH),其中R/W/X表示读写执行权限,USR/GRP/OTH分别表示文件的所有者/文件所属组/其他用户,如S_IRUUR|S_IWUUR|S_IXUUR,(-rex------),也可用八进制800表示同样的权限

2. close 函数

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

    2). 所需头文件

         #include<unistd.h>

    3). 函数原型: int close(int fd)

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

    5). 参数:fd文件描述符

3. read 函数

    1). 功能描述: 从文件读取数据。

    2). 所需头文件

         #include<unistd.h>

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

    4). 参数:  

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

    5). 返回值

         1. 成功: 返回所读取的字节数 或者 0(读到EOF)

         2. 失败: -1

    6). 以下几种情况会导致读取到的字节数小于 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 增加,增量为实际读取到的字节数。

 

4. write 函数

    1). 功能描述: 向文件写入数据。

    2). 所需头文件

         #include<unistd.h>

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

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

    5). 功能: write 函数向文件中写入count字节数据,数据来源为 buf 。返回值一般总是等于count,否则就是出错了。 

    6). 常见的出错原因是磁盘空间满了或者超过了文件大小限制。

5. lseek 函数 

    1). 功能描述: 用于在指定的文件描述符中将将文件指针定位到相应位置。

    2). 所需头文件

         #include<unistd.h>

         #include<sys/types.h>

    3). 函数原型: off_t lseek(int fd, off_t offset, int whence);

    4). 返回值

         成功: 返回当前位移

         失败: 返回-1

    5). 参数

         fd;文件描述符

         offset:偏移量,每一个读写操作所需要移动的距离,单位是字节,可正可负(向前移,向后移)

         whence:

                    SEEK_SET:当前位置为文件的开头,新位置为偏移量的大小

                    SEEK_CUR:当前位置为指针的位置,新位置为当前位置加上偏移量

                    SEEK_END:当前位置为文件的结尾,新位置为文件大小加上偏移量的大小

你可能感兴趣的文章
小程序开发总结
查看>>
Tomcat监听器设计思路
查看>>
管理ORACLE实例
查看>>
Confluence 6 MySQL 数据库设置准备
查看>>
Ruby 中 0/0.0 = NaN
查看>>
JEESNS数据库表设计结构
查看>>
JavaScript学习笔记:判断变量是否为undefined,判断变量和函数是否声明
查看>>
局域网访问Apache服务器
查看>>
JavaScript 闭包
查看>>
Spark算子:RDD行动Action操作(3)–aggregate、fold、lookup
查看>>
UILabel总结
查看>>
java获取当前时间前一周、前一月、前一年的时间
查看>>
话说WEB开发之页面重绘和回流
查看>>
using标识使用
查看>>
解决linux下不能上网
查看>>
nginx rewrite伪静态配置参数说明
查看>>
python学习笔记(15-18)
查看>>
Oracle 查询不区分大小写 (正则函数)
查看>>
T264接口说明
查看>>
SELinux介绍
查看>>