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

huaxiazhihuo

 

c++單元測試框架關(guān)鍵點記錄成員函數(shù)地址

原則上,C++下最好的單元測試代碼應該長成這樣子,用起來才是最方便的
TEST_CLASS(className)
{
    
// 變量
    TEST_METHOD(fn1)
    {
        
// 
    }    
    TEST_METHOD(fn1)
    {
        
// 
    }
    
//
}
vczh大神的測試代碼是這樣子,這是最方便使用的形式,但因為是以測試方法為粒度,大括號里面就是一個函數(shù)體,所以顯得功能上有些不足。
TEST_CASE(ThisIsATestCase)
{
TEST_ASSERT(1+1==2);
}
      當然,這里隱藏了很多宏的丑陋實現(xiàn),但是,那又有什么要緊呢。好不好并不是在于用了什么東西,goto,多繼承,宏,隱式類型轉(zhuǎn)換,……,這些,如果能夠顯著地減少重復性相似性代碼,還能帶來類型安全,然后又其潛在的問題又在可控的范圍之內(nèi),那么,又有什么理由拒絕呢。老朽一向認為,語言提供的語法糖功能要多多益善,越多越好,當然,必須像C++那樣,不用它們的時候,就不會帶來任何代價,那怕是一點點,就好像它們不存在,并且它們最好能正交互補。但是,你看看,cppunit,gtest的測試代碼又是什么貨色呢。
      據(jù)說cppunit里面用了很多模式,其架構(gòu)什么的非常巧妙。反正使用起來這么麻煩,要做的重復事情太多了,這里寫測試函數(shù),那里注冊測試函數(shù),只能表示,慢走不送。gtest據(jù)說其架構(gòu)也大有講究,值得學習,用起來,也比cppunit方便,但是,看看TEST_F,什么SetUp,TearDown,各種鬼麻煩,誰用誰知道。一句話,我們其實只需要class粒度的測試代碼,其他的一切問題就都是小case了。
      當然,class粒度的單元測試實現(xiàn)的難點在于收集要測試的成員函數(shù)。這里不能用虛函數(shù)。必須類似于mfc里面的消息映射成員函數(shù)表。也即是當寫下TEST_METHOD(fn1),宏TEST_METHOD就要記錄下來fn1的函數(shù)指針。后面跟著的一對大括號體是fn1的函數(shù)體,已經(jīng)越出宏的控制范圍了,所以只能在前面大做文章。下面是解決這個問題的思路。這個問題在C++03之前的版本,比較棘手。但是,所幸,C++11帶來很多逆天的新功能,這個問題做起來就沒那么難了。下面的思路省略其他各種次要的細節(jié)問題。
首先,我們定義一個空類和要測試的成員函數(shù)的形式。
struct EmptyClass{};
typedef void(EmptyClass::*TestMethodPtr)();
還有存放成員函數(shù)地址的鏈表節(jié)點
struct MethodNode
{
    MethodNode(MethodNode
*& head, TestMethodPtr method)
    {
        mNext 
= head;
        head 
= this;
        mMethod 
= method;
    }
    MethodNode
* mNext;
    TestMethodPtr mMethod;
};
還有提取成員函數(shù)地址的函數(shù)

template 
<class OutputClass, class InputClass>
union horrible_union{
    OutputClass 
out;
    InputClass 
in;
};

template 
<class OutputClass, class InputClass>
inline 
void union_cast(OutputClass& outconst InputClass input){
    horrible_union
<OutputClass, InputClass> u;
    static_assert(
sizeof(InputClass) == sizeof(u) && sizeof(InputClass) == sizeof(OutputClass), "out and in should be the same size");
    u.
in = input;
    
out = u.out;
}
template
<typename Ty>
TestMethodPtr GetTestMethod(
void(Ty::*testMethod)())
{
    TestMethodPtr methodPtr;
    union_cast(methodPtr, testMethod);
    
return methodPtr;
}
方法是每定義一個測試函數(shù),在其上面就先定義一個鏈表節(jié)點變量,其構(gòu)造函數(shù)記錄測試函數(shù)地址,并把自身加入到鏈表中。但是,在此之前,我們將遭遇到編譯器的抵觸。比如
struct TestCase
{
    typedef TestCase ThisType;
    MethodNode
* mMethods = nullptr;

    TestMethodPtr mTestMethodfn1 
= GetTestMethod(&fn1);
    void fn1(){}
};
      vc下面,編譯器報錯 error C2276: “&”: 綁定成員函數(shù)表達式上的非法操作
      原來在就地初始化的時候,不能以這種方式獲取到地址。然后,試試在TestCase里面的其他函數(shù)中,包括靜態(tài)函數(shù),就可以將取地址符號用到成員函數(shù)前面。
      這好像分明是編譯器在故意刁難,不過,任何代碼上的問題都可以通過引入中間層來予以解決。用內(nèi)部類。
struct TestCase
{
    typedef TestCase ThisType;
    MethodNode
* mMethods = nullptr;

   
struct Innerfn1 : public MethodNode
    {
        Innerfn1(ThisType
* pThis) : MethodNode(pThis->mMethods, GetTestMethod(&ThisType::fn1))
        {
        }
    } mTestMethodfn1 
= this;
    
void fn1(){}

    
struct Innerfn2 : public MethodNode
    {
        Innerfn2(ThisType
* pThis) : MethodNode(pThis->mMethods, GetTestMethod(&ThisType::fn2))
        {
        }
    } mTestMethodfn2 
= this;
    
void fn2(){}
};
      有多少個測試方法,就動用多少種內(nèi)部類。然后,一旦定義一個測試類的變量,那么這些內(nèi)部類的構(gòu)造函數(shù)就執(zhí)行了,把測試方法串聯(lián)在一塊,逆序,也就是說最后定義測試方法反而跑到前面去了。這樣子就自動記錄下來所有的測試方法的地址。有了這些函數(shù)地址信息,后面怎么玩都可以。包括漂亮的測試結(jié)果顯示,日志記錄,甚至嵌入到vs的單元測試界面中,又或者是生成配置文件,各種花招,怎么方便就怎么玩。這個時候,可以拿來主義,把cppunit,gtest等的優(yōu)點都吸收過來。
      是否覺得這還不夠,好像有很多事情要做。比如說,測試方法逆序了,在同一個測試類的變量上執(zhí)行這些測試方法,會不會就擾亂類的內(nèi)部信息了,每次new一個測試類,所有的測試方法都要重復記錄,內(nèi)部類變量要占內(nèi)存……。咳咳,這些都可以一一解決。這里只是用最簡明的方式展示自動記錄測試方法,產(chǎn)品級的寫法肯定大有講究了。
      可以看到上面的代碼都是有意做成很相似的,這些都是準備給宏大展身手的。這些低級宏太容易編寫了,任何經(jīng)歷mfc或者boost代碼折磨的猿猴,都完全能夠勝任,這就打住了。對了,這里的自動記錄成員函數(shù)的宏手法,可以大量地使用到其他地方,比如說,自動生成消息映射表,比mfc的那一套要好一百倍,應用范圍太廣了。當初老朽以為就只能用于單元測試框架的編寫上面,想不到其威力如此巨大,消息系統(tǒng)全靠它了。C++的每一項奇技淫巧和功能被發(fā)現(xiàn)后,其價值都難以估量,好像bs所說的,他老人家不會給c++增添一項特性,其應用范圍一早就可以預料的。對付一個問題,C++有一百種解決方案,當然里面只有幾種才最貼切問題領(lǐng)域,但是很多時候,我們往往只選擇或者尋找到另外的那90多種,最后注定要悲劇。

posted on 2016-05-11 18:01 華夏之火 閱讀(1558) 評論(0)  編輯 收藏 引用 所屬分類: c++技術(shù)探討

導航

統(tǒng)計

常用鏈接

留言簿(6)

隨筆分類

