Linux下libaio的一個簡單例子


轉載:http://www.cnblogs.com/aLittleBitCool/archive/2011/10/18/2216646.html

異步io,很好玩的一個東西,從接口來看,封裝的比較厲害,有時間研究內部實現,可以在項目中考慮替代select.

libaio是Linux下的一個異步非阻塞接口,它提供了以異步非阻塞方式來讀寫文件的方式,讀寫效率比較高。

首先推薦兩個介紹Linux I/O模型的頁面,寫的很好:

http://www.ibm.com/developerworks/cn/linux/l-async/

http://www.iteye.com/topic/868702

對於libaio的讀寫過程簡單說來就是你發出一個讀寫請求,然后你可以開始做其他事情,當讀寫過程結束時libaio會通知你你的這次請求已經完成(而select模型是告訴你讀寫已經就緒)。

這里給出一個很簡單的小例子,具體函數可以通過man查看:

#include<stdio.h>
#include<fcntl.h>
#include<string.h>
#include<stdlib.h>
#include<libaio.h>
#include<errno.h>
#include<unistd.h>
int main(void){
    int output_fd;
    const char *content="hello world!";
    const char *outputfile="hello.txt";
    io_context_t ctx;
    struct iocb io,*p=&io;
    struct io_event e;
    struct timespec timeout;
    memset(&ctx,0,sizeof(ctx)); 
    if(io_setup(10,&ctx)!=0){//init
        printf("io_setup error\n"); 
        return -1; 
    }   
    if((output_fd=open(outputfile,O_CREAT|O_WRONLY,0644))<0){   
        perror("open error");
        io_destroy(ctx);
        return -1; 
    }   
    io_prep_pwrite(&io,output_fd,content,strlen(content),0);
    io.data=content;
    if(io_submit(ctx,1,&p)!=1){
        io_destroy(ctx);
        printf("io_submit error\n");    
        return -1; 
    }   
    while(1){
        timeout.tv_sec=0;
        timeout.tv_nsec=500000000;//0.5s
        if(io_getevents(ctx,0,1,&e,&timeout)==1){   
            close(output_fd);
            break;
        }   
        printf("haven't done\n");
        sleep(1);
    }   
    io_destroy(ctx);
    return 0;
}

  

有關libaio更加詳細的內容可以看以下兩個頁面:

http://tiaozhanshu.com/libaio-api.html

http://lse.sourceforge.net/io/aio.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM