APUE之IO

1.open,create,write,close,lseek。fcntl.h、unistd.h中

等无缓冲IO函数(其实也是有缓冲buf的,只是在内核态不再用户态),打开的文件是在内核中用int类型的文件描述符来标识由open系统调用获得,write,close,lseek等系统调用要用到文件描述符。

其中惯例是0为标准输入STDIN_FILENO,1为标准输出STDOUT_FILENO,2为标准错误STDERR_FILENO.

格式如下:

a.int open(const char *pathname,int oflag,..../mode_t mode/);返回文件描述符

b.int close(int filedes);filedes为文件描述符。

c.off_t lseek(int filedes,off_t offset,int whence)可根据whence的不同来判断从哪里开始偏移。返回偏移量

d.size_t read(int filedes,void *buf,size_t count);读取count字节到buf缓冲区。此缓冲区与用户态的I/O缓冲区不同,这是内核态的缓冲区。如getc取1个字节,从用户态看缓冲区只有一个,但是内核态却缓存了很多个。返回值是读取的字节数,有可能比你要读取的字节数少,当返回-1表明出错了。读取终端时,以行为单位,读到换行符也直接返回了。

e.size_t write(int filedes,void *buf,size_t count);

读取和写入时,会产生阻塞。普通文件不会产生。

终端写入或者读取时,若没获取到换行符,则会长久等待造成堵塞。网络收数据也容易发生此状况。所以read参数中应该加NONBLOCK,当没有数据读返回-1并报错。

read,write,lseek都是需要文件描述符的,所以使用前要打开open文件,终端输入输出错误除外,因为已经打开且有描述符012.



2.用open打开的文件 一定是返回最小的可用的文件描述符。如,打开第一个文件,其描述符是3,再打开一个,是4.

重定向:可将输出文件描述符关掉(用close),然后打开文件必然是描述符为1.然后printf出来的数据就到文件了而不是输出终端。

自己写了一个重定向的程序:

#include <fcntl.h>
#include <stdio.h>
#include <unistd.h>

int
main(int argc,char *argv[])
{
        int p;
        close(STDOUT_FILENO);
        if(p=creat(argv[1],700)<0)
                perror("FILE");
        printf("You are a big pig!");
        close(p);
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值