Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1504812
  • 博文数量: 218
  • 博客积分: 6394
  • 博客等级: 准将
  • 技术积分: 2563
  • 用 户 组: 普通用户
  • 注册时间: 2008-02-08 15:33
个人简介

持之以恒

文章分类

全部博文(218)

文章存档

2013年(8)

2012年(2)

2011年(21)

2010年(55)

2009年(116)

2008年(16)

分类: 网络与安全

2010-01-10 08:50:06

从文件中读取日志信息,将其封装成ACE_Message_Block组成的复合消息,然后将消息在界面上显示出来。

#pragma once
#pragma comment(lib,"ACEd.lib")
#include "ACE/OS.h"
#include "ACE/ACE.h"
#include "ACE/Message_Block.h"
#include <fstream>
#define BUFSIZE 400 + 14//注意Message_Block分配的空间是要比实际的数据大,否则在release的时候将会出错!

//400的话就会有错!

typedef struct
{
    int nDataSize;
    char chRealData[400];
} MYDATAFRAME;//数据缓冲

int main(int argc,char * argv[])
{
    //////////////////////////////////////////////////////////////////////////

    /// 读取Log文件,将Log文件的内容封装成复合消息(ACE_Message_Block)

    /// 并显示出来

    //////////////////////////////////////////////////////////////////////////

    ACE_Message_Block * head = new ACE_Message_Block(BUFSIZE);
    ACE_Message_Block * mblk = head;
    std::ifstream ifLogFile;
    ifLogFile.open("ace.log",ios::in);
    MYDATAFRAME m_frameDataBuffer;
    ACE_OS::memset(m_frameDataBuffer.chRealData,'\0',400);
    m_frameDataBuffer.nDataSize = 0;
    int nReadCnt = 0;
    while(!ifLogFile.eof())
    {
        ifLogFile.read(m_frameDataBuffer.chRealData,REAL_DATA_SIZE);
        nReadCnt = ifLogFile.gcount();
        //gcount函数:返回上次"非格式话读取操作"所读入的字符的个数

        m_frameDataBuffer.nDataSize=nReadCnt;
        int count = ::sprintf(mblk->wr_ptr(),m_frameDataBuffer.chRealData);
        mblk->wr_ptr(nReadCnt);//注意这里不能用::sprintf返回的count,这个数值是不准确的!,而是使用gcount函数返回的nReadCnt

        ACE_OS::memset(m_frameDataBuffer.chRealData,'\0',400);
        m_frameDataBuffer.nDataSize = 0;
        if (nReadCnt <= 0)
        {
            break;
        }
        mblk->cont(new ACE_Message_Block(BUFSIZE));//组成消息链,复合消息

        mblk = mblk->cont();
    }
    ifLogFile.close();
    for (mblk = head; mblk != 0;mblk = mblk->cont())
    {
        ACE::write_n(ACE_STDOUT,mblk->rd_ptr(),mblk->length());
    }
    head->release();//释放空间,注意这里是全部消息链上的空间都进行了释放!

    getchar();
    return 0;
}


阅读(1082) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~