C++中函數(shù)指針數(shù)組的使用

字號(hào):

考試大編輯整理C++編程知識(shí)
    在開發(fā)某軟件過程中遇到這樣一個(gè)問題,前級(jí)模塊傳給我二進(jìn)制數(shù)據(jù),輸入?yún)?shù)為 char* buffer和 int length,buffer是數(shù)據(jù)的首地址,length表示這批數(shù)據(jù)的長度。數(shù)據(jù)的特點(diǎn)是:長度不定,類型不定,由第一個(gè)字節(jié)(buffer[0])標(biāo)識(shí)該數(shù)據(jù)的類型,共有256(28 )種可能性。
    我的任務(wù)是必須對(duì)每一種可能出現(xiàn)的數(shù)據(jù)類型都要作處理,并且我的模塊包含若干個(gè)函數(shù),在每個(gè)函數(shù)里面都要作類似的處理。若按通常做法,會(huì)寫出如下代碼:
    void MyFuntion( char* buffer, int length )
    {__int8 nStreamType = buffer[0];
    switch( nStreamType )
    {case 0:
    function1();
    break;
    case 1:
    ......
    case 255:
    function255();
    break;
    }
    如果按照這種方法寫下去,那么在我的每一個(gè)函數(shù)里面,都必須作如此多的判斷,寫出的代碼肯定很長,并且每一次處理,都要作許多次判斷之后才找到正確的處理函數(shù),代碼的執(zhí)行效率也不高。針對(duì)上述問題,我想到了用函數(shù)指針數(shù)組的方法解決這個(gè)問題。
    函數(shù)指針的概念,在潭浩強(qiáng)先生的C語言程序設(shè)計(jì)這本經(jīng)典的教程中提及過,在大多數(shù)情況下我們使用不到,也忽略了它的存在。函數(shù)名實(shí)際上也是一種指針,指向函數(shù)的入口地址,但它又不同于普通的如int*、double*指針,看下面的例子來理解函數(shù)指針的概念:
    1 int funtion( int x, int y );
    2 void main ( void )
    {
    3  int (*fun) ( int x, int y );
    4  int a = 10, b = 20;
    5  function( a, b );
    6  fun = function;
    7 ?。?fun)( a, b );
    8 ……
    }