自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

詳細(xì)解說(shuō)C++中函數(shù)指針數(shù)組的妙用

開發(fā) 后端
本文介紹的是C++中函數(shù)指針數(shù)組的使用,希望對(duì)你有幫助,一起來(lái)看。

筆者在開發(fā)某軟件過(guò)程中遇到這樣一個(gè)問(wèn)題,前級(jí)模塊傳給我二進(jìn)制數(shù)據(jù),輸入?yún)?shù)為 char* buffer和 int length,buffer是數(shù)據(jù)的首地址,length表示這批數(shù)據(jù)的長(zhǎng)度。數(shù)據(jù)的特點(diǎn)是:長(zhǎng)度不定,類型不定,由第一個(gè)字節(jié)(buffer[0])標(biāo)識(shí)該數(shù)據(jù)的類型,共有256(28 )種可能性。我的任務(wù)是必須對(duì)每一種可能出現(xiàn)的數(shù)據(jù)類型都要作處理,并且我的模塊包含若干個(gè)函數(shù),在每個(gè)函數(shù)里面都要作類似的處理。若按通常做法,會(huì)寫出如下代碼:

  1. void MyFuntion( char* buffer, int length )  
  2. {  
  3. __int8 nStreamType = buffer[0];  
  4. switch( nStreamType )  
  5. {  
  6. case 0:  
  7. function1();  
  8. break;  
  9. case 1:  
  10. ......  
  11. case 255:  
  12. function255();  
  13. break;  
  14. }  

如果按照這種方法寫下去,那么在我的每一個(gè)函數(shù)里面,都必須作如此多的判斷,寫出的代碼肯定很長(zhǎng),并且每一次處理,都要作許多次判斷之后才找到正確的處理函數(shù),代碼的執(zhí)行效率也不高。針對(duì)上述問(wèn)題,我想到了用函數(shù)指針數(shù)組的方法解決這個(gè)問(wèn)題。

函數(shù)指針的概念,在潭浩強(qiáng)先生的C語(yǔ)言程序設(shè)計(jì)這本經(jīng)典的教程中提及過(guò),在大多數(shù)情況下我們使用不到,也忽略了它的存在。函數(shù)名實(shí)際上也是一種指針,指向函數(shù)的入口地址,但它又不同于普通的如int*、double*指針,看下面的例子來(lái)理解函數(shù)指針的概念:

  1. int funtion( int x, int y );  
  2. void main ( void )   
  3.  {  
  4.  int (*fun) ( int x, int y );  
  5.  int a = 10, b = 20;  
  6.  function( a, b );  
  7.  fun = function;  
  8. ?。?fun)( a, b );  
  9. ……  

語(yǔ)句1定義了一個(gè)函數(shù)function,其輸入為兩個(gè)整型數(shù),返回也為一個(gè)整型數(shù)(輸入?yún)?shù)和返回值可為其它任何數(shù)據(jù)類型);語(yǔ)句3定義了一個(gè)函數(shù)指針,與int*或double*定義指針不同的是,函數(shù)指針的定義必須同時(shí)指出輸入?yún)?shù),表明這是一個(gè)函數(shù)指針,并且*fun也必須用一對(duì)括號(hào)括起來(lái);語(yǔ)句6將函數(shù)指針賦值為funtion,前提條件是*fun和function的輸入?yún)?shù)和返回值必須保持一致。語(yǔ)句5直接調(diào)用函數(shù)function(),語(yǔ)句7是調(diào)用函數(shù)指針,二者等效。

當(dāng)然從上述例子看不出函數(shù)指針的優(yōu)點(diǎn),目的主要是想引出函數(shù)指針數(shù)組的概念。我們從上面例子可以得知,既然函數(shù)名可以通過(guò)函數(shù)指針加以保存,那們也一定能定義一個(gè)數(shù)組保存若干個(gè)函數(shù)名,這就是函數(shù)指針數(shù)組。正確使用函數(shù)指針數(shù)組的前提條件是,這若干個(gè)需要通過(guò)函數(shù)指針數(shù)組保存的函數(shù)必須有相同的輸入、輸出值。

這樣,我工作中所面臨的問(wèn)題可以解決如下:

首先定義256個(gè)處理函數(shù)(及其實(shí)現(xiàn))。

  1. void funtion0( void );  
  2. ……..  
  3. void funtion255(void ); 

其次定義函數(shù)指針數(shù)組,并給數(shù)組賦值。

  1. void (*fun[256])(void);  
  2.  
  3. fun[0] = function0;  
  4. …….  
  5. fun[255] = function(); 

最后,MyFunction()函數(shù)可以修改如下:

  1. void MyFuntion( char* buffer, int length )  
  2. {  
  3. __int8 nStreamType = buffer[0];  
  4. (*fun[nStreamType])();  

只要2行代碼,就完成了256條case語(yǔ)句要做的事,減少了編寫代碼時(shí)工作量,將nStreamType作為數(shù)組下標(biāo),直接調(diào)用函數(shù)指針,從代碼執(zhí)行效率上來(lái)說(shuō),也比case語(yǔ)句高。假如多個(gè)函數(shù)中均要作如此處理,函數(shù)指針數(shù)組更能體現(xiàn)出它的優(yōu)勢(shì)。

希望通過(guò)本文的介紹,能夠給你帶來(lái)幫助。

責(zé)任編輯:于鐵 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2015-05-13 10:37:58

C++指針與引用

2010-02-02 15:01:59

C++成員函數(shù)指針

2010-01-19 13:43:59

C++函數(shù)

2011-07-20 18:03:54

CC++

2024-03-28 18:12:28

指針函數(shù)指針C++

2011-04-11 11:09:50

this指針

2011-07-15 01:20:58

C指針函數(shù)函數(shù)指針

2009-07-31 15:10:21

C#函數(shù)指針數(shù)組C#數(shù)組

2011-07-20 16:43:34

C++

2023-11-27 19:35:01

C++extern

2011-07-20 17:16:50

C++重載函數(shù)

2009-09-27 11:14:09

C#數(shù)組

2011-07-14 17:17:21

C++指針

2011-07-14 17:02:09

C++指針

2024-02-23 18:04:37

C++const關(guān)鍵字

2011-04-19 16:38:00

對(duì)象指針指針C++

2011-04-19 09:19:09

C++指針

2010-01-20 10:19:55

C++數(shù)組

2010-01-28 11:08:09

C++變量

2023-11-22 13:22:51

C++函數(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)