考試大編輯整理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 ……
}
在開發(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 ……
}