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

            JACKY_ZZ[貓貓愛吃魚]

            春風拂面兩頰紅,秋葉灑地一片金。 夏荷搖曳一身輕,冬雪覆蓋大地銀。
            posts - 30, comments - 123, trackbacks - 0, articles - 0

            [C/C++] union再探

            Posted on 2007-08-07 16:45 jacky_zz 閱讀(392) 評論(2)  編輯 收藏 引用 所屬分類: C/C++
            這里將再次對UNION進行一些小小的探究,思路來源于MFC中消息函數(shù)執(zhí)行過程中的一些疑問。union初探初步闡述了union與struct的一些區(qū)別,以及相應的使用方法,這里將以此為基礎,以類的方式進一步對union的運用方法進行一點說明。首先在項目中聲明一個超類(父類)CClassBase和一個子類CClassA,代碼如下:
             1 class CClassBase {
             2 public:
             3     CClassBase(void);
             4     ~CClassBase(void);
             5 };
             6 
             7 class CClassA : public CClassBase {
             8 public:
             9     CClassA(void);
            10     ~CClassA(void);
            11 
            12     void Func01(void);
            13     int Func02(int);
            14     int Func03(intint);
            15     void Func04(intint*);
            16 };
            類CClassBase和類CClassA的實現(xiàn)代碼如下:
             1 CClassBase::CClassBase(void) {
             2 }
             3 
             4 CClassBase::~CClassBase(void) {
             5 }
             6 
             7 CClassA::CClassA(void) {
             8 }
             9 
            10 CClassA::~CClassA(void) {
            11 }
            12 
            13 void CClassA::Func01(void) {
            14     printf("call Func01\n");
            15 }
            16 
            17 int CClassA::Func02(int param) {
            18     printf("call Func02, parameter:%d\n", param);
            19     return param;
            20 }
            21 
            22 int CClassA::Func03(int param1, int param2) {
            23     printf("call Func03, parameter:%d, %d\n", param1, param2);
            24     return param1 + param2;
            25 }
            26 
            27 void CClassA::Func04(int inParam, int* outParam) {
            28     printf("call Func04, parameter:%d\n", inParam);
            29     *outParam = inParam * inParam;
            30 }
            如何將類中的方法或函數(shù)能通過一個全局函數(shù)進行調用呢?這里可以選用union來實現(xiàn),首先需要定義一個能表示某個函數(shù)的函數(shù)類型,這里使用了一個enum來實現(xiàn),代碼如下:
            1 enum FUNC_TYPE {
            2     TYPE_VOID_VOID = 0,
            3     TYPE_INT_INT,
            4     TYPE_INT_INT_INT,
            5     TYPE_VOID_INT_PINT
            6 };
            其中TYPE_VOID_VOID代表返回值為void,參數(shù)為void;TYPE_INT_INT代表返回值為int,參數(shù)為int; TYPE_INT_INT_INT代表返回值為int,參數(shù)兩個,類型都是int;TYPE_VOID_INT_INT代表返回值為void,參數(shù)兩個,一個是int,另一個是int*。
            定義完函數(shù)類型后,還需要定義一個通用的函數(shù)指針,用于指向任意一個成員函數(shù),定義如下:
            typedef void (CClassBase::*PFUNC)(void);
            定義完函數(shù)類型和通用的函數(shù)指針后,就可以定義需要使用到的union了,代碼如下:
            1 union UNION_FUNC {
            2     PFUNC pFunc;
            3 
            4     void (CClassBase::*pFunc_v_v)(void);
            5     int (CClassBase::*pFunc_i_i)(int);
            6     int (CClassBase::*pFunc_i_i_i)(intint);
            7     void (CClassBase::*pFunc_i_pi)(intint*);
            8 };
            有了定義好的union,就可以定義一個全局函數(shù)調用指定類的實例的成員函數(shù)了,定義如下:
            1 int CallFunc(CClassBase* pTarget, enum FUNC_TYPE func_type, PFUNC pFunc);
            全局函數(shù)的實現(xiàn)代碼如下:
             1 int CallFunc(CClassBase* pTarget, enum FUNC_TYPE func_type, PFUNC pFunc) {
             2     if(pTarget == NULL) return 0;
             3     if(pFunc == NULL) return 0;
             4 
             5     union UNION_FUNC _FUNC_;
             6     _FUNC_.pFunc = pFunc;
             7     int result;
             8 
             9     switch(func_type) {
            10         case TYPE_VOID_VOID:
            11             (pTarget->*_FUNC_.pFunc_v_v)();
            12             result = 1;
            13             break;
            14         case TYPE_INT_INT:
            15             result = (pTarget->*_FUNC_.pFunc_i_i)(10);
            16             break;
            17         case TYPE_INT_INT_INT:
            18             result = (pTarget->*_FUNC_.pFunc_i_i_i)(10,20);
            19             break;
            20         case TYPE_VOID_INT_PINT:
            21             (pTarget->*_FUNC_.pFunc_i_pi)(10&result);
            22             break;
            23         default:
            24             return 0;
            25     }
            26 
            27     return result;
            28 }
            這里需要說明一下的是,PFUNC需要在作用域CClassBase::下方可調用CClassBase及其子類的成員方法,如果沒有 CClassBase::的修飾,系統(tǒng)將認為是一個非法的函數(shù)調用,編譯時將發(fā)生錯誤。這也就是為什么要在真正的函數(shù)調用時加上CClassBase:: 或this->的修飾了,而函數(shù)前的*是解引用。通過以上的聲明和實現(xiàn),就可以進行測試運行了,代碼如下:
            1 int main(int argc, char* argv[])
            2 {
            3     system("cls");
            4 
            5     CClassA classA;
            6     int result = CallFunc(&classA, TYPE_INT_INT_INT, (PFUNC)(static_cast< int (CClassBase::*)(intint>(CClassA::Func03)));
            7     return 0;
            8 }

            Feedback

            # re: union再探[未登錄]  回復  更多評論   

            2009-07-12 21:34 by Michael
            Main 函數(shù)中6 line 要寫成&CClassA::Func03

            # re: union再探  回復  更多評論   

            2009-07-13 11:30 by jacky_zz
            可以不加&符號的,可能在VC6里需要加。
            99久久久精品免费观看国产| 国内精品久久久久影院亚洲| 久久99精品国产自在现线小黄鸭 | 国产精品99久久久久久宅男小说| 国产精品乱码久久久久久软件 | 人妻久久久一区二区三区| 久久久精品国产sm调教网站| 91久久九九无码成人网站 | 精品久久国产一区二区三区香蕉| 久久噜噜久久久精品66| 久久久无码精品亚洲日韩蜜臀浪潮| 久久精品一区二区三区不卡| 午夜视频久久久久一区| 激情伊人五月天久久综合| 色播久久人人爽人人爽人人片aV| 97久久精品人妻人人搡人人玩| 无码精品久久一区二区三区| 国产午夜精品久久久久免费视 | 香蕉久久夜色精品升级完成| 久久久久亚洲爆乳少妇无| 91精品国产综合久久婷婷| 狠狠色丁香久久婷婷综合图片| 久久亚洲国产午夜精品理论片| 亚洲精品无码久久久影院相关影片| 久久99热这里只有精品国产| 精品一区二区久久久久久久网站| 亚洲精品乱码久久久久久| 久久笫一福利免费导航 | 日批日出水久久亚洲精品tv| 国产精品女同一区二区久久| 久久综合久久久| 日韩精品国产自在久久现线拍| 国产亚洲婷婷香蕉久久精品| 7777久久亚洲中文字幕| 狠狠色噜噜色狠狠狠综合久久 | 国产精品欧美久久久天天影视 | 日本道色综合久久影院| 国产精品久久永久免费| 久久精品男人影院| 超级碰久久免费公开视频| 国产精品成人99久久久久 |