青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Codejie's C++ Space

Using C++

OutputAgentObject:用于Log輸出的對象

Log的輸出問題是程序設計需要在設計初期就要計劃的一個模塊,其接口和功能的設計,會直接影響整體程序的調試和信息輸出等方面。
    wxDeMPQ在初期,計劃通過其StatusBar作為Log輸出,并簡單封裝了一個函數,但在實際使用中,由于急于實現功能和DLL等的引入,加上VC方便的調試,導致完全廢棄了當初的想法,這也是的wxDeMPQ在后期實現上沒有任何的Log輸出,這對于Debug的程序來說,是--災難和活該。
    對于類似Log輸出的模塊,在實現時需要考慮的是使用時的易融合性和靈活性。簡單地說,一來此模塊的引入不應影響原代碼的執行;二來要考慮信息輸出的不確定性,就是說你可能無法預知程序會最終通過什么方式輸出,文件?Console?或者一個EditCtrl?這兩點我認為是需要在初期著重考慮的。
    下面是一個簡單Log輸出模塊的實現,通過Adapter方式,連接輸入和輸出。
#pragma once

#include 
<string>

#ifdef OUTPUTAGENTLIBRARY_EXPORTS
#define OUTPUTAGENTLIBRARY_API __declspec(dllexport)
#else
#define OUTPUTAGENTLIBRARY_API __declspec(dllimport)
#endif

namespace OUTPUT
{

class OUTPUTAGENTLIBRARY_API COutputBase
{
public:
    COutputBase() {}
    
virtual ~COutputBase() {}

    
virtual void Output(const std::wstring& info) = 0;
};

const unsigned int LEVEL_DEBUG        =    1;
const unsigned int LEVEL_INFO        =    2;
const unsigned int LEVEL_WARN        =    4;
const unsigned int LEVEL_ERROR        =    8;

const unsigned int LEVEL_ALL        =    0xFFFFFFFF;

class OUTPUTAGENTLIBRARY_API COutputAgentObject
{
public:
    COutputAgentObject();
    
virtual ~COutputAgentObject();

    
void SetLevel(unsigned int level);
    unsigned 
int GetLevel() const;
    
void SetOutput(COutputBase* output);
    COutputBase 
* GetOutput() const;

    
void Output(unsigned int level, const std::wstring& info);
protected:
    COutputBase
* _output;
    unsigned 
int _level;
};

}

//#define OUTPUT(outputptr, level, info) \
//{\
//    if(outputptr != NULL) \
//    {\
//        std::wostringstream ostr; \
//        ostr << info; \
//        outputptr->Output(level, ostr.c_str()); \
//    }\
//}

#include "stdafx.h"

#include 
"OutputAgentObject.h"

namespace OUTPUT
{

COutputAgentObject::COutputAgentObject()
: _output(NULL), _level(LEVEL_ALL)
{
}

COutputAgentObject::
~COutputAgentObject()
{
}

void COutputAgentObject::SetLevel(unsigned int level)
{
    _level 
= level;
}

unsigned 
int COutputAgentObject::GetLevel() const
{
    
return _level;
}

void COutputAgentObject::SetOutput(COutputBase* output)
{
    _output 
= output;
}

COutputBase
* COutputAgentObject::GetOutput() const
{
    
return _output;
}

void COutputAgentObject::Output(unsigned int level, const std::wstring& info)
{
    
if(_output == NULL)
        
return;
    
if((level & _level) == 0)
        
return;
    _output
->Output(info);
}


}

    下面是一段測試代碼,用于展示如何使用。
#pragma once

#include 
<string>
#include 
<sstream>

#include 
"wx/wx.h"

#include 
"OutputAgentObject.h"

class COutput : public OUTPUT::COutputBase
{
public:
    COutput(wxTextCtrl
* text)
        :_text(text)
    {
    }
    
virtual ~COutput() {}

    
virtual void Output(const std::wstring& info)
    {
        
if(_text != NULL)
        {
            _text
->AppendText(WString2wxString(info));
        }
    }
protected:
    
const wxString WString2wxString(const std::wstring& str)
    {
        
return wxString(str.c_str(), wxConvISO8859_1);
    }
private:
    wxTextCtrl
* _text;
};

OUTPUT::COutputAgentObject g_stOutputAgent;

#define OUTPUT(level, info) \
{\
    std::wostringstream ostr; \
    ostr 
<< info; \
    g_stOutputAgent.Output(level, ostr.str());\
}

    _output = new COutput(m_textOutput);

    g_stOutputAgent.SetOutput(_output);

    OUTPUT(OUTPUT::LEVEL_INFO, L"Level:" << g_stOutputAgent.GetLevel() << std::endl);


   簡單實現,很多因素并不考慮,如Thread Safe問題等,源碼和測試代碼在這里。測試程序模樣如下:


posted on 2009-06-09 10:52 codejie 閱讀(262) 評論(0)  編輯 收藏 引用 所屬分類: C++

公告

Using C++

導航

統計

留言簿(73)

