• <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>

            visualfc

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              42 隨筆 :: 0 文章 :: 119 評論 :: 0 Trackbacks
                本文編寫 visualfc

                寫一個invoke函數(shù)以支持任意參數(shù)調(diào)用,實現(xiàn)類似以下的功能代碼。注:本代碼純屬試驗。
            1. class a
            2. {
            3.    void func1(int,int);
            4.    void func2(char*,int);
            5. };

            6. void invoke(a*,char * method,...);

            7. void test()
            8. {
            9.    a a1,
            10.    invoke(&a1,"func1",10,20);
            11.    invoke(&a2,"func2","ok",0);
            12. }
                我目前試驗了三種方式,第一種是模板方式實現(xiàn),第二種是基于可變參數(shù)(...)實現(xiàn),第三種是使用類似boost::any的方式來實現(xiàn)。比較三種方式, 模板方式實現(xiàn)起來尤其不易,但是能夠做參數(shù)檢查,問題在于只能存在在頭文件中。 第二種為可變參數(shù)方式, 本文給出了這種方式的試驗代碼,實現(xiàn)起來也比較簡單,問題是無法驗證參數(shù)。第三種方式為以類似any的方式來實現(xiàn),但是實現(xiàn)效率則相對較低。
                下面給出了第二種方式,即使用可變參數(shù)調(diào)用的實現(xiàn),沒有使用va_list和va_arg,這是因為函數(shù)調(diào)用棧順序的原因,我使用了自定義的get_arg_back函數(shù)來獲取可變參數(shù)。

            1. template <typename T>
            2. T get_arg_back(char ** parg)
            3. {
            4.     *parg -= sizeof(T);
            5.     T t = *((T*)*parg);
            6.     return t;
            7. }
            8. template <typename R, typename CLS, typename T1, typename T2>
            9. R invoke_cls(CLS * pcls, R (CLS::*ptr)(T1,T2), char ** parg)
            10. {
            11.     char * end = *parg+sizeof(T1)+sizeof(T2);
            12.     return (pcls->*ptr)(get_arg_back<T1>(&end),get_arg_back<T2>(&end));
            13. }

            14. class a
            15. {
            16. public:
            17.     int test(char * buf, int i)
            18.     {
            19.         printf ("test %s %d\n",buf,i);
            20.         return 0;
            21.     }
            22.     int test2(int i, char * buf)
            23.     {
            24.         printf ("test2 %s %d\n",buf,i);
            25.         return 100;
            26.     }
            27. };
            28. void invoke(void * ptr, char * method,...)
            29. {
            30.     char * parg = (char*)&method+sizeof(method);
            31.     if (method == "test")
            32.         invoke_cls((a*)ptr,&a::test,&parg);
            33.     else if (method == "test2")
            34.         invoke_cls((a*)ptr,&a::test2,&parg);
            35.     parg = NULL;
            36. }
            37. int main(int argc, char* argv[])
            38. {
            39.     a a1;
            40.     invoke(&a1,"test","ok",1);
            41.     invoke(&a1,"test2",1,"ok");
            42.     return 0;
            43. }


            posted on 2008-10-11 16:37 visualfc 閱讀(1638) 評論(1)  編輯 收藏 引用 所屬分類: C++

            評論

            # re: 關于可變參數(shù)函數(shù)調(diào)用 2008-10-11 18:14 陳梓瀚(vczh)
            boost的Functor的代碼展開之后,如果你要求產(chǎn)生最多20個參數(shù)的函數(shù)對象的話,那么他就將有20個互相之間沒有關系的類。

            第二種做法是,將參數(shù)聲明寫進宏,雖然要重復一次數(shù)據(jù),但是只需要一個類就可以了。

            第三種做法,目前沒有。  回復  更多評論
              

            AV狠狠色丁香婷婷综合久久| 久久久久久亚洲AV无码专区| 成人a毛片久久免费播放| 久久99中文字幕久久| 999久久久国产精品| 国产精品久久久久久福利漫画| 国产精品九九九久久九九| 91精品国产综合久久四虎久久无码一级| 精品久久久久久亚洲精品| 色综合久久综精品| 亚洲国产高清精品线久久 | 久久综合88熟人妻| 色综合合久久天天综合绕视看 | 国内精品九九久久久精品| 国产精品久久久天天影视| 久久久久久久综合综合狠狠| 一本色道久久HEZYO无码| 国产精品一久久香蕉国产线看观看| 9999国产精品欧美久久久久久| 2021国内精品久久久久久影院| 久久久久久国产精品无码超碰| 久久精品一区二区三区中文字幕| 亚洲精品无码成人片久久| 精品水蜜桃久久久久久久| 1000部精品久久久久久久久| 亚洲国产成人久久一区久久| 久久99热国产这有精品| 97精品依人久久久大香线蕉97| 久久91精品国产91久久麻豆| 精品久久久久久中文字幕大豆网| 久久久久中文字幕| 久久香蕉国产线看观看精品yw| 久久久久久久国产免费看| 久久久久久狠狠丁香| 日韩精品无码久久久久久| 一级做a爰片久久毛片看看| 精品久久香蕉国产线看观看亚洲| 伊人久久大香线蕉精品不卡| 精品久久久久久久久久久久久久久| 99国产精品久久| 国产精品福利一区二区久久|