几个基本的I/O系统调用,你看你会了吗???

一。open 函数用于打开和创建文件。以下是 open 函数的简单描述

        #include <fcntl.h>

        int open(const char *pathname, int oflag, ... /* mode_t mode */);

                    返回值:成功则返回文件描述符,否则返回 -1

对于 open 函数来说,第三个参数(...)仅当创建新文件时才使用,用于指定文件的访问权限位(access permission bits)。pathname 是待打开/创建文件的路径名(如 C:/cpp/a.cpp);oflag 用于指定文件的打开/创建模式,这个参数可由以下常量(定义于 fcntl.h)通过逻辑或构成。

        O_RDONLY      只读模式
        O_WRONLY      只写模式
        O_RDWR        读写模式
 
打开/创建文件时,至少得使用上述三个常量中的一个。以下常量是选用的:

        O_APPEND       每次写操作都写入文件的末尾
        O_CREAT        如果指定文件不存在,则创建这个文件
        O_EXCL         如果要创建的文件已存在,则返回 -1,并且修改 errno 的值
        O_TRUNC        如果文件存在,并且以只写/读写方式打开,则清空文件全部内容
        O_NOCTTY       如果路径名指向终端设备,不要把这个设备用作控制终端。
        O_NONBLOCK     如果路径名指向 FIFO/块文件/字符文件,则把文件的打开和后继 I/O
                       设置为非阻塞模式(nonblocking mode)

以下三个常量同样是选用的,它们用于同步输入输出

        O_DSYNC        等待物理 I/O 结束后再 write。在不影响读取新写入的数据的
                       前提下,不等待文件属性更新。
        O_RSYNC        read 等待所有写入同一区域的写操作完成后再进行
        O_SYNC         等待物理 I/O 结束后再 write,包括更新文件属性的 I/O

open 返回的文件描述符一定是最小的未被使用的描述符。

    如果 NAME_MAX(文件名最大长度,不包括'/0')是 14,而我们想在当前目录下创建文件名长度超过 14 字节的文件,早期的 System V 系统(如 SVR2)会截断超出部分,只保留前 14 个字节;而由 BSD 衍生的(BSD-derived)系统会返回错误信息,并且把 errno 置为 ENAMETOOLONG。

    POSIX.1 引入常量 _POSIX_NO_TRUNC 用于决定是否截断长文件名/长路径名。如果_POSIX_NO_TRUNC 设定为禁止截断,并且路径名长度超过 PATH_MAX(包括 '/0'),或者组成路径名的任意文件名长度超过 NAME_MAX,则返回错误信息,并且把 errno 置为 ENAMETOOLONG。
 

2. read

        #include <unistd.h>

        ssize_t read(int filedes, void *buf, size_t nbytes);
 
                  返回值:读取到的字节数;0(读到 EOF);-1(出错)

    read 函数从 filedes 指定的已打开文件中读取 nbytes 字节到 buf 中。以下几种情况会导致读取到的字节数小于 nbytes :

    A. 读取普通文件时,读到文件末尾还不够 nbytes 字节。例如:如果文件只有 30 字节,而我们想读取 100 字节,那么实际读到的只有 30 字节,read 函数返回 30 。此时再使用 read 函数作用于这个文件会导致 read 返回 0 。

    B. 从终端设备(terminal device)读取时,一般情况下每次只能读取一行。

    C. 从网络读取时,网络缓存可能导致读取的字节数小于 nbytes 字节。

    D. 读取 pipe 或者 FIFO 时,pipe 或 FIFO 里的字节数可能小于 nbytes 。

    E. 从面向记录(record-oriented)的设备读取时,某些面向记录的设备(如磁带)每次最多只能返回一个记录。

    F. 在读取了部分数据时被信号中断。

读操作始于 cfo 。在成功返回之前,cfo 增加,增量为实际读取到的字节数。


3. write

        #include <unistd.h>

        ssize_t write(int filedes, const void *buf, size_t nbytes);
 
                返回值:写入文件的字节数(成功);-1(出错)

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

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

4.lseek函数 用法 :


表头文件:#include   <sys/types.h>
           #include   <unistd.h>
定义函数:off_t   lseek(int fildes,   off_t   offset,   int   whence)
函数说明:每一个已打开的文件都有一个读写位置,当打开文件时通常其读写位置是指向文件开头,若是以附加的方式打开文件(如O_APPEND),则会读写位置会指向文件尾。当read()或write()时,读写位置会随之增加,lseek()便是用来控制该文件的读写位置。参数fildes为已打开的文件描述词,参数offset为根据参数whence来移动读写位置的位移数。参数whence为下列其中一种:
SEEK_SET             参数offset即为新的读写位置
SEEK_CUR             当前读写位置后增加offset个位移量。
SEEK_END             将读写位置指向文件尾后再增加offset个位移量

当whence值为SEEK_CUR或SEEK_END时,参数offset允许负值的出现

下列是较特别的使用方式:
1)欲将读写位置移到文件开头时:lseek(int   fildes, 0, SEEK_SET)
2)欲将读写位置移到文件尾时时:lseek(int fildes, 0, SEEK_END)
3)欲将取得目前文件位置时:lseek(int fildes, 0, SEEK_CUR)

返回值:当调用成功时则返回目前的读写位置,也就是距离文件开头多少个字符。若有错误则返回-1, errno会存放错误代码。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值