隨筆分類(513)

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久不射中文字幕| 久久综合中文| 午夜伦欧美伦电影理论片| 亚洲第一在线| 欧美一区二区视频97| 国产精品v日韩精品v欧美精品网站| 亚洲第一精品夜夜躁人人躁| 欧美一区免费| 午夜欧美精品| 国产一区二区三区观看| 久久精品国产69国产精品亚洲| 亚洲天堂第二页| 国产精品亚洲综合一区在线观看| 亚洲字幕在线观看| 亚洲欧美日韩第一区| 国产伦精品一区二区三| 欧美一区视频| 久久国产黑丝| 91久久精品日日躁夜夜躁国产| 欧美韩日高清| 欧美夫妇交换俱乐部在线观看| 牛夜精品久久久久久久99黑人| 久久精品首页| 亚洲国产精品成人综合| 欧美黄色精品| 欧美日韩在线三区| 久久国产乱子精品免费女 | 一本色道久久| 国产精品一区二区你懂得| 欧美中文在线观看| 久久综合久久综合九色| 亚洲精品欧美日韩专区| 99热免费精品| 国内伊人久久久久久网站视频| 欧美成人激情视频| 欧美日本亚洲视频| 久久久999成人| 欧美黄色aa电影| 香港久久久电影| 久久久午夜电影| 中文久久乱码一区二区| 欧美伊人久久| 99在线精品视频在线观看| 亚洲一本大道在线| 在线观看视频欧美| 亚洲视频导航| 91久久综合亚洲鲁鲁五月天| 亚洲图片欧美一区| 亚洲国产91精品在线观看| 亚洲视频电影在线| 在线精品观看| 午夜精品久久久久久久99热浪潮 | 欧美高清在线视频观看不卡| 欧美日韩精品欧美日韩精品一| 久久精品72免费观看| 欧美人体xx| 免费欧美网站| 国产日韩欧美麻豆| av不卡免费看| 亚洲日本电影| 久久精品99无色码中文字幕| 亚洲视频久久| 美女成人午夜| 久久美女性网| 国产伦精品一区二区三区高清版| 亚洲电影免费观看高清完整版在线观看 | 欧美国产大片| 国产一区二区电影在线观看| 亚洲日本aⅴ片在线观看香蕉| 黄色一区三区| 欧美中文字幕| 久久精品国产精品亚洲| 国产精品伦一区| 99av国产精品欲麻豆| 亚洲美女毛片| 欧美不卡高清| 欧美激情久久久久| 亚洲二区免费| 久久成人精品电影| 亚洲日本中文字幕区| 国产人成一区二区三区影院| 亚洲日本激情| 亚洲国产欧美另类丝袜| 久久久国产精品一区二区三区| 香蕉成人啪国产精品视频综合网| 欧美视频手机在线| aa级大片欧美三级| 亚洲视屏一区| 国产精品久久久久久久久果冻传媒 | 欧美精品一区在线观看| 欧美黑人在线播放| 亚洲激情国产| 欧美大片91| 亚洲人体影院| 亚洲一区二区三区四区中文| 欧美特黄一区| 亚洲一区二区三区高清不卡| 亚洲欧美国产精品桃花| 国产精品一区二区a| 小黄鸭精品密入口导航| 久久久久久久综合狠狠综合| 国产一区二区三区在线观看免费| 欧美在线观看www| 免费欧美日韩| 一区二区三区高清视频在线观看| 欧美日韩国产精品自在自线| 一本久久综合亚洲鲁鲁五月天| 亚洲欧美国产制服动漫| 国产一区二区三区成人欧美日韩在线观看| 性娇小13――14欧美| 美脚丝袜一区二区三区在线观看 | 国产精品久久久一区麻豆最新章节| 在线亚洲电影| 久久久久久夜| 亚洲美女视频在线观看| 欧美午夜精品久久久久久超碰| 亚洲欧美成人综合| 欧美成人午夜免费视在线看片| 99re视频这里只有精品| 国产精品久久久久国产a级| 欧美一区在线直播| 亚洲黄色成人网| 亚洲欧美在线一区| 在线欧美日韩| 国产精品毛片| 美女精品网站| 亚洲自拍偷拍麻豆| 亚洲高清免费视频| 欧美一区二区三区四区视频| 亚洲第一福利视频| 国产精品成人在线| 美女精品视频一区| 午夜精品久久一牛影视| 亚洲国产欧美另类丝袜| 久久国产精品99国产| 99精品国产热久久91蜜凸| 国产亚洲成av人在线观看导航| 欧美成人蜜桃| 久久精品99| 一区二区欧美精品| 欧美性天天影院| 久久免费偷拍视频| 一区二区日韩| 亚洲国产一区在线观看| 久久成人国产精品| 亚洲一二三区精品| 亚洲精品国产欧美| 在线成人av网站| 国产精品色午夜在线观看| 欧美大片在线观看一区| 久久高清福利视频| 午夜视频久久久| 这里只有精品视频| 亚洲精品视频免费观看| 欧美国产高清| 蜜桃久久av| 美女视频黄 久久| 久久激情久久| 欧美综合激情网| 欧美一级一区| 亚洲欧美日韩视频一区| 亚洲一区二区三区视频| 99亚洲精品| 99国产精品久久久| 99re热这里只有精品免费视频| 亚洲国产精品久久久久秋霞影院| 韩国成人福利片在线播放| 国产精品一国产精品k频道56| 欧美日韩成人综合天天影院| 欧美成人免费播放| 欧美国产一区二区三区激情无套| 乱人伦精品视频在线观看| 蜜桃久久av| 毛片基地黄久久久久久天堂| 久久久噜噜噜久久| 久久久国产精品亚洲一区 | 亚洲欧洲一区二区在线播放| 欧美搞黄网站| 最新69国产成人精品视频免费| 亚洲激情视频| 99riav久久精品riav| 一区二区三区黄色| 亚洲一区二区成人| 午夜久久美女| 噜噜爱69成人精品| 欧美人与性动交α欧美精品济南到| 欧美久久久久久久久| 欧美三级在线播放| 国产精品一区二区久久久久| 国产夜色精品一区二区av| 永久久久久久| 一区二区三区高清| 久久福利视频导航| 欧美成人午夜激情| 一区二区高清视频在线观看| 亚洲欧美国产日韩天堂区| 久久九九热免费视频| 欧美激情视频一区二区三区在线播放 | 久久在线视频在线| 欧美日本一区|