隨筆檔案

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            宅男噜噜噜66国产日韩在线观看| 久久九九国产| 亚洲国产高清高潮精品美女| 久久久久国产精品一区| 在线欧美不卡| 亚洲国产专区校园欧美| 欧美激情精品久久久六区热门 | 国产精品爱啪在线线免费观看| 国产视频在线观看一区| 午夜综合激情| 欧美影视一区| 亚洲电影在线播放| 欧美激情在线有限公司| 欧美日韩在线不卡一区| 欧美在线精品免播放器视频| 久久精品中文字幕一区| 亚洲精品一区二区三区av| 亚洲午夜在线观看视频在线| 国产一区二区三区网站| 亚洲国产另类 国产精品国产免费| 欧美日韩另类综合| 久久久亚洲综合| 欧美韩日一区| 欧美中文字幕在线观看| 欧美成年人视频网站| 午夜亚洲影视| 美日韩精品视频免费看| 亚洲欧美久久久久一区二区三区| 久久久久久久久伊人| 一区二区三区久久| 久久久久久夜| 亚洲欧美日韩精品久久奇米色影视| 午夜精品久久久久| 亚洲精品资源| 久久激情视频久久| 一本综合精品| 久久久久久亚洲精品中文字幕| 国产精品99久久久久久久久| 久久久国际精品| 午夜一区二区三区不卡视频| 美女国产一区| 久久久综合网| 国产精品乱子乱xxxx| 蜜桃精品久久久久久久免费影院| 国产精品久久久久av免费| 亚洲国产精品久久久久| 激情视频一区二区| 亚洲一区在线看| 亚洲五月婷婷| 欧美片在线播放| 久久阴道视频| 国产日韩久久| 亚洲永久免费视频| 国产精品99久久久久久久女警 | 久久福利一区| 国产精品红桃| 艳女tv在线观看国产一区| 最近中文字幕日韩精品 | 中文精品视频| 日韩一区二区高清| 蜜桃av噜噜一区| 欧美成人a∨高清免费观看| 国产一区日韩二区欧美三区| 欧美一级久久久久久久大片| 欧美一区二区三区四区视频| 国产精品美女999| 一区二区三区国产精华| 亚洲特黄一级片| 欧美三区免费完整视频在线观看| 日韩午夜在线视频| 亚洲久久一区二区| 国产精品乱码久久久久久| 99在线|亚洲一区二区| 日韩一级黄色片| 欧美日韩一区在线观看| 中文在线资源观看视频网站免费不卡| 亚洲手机成人高清视频| 国产精品美女久久久浪潮软件| 亚洲午夜性刺激影院| 性刺激综合网| 国内精品久久久久久久果冻传媒 | 亚洲高清av| 一区二区久久久久久| 欧美午夜国产| 午夜欧美电影在线观看| 麻豆精品视频在线| 日韩一区二区电影网| 国产精品家教| 欧美主播一区二区三区美女 久久精品人| 久久精品国产精品亚洲综合| 亚洲国产成人一区| 欧美日韩亚洲国产精品| 午夜国产一区| 亚洲国产欧美精品| 亚洲欧美综合网| 在线观看成人小视频| 欧美日韩三级在线| 欧美一区免费| 亚洲精品久久久久久下一站| 欧美一区二区成人| 亚洲日本乱码在线观看| 国产精品国产精品| 老鸭窝91久久精品色噜噜导演| 亚洲美女在线观看| 久久人人97超碰精品888| 亚洲开发第一视频在线播放| 国产欧美婷婷中文| 美女成人午夜| 性欧美18~19sex高清播放| 亚洲激情第一区| 欧美在线地址| 一区二区三区你懂的| 一区二区三区在线高清| 国产精品免费观看在线| 欧美xxxx在线观看| 久久av最新网址| 亚洲午夜三级在线| 亚洲日本欧美日韩高观看| 理论片一区二区在线| 亚洲欧美激情精品一区二区| 99re热这里只有精品免费视频| 国产一区二区剧情av在线| 欧美日韩一级黄| 男同欧美伦乱| 久久琪琪电影院| 午夜精品一区二区三区在线视 | 欧美国产免费| 久久蜜桃精品| 欧美一区2区三区4区公司二百| 亚洲网站在线播放| 亚洲毛片在线免费观看| 亚洲国产免费| 亚洲风情亚aⅴ在线发布| 国产亚洲欧美日韩日本| 国产精品理论片| 国产精品国产三级国产普通话99| 欧美日本精品在线| 欧美风情在线| 欧美国产精品| 欧美国产国产综合| 奶水喷射视频一区| 亚洲国产美女| 欧美伊久线香蕉线新在线| 亚洲欧美另类中文字幕| 亚洲一区二区三区午夜| 在线中文字幕日韩| 亚洲一区二区三区精品在线| 亚洲午夜视频| 午夜精品视频在线| 欧美在线视频全部完| 久久精品国产欧美亚洲人人爽| 香蕉久久夜色精品国产使用方法| 亚洲欧美成aⅴ人在线观看| 亚洲欧美日韩成人| 久久国产精品色婷婷| 久久精品国产99精品国产亚洲性色| 久久精品导航| 毛片精品免费在线观看| 亚洲国产裸拍裸体视频在线观看乱了 | 免费观看亚洲视频大全| 欧美高清视频一二三区| 欧美喷水视频| 国产精品羞羞答答xxdd| 国精品一区二区三区| 亚洲国产精品久久| 中文精品99久久国产香蕉| 亚洲欧洲99久久| 久久久九九九九| 亚洲盗摄视频| 亚洲午夜精品| 久久久久久久91| 欧美男人的天堂| 国产区日韩欧美| 亚洲国产三级| 亚洲欧美激情在线视频| 另类亚洲自拍| 夜夜嗨av一区二区三区四季av | 欧美国产1区2区| 亚洲天堂成人在线视频| 久久久久久久999精品视频| 欧美精品一区二区三区四区| 国产女主播在线一区二区| 亚洲国产一区二区三区高清| 午夜精品理论片| 欧美成人一区二区三区| 亚洲性视频h| 美女视频黄a大片欧美| 国产毛片精品国产一区二区三区| 最新高清无码专区| 久久riav二区三区| 日韩图片一区| 免费欧美在线| 国产一区欧美| 亚洲欧美综合国产精品一区| 欧美激情久久久| 欧美怡红院视频| 国产精品播放| 亚洲精品一线二线三线无人区| 久久精品国产77777蜜臀| 99视频精品|