筆者在開發某軟體過程中遇到這樣乙個問題,前級模組傳給我二進位制資料,輸入引數為 char* buffer和 int length,buffer是資料的首位址,length表示這批資料的長度。資料的特點是:長度不定,型別不定,由第乙個位元組(buffer[0])標識該資料的型別,共有256(28 )種可能性。我的任務是必須對每一種可能出現的資料型別都要作處理,並且我的模組包含若干個函式,在每個函式裡面都要作類似的處理。若按通常做法,會寫出如下**:
void myfuntion( char* buffer, int length )}
如果按照這種方法寫下去,那麼在我的每乙個函式裡面,都必須作如此多的判斷,寫出的**肯定很長,並且每一次處理,都要作許多次判斷之後才找到正確的處理函式,**的執行效率也不高。針對上述問題,我想到了用函式指標陣列的方法解決這個問題。
函式指標的概念,在潭浩強先生的c語言程式設計這本經典的教程中提及過,在大多數情況下我們使用不到,也忽略了它的存在。函式名實際上也是一種指標,指向函式的入口位址,但它又不同於普通的如int*、double*指標,看下面的例子來理解函式指標的概念:
int funtion( int x, int y );
void main ( void )
語句1定義了乙個函式function,其輸入為兩個整型數,返回也為乙個整型數(輸入引數和返回值可為其它任何資料型別);語句3定義了乙個函式指標,與int*或double*定義指標不同的是,函式指標的定義必須同時指出輸入引數,表明這是乙個函式指標,並且*fun也必須用一對括號括起來;語句6將函式指標賦值為funtion,前提條件是*fun和function的輸入引數和返回值必須保持一致。語句5直接呼叫函式function(),語句7是呼叫函式指標,二者等效。
當然從上述例子看不出函式指標的優點,目的主要是想引出函式指標陣列的概念。我們從上面例子可以得知,既然函式名可以通過函式指標加以儲存,那們也一定能定義乙個陣列儲存若干個函式名,這就是函式指標陣列。正確使用函式指標陣列的前提條件是,這若干個需要通過函式指標陣列儲存的函式必須有相同的輸入、輸出值。
這樣,我工作中所面臨的問題可以解決如下:
首先定義256個處理函式(及其實現)。
void funtion0( void );
……..
void funtion255(void );
其次定義函式指標陣列,並給陣列賦值。
void (*fun[256])(void);
fun[0] = function0;
…….fun[255] = function();
最後,myfunction()函式可以修改如下:
void myfuntion( char* buffer, int length )
只要2行**,就完成了256條case語句要做的事,減少了編寫**時工作量,將nstreamtype作為陣列下標,直接呼叫函式指標,從**執行效率上來說,也比case語句高。假如多個函式中均要作如此處理,函式指標陣列更能體現出它的優勢。
原文:
指標陣列 陣列指標 函式指標 函式指標陣列
陣列指標 指向陣列的指標,是乙個指標,其指向的型別是陣列 指標陣列 元素為指標的陣列,是乙個陣列,其中的元素為指標。例如 int a 5 這個是陣列指標。int a 5 這個是指標陣列。定義函式指標型別 int max int,int typedef int fun ptr int,int 申明變數...
指標陣列,陣列指標,指標函式,函式指標
int p 4 指標陣列。是個有4個元素的陣列,每個元素的是指向整型的指標。int p 4 陣列指標。它是乙個指標,指向有4個整型元素的陣列。int func void 指標函式。無參函式,返回整型指標。int func void 表示函式指標,可以指向無參,且返回值為整型指標的函式。右左規則 因為...
陣列指標,指標陣列,函式指標,指標函式
陣列指標,指標陣列,函式指標,指標函式 指標 變數,存放變數的位址。例 int ptr,ptr是乙個指向整形變數的指標 陣列 例 int a 10 定義了乙個具有10個元素的一維陣列,其中陣列的每個元素是乙個int型別。陣列指標 陣列首元素位址的指標,即是指向陣列的指標。例 int ptr 10 c...