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

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 閱讀(260) 評論(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>
            欧美成熟视频| 亚洲最新视频在线播放| 久久亚洲精品一区二区| 久久精品视频免费| 久久久xxx| 可以看av的网站久久看| 蜜桃av一区二区三区| 欧美激情网友自拍| 国产精品国内视频| 国产精品视屏| 激情欧美日韩| 99精品国产在热久久下载| 亚洲一区在线看| 久久久亚洲国产天美传媒修理工 | 亚洲国产精品福利| 久久精品网址| 亚洲国产精品毛片| 亚洲欧美日韩国产| 久久野战av| 欧美亚洲第一页| 伊人久久亚洲影院| 亚洲视频axxx| 久久综合伊人77777尤物| 亚洲国产日韩欧美在线99| 亚洲自拍偷拍一区| 欧美国产高潮xxxx1819| 国产网站欧美日韩免费精品在线观看| 伊人激情综合| 亚洲欧美区自拍先锋| 欧美**字幕| 亚洲综合视频网| 欧美11—12娇小xxxx| 亚洲人成在线播放| 精品动漫av| 亚洲三级视频| 欧美一区二区三区视频免费播放 | 在线观看欧美日韩| 亚洲在线观看视频| 欧美成人有码| 久久成人精品无人区| 欧美视频一区二区三区| 亚洲电影免费观看高清| 久久精品国产综合精品| 99re热这里只有精品视频| 久久在线免费视频| 黄色成人在线网址| 性伦欧美刺激片在线观看| 亚洲日本成人在线观看| 麻豆精品精华液| 亚洲第一黄网| 欧美a一区二区| 久久久久久精| 激情久久综艺| 另类图片综合电影| 欧美在线亚洲在线| 国产亚洲欧洲| 欧美在线中文字幕| 亚洲欧美日韩爽爽影院| 国产精品乱码一区二区三区| 亚洲综合色婷婷| 亚洲网站在线观看| 国产精品入口| 久久久久久久综合| 久久婷婷一区| 亚洲人成艺术| 日韩五码在线| 国产欧美欧洲在线观看| 久久精品91| 久久亚洲综合网| 99天天综合性| 亚洲尤物视频网| 一区二区三区在线观看欧美 | 夜夜夜精品看看| 欧美午夜www高清视频| 午夜免费电影一区在线观看| 亚洲欧美中日韩| 在线观看成人网| 亚洲激情av| 欧美午夜一区二区福利视频| 亚洲女女女同性video| 亚洲免费网址| 尤妮丝一区二区裸体视频| 亚洲第一黄色| 国产精品久久久久久久久久免费 | 欧美 日韩 国产在线| 午夜精品亚洲| 美女久久一区| 亚洲字幕在线观看| 久久av资源网| 一区二区黄色| 欧美专区第一页| 99精品99| 欧美伊人影院| 亚洲精品欧美| 亚洲欧美日韩国产综合在线| 激情六月婷婷综合| 日韩一级片网址| 伊人久久婷婷| 亚洲欧美在线免费观看| 日韩亚洲欧美成人一区| 欧美一区亚洲| 亚洲一二区在线| 久久综合色综合88| 欧美亚洲免费在线| 欧美人与禽性xxxxx杂性| 香港成人在线视频| 欧美激情一区在线观看| 久久伊伊香蕉| 国产精品视频导航| 亚洲日韩欧美一区二区在线| 激情婷婷欧美| 欧美一区二区高清在线观看| 亚洲午夜三级在线| 欧美激情综合网| 免播放器亚洲一区| 国产精品久久久久久久app| 亚洲福利在线看| 激情小说另类小说亚洲欧美| 亚洲一线二线三线久久久| 亚洲麻豆视频| 欧美a级一区二区| 久久午夜视频| 国产人久久人人人人爽| 中文av一区二区| 亚洲性视频网站| 欧美日韩亚洲综合| 亚洲欧洲三级| 亚洲精品欧美在线| 免费观看成人鲁鲁鲁鲁鲁视频 | 西西人体一区二区| 欧美天堂在线观看| 99精品欧美一区二区三区 | 国产亚洲欧洲| 香蕉久久夜色精品国产| 亚洲欧美中文在线视频| 国产精品久99| 亚洲在线日韩| 欧美一区日韩一区| 国产三级欧美三级日产三级99| 亚洲一区二区三区久久| 欧美一区二区三区精品电影| 国产精品女主播一区二区三区| 亚洲天堂黄色| 欧美在线观看一区二区| 国产精品综合网站| 欧美影视一区| 男女激情视频一区| 亚洲人体偷拍| 欧美激情一区二区三区蜜桃视频| 免费成人在线视频网站| 一区在线播放| 麻豆精品视频在线| 欧美国产日韩一区| 亚洲免费播放| 国产精品久久久久久久午夜| 亚洲一区免费视频| 久久免费黄色| 亚洲日本中文字幕区| 欧美另类极品videosbest最新版本 | 毛片一区二区| 亚洲美女黄网| 欧美在线一区二区| 亚洲清纯自拍| 国产精品美女在线| 久久久久国产精品厨房| 亚洲精品久久久蜜桃| 午夜精品福利电影| 经典三级久久| 欧美日韩一区成人| 久久精品理论片| 99精品国产在热久久婷婷| 久久精品一级爱片| 日韩性生活视频| 国产亚洲精品一区二555| 免费观看国产成人| 亚洲女性裸体视频| 亚洲激情一区二区三区| 欧美一级一区| 99国产成+人+综合+亚洲欧美| 国产精品视频最多的网站| 欧美.日韩.国产.一区.二区| 亚洲男人的天堂在线| 亚洲国产精品一区制服丝袜| 久久成人久久爱| 亚洲无线一线二线三线区别av| 黄色一区三区| 国产精品一区二区三区四区五区| 免费久久久一本精品久久区| 亚洲综合色视频| 99热在线精品观看| 亚洲国产高清在线| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲午夜电影| 亚洲乱码久久| 亚洲国产欧美一区二区三区同亚洲| 国产精品视频区| 欧美性片在线观看| 欧美日韩在线三区| 欧美日韩不卡视频| 欧美大色视频|