首页 > 系统服务 > 详细

基于本博客版本中的循环缓冲的测试(Linux环境)

时间:2014-06-08 20:45:53      阅读:497      评论:0      收藏:0      [点我收藏+]

 

bubuko.com,布布扣
#include <stdlib.h>
#include <stdio.h>
#include <pthread.h>
#include "ringbuffer.h"

static int b_flag = 0;

pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
#define TX_LOCK(lock)   pthread_mutex_lock(&lock)
#define TX_UNLOCK(lock) pthread_mutex_unlock(&lock)

void* ReadBufferThread(void* param)
{
    RingBuffer * pstRing = (RingBuffer *)param;
    FILE* fpOut = NULL;
    size_t ret = 0;
    uint8 szBuf[128*1024] = {0};
    int nLen = 0;

    fpOut = fopen("file.bak", "w");
    if (fpOut == NULL)
    {
        return NULL;
    }
    while(b_flag)
    {
        TX_LOCK(mutex);
        nLen = RingBuffer_read(pstRing, szBuf, sizeof(szBuf));
        TX_UNLOCK(mutex);
        if (nLen)
        {
            ret = fwrite(szBuf, sizeof(char), nLen, fpOut);
            if (ret != nLen)
            {
                printf("fwrite failure!, ret = %d, nLen = %d\n", ret, nLen);
            }
        }
        
        usleep(100);        
    }
    fclose(fpOut);
    return NULL;
}
int main(int argc, char**argv)
{
    FILE* fpIn = NULL;
    size_t ret = 0;
    uint8 szBuf[64*1024] = {0};    
    int nWriteLen = 0;
    int nOffset = 0;
    int nReReadFlag = 0;
    pthread_t threadID = 0;
    RingBuffer * pstRing = NULL;

    if (argc < 2)
    {
        printf("usage: %s file_to_read\n", argv[0]);
        return -1;
    }

    pstRing = RingBuffer_create(2*1024*1024);

    if (pstRing == NULL)
    {
        printf("create ring buffer failure!\n");
        return -1;
    }
    
    b_flag = 1;
    pthread_create(&threadID, NULL, ReadBufferThread, pstRing);

    fpIn = fopen(argv[1], "r");
    if (fpIn == NULL)
    {
        b_flag = 0;
        pthread_cancel(threadID);
        pthread_join(threadID,NULL);
        return -1;
    }
    while(1)
    {
        if (nReReadFlag == 0)
        {
            ret = fread (szBuf, sizeof(char), sizeof(szBuf), fpIn) ;
            if (ret != sizeof(szBuf))
            {
                printf("reach to the end of the file ret = %d, eof = %d!\n",ret,feof(fpIn));
                TX_LOCK(mutex);
                nWriteLen = RingBuffer_write(pstRing, szBuf, ret);
                TX_UNLOCK(mutex);
                if (nWriteLen != ret)
                {
                    ret = ret - nWriteLen;
                    nOffset = nWriteLen;
                    nReReadFlag = 1;
                    printf("here still need to write %d byte to buffer!\n", ret);
                }
                else
                {
                    ret = 0;
                    nWriteLen = 0;
                    nOffset = 0;
                    nReReadFlag = 0;
                }
                break;
            }
        }        
        TX_LOCK(mutex);
        nWriteLen = RingBuffer_write(pstRing, &szBuf[nOffset], ret);
        TX_UNLOCK(mutex);
        if (nWriteLen != ret)
        {
            printf("%d, still need to write %d, write len = %d, offset = %d\n", __LINE__, ret, nWriteLen, nOffset);
            ret -= nWriteLen;
            nOffset += nWriteLen;
            nReReadFlag = 1;
        }
        else
        {
            printf("ret = %d, nWriteLen = %d\n",ret, nWriteLen);
            nWriteLen = 0;
            nOffset = 0;
            ret = 0;
            nReReadFlag = 0;
        }
        
        usleep(200);
    }
    
    fclose(fpIn);
    
    printf("already finished read the file!\n");

    while(ret)
    {
        printf("here again write %d byte...\n", ret);
        TX_LOCK(mutex);
        nWriteLen = RingBuffer_write(pstRing, &szBuf[nOffset], ret);
        TX_UNLOCK(mutex);
        if (nWriteLen != ret)
        {
            ret -= nWriteLen;
            nOffset += nWriteLen;
        }
        else
        {
            ret = 0;
            nWriteLen = 0;
            nOffset = 0;
        }
        
        usleep(300);
    }

    while(1)
    {
        TX_LOCK(mutex);
        ret = RingBuffer_empty(pstRing);
        TX_UNLOCK(mutex);
        if (ret)
        {
            printf("the buffer is empty...\n");
            break;
        }
        usleep(100);
    }
        
    RingBuffer_destroy(pstRing);

    b_flag = 0;
    pthread_cancel(threadID);
      pthread_join(threadID,NULL);

    return 0;
}
bubuko.com,布布扣

 

基于本博客版本中的循环缓冲的测试(Linux环境),布布扣,bubuko.com

基于本博客版本中的循环缓冲的测试(Linux环境)

原文:http://www.cnblogs.com/eric-geoffrey/p/3775896.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!