Linux I/O模型 与 Java I/O模型、驱动中的异步函数 的区别。

本文通过一个小例子展示了Linux下aio_suspend()函数如何挂起进程直至异步I/O请求完成,并对比了Linux与Java中异步I/O的设计亮点。

主要欣赏 Linux 异步I/O 与 Java 的 异步 I/O 设计的精彩之处。

Linux 异步IO

1 : aio_suspend()
这里写图片描述
它会挂起调用的进程,直到异步的请求完成,数组中的任何一个异步I/O请求完成,aio_suspend都会返回。
那么,下面的一个小例子来实验 验证。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
?#include <unistd.h>
#include <fcntl.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <aio.h>

#define BUFFER_SIZE 1024
#define MAX 2
#define ERR_EXIT(m)\
    do\
    {\
        perror(m);\
        exit(EXIT_FAILURE);\
    }while(0)

int main(void)
{
    struct aiocb lee_aiocb,lee_aiocb2;
    const struct aiocb * cblist[MAX];
    int fd ;
    fd = open("/dev/input/event2",O_RDWR);  
    if(fd < 0){
        ERR_EXIT("open");
    }

    memset(&my_aiocb,0,sizeof(lee_aiocb));
    memset(&my_aiocb2,0,sizeof(lee_aiocb2));
    memset(cblist,0,sizeof(cblist));

    cblist[0] = &lee_aiocb;
    cblist[1] = &lee_aiocb2

    lee_aiocb.aio_fildes = fd;
    lee_aiocb.aio_nbytes = BUFFER_SIZE;
    lee_aiocb.aio_offset = 0;
    lee_aiocb.aio_buf = malloc(BUFFER_SIZE + 1 );
    if(!lee_aiocb.aio_buf){
        ERR_EXIT("malloc");
    }
    lee_aiocb2.aio_fildes = 0;        // 0 标准输入
    lee_aiocb2.aio_nbytes = BUFFER_SIZE;
    lee_aiocb2.aio_offset = 0;
    lee_aiocb.aio_buf = malloc(BUFFER_SIZE + 1);
    if(!lee_aiocb.aio_buf){
        ERR_EXIT("malloc"); 
    }

    ret = aio_read(&lee_aiocb);
    if(ret < 0){
        ERR_EXIT("aio_read");
    }

    aio_read(&lee_aiocb2);

    printf("before aio_suspend\n");

    ret = aio_suspend(cblist,2,NULL);
    if(ret < 0){
        .......
    }   
    printf("after aio_suspend\n");
    close(fd);
    return 0;
}
IO多路复用模型
信号驱动IO模型
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值