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

C++函數(shù)指針相關(guān)內(nèi)容介紹

開發(fā) 后端
C++函數(shù)指針在運行時動態(tài)調(diào)用中是一種非常好用的手段。不過對于初學(xué)者來說,理解起來可能還會有點困難。在這里我們就為大家詳細(xì)介紹一下這方面的相關(guān)概念。

C++語言的原始版本是由C語言的一種叫C with Class的***版本演化而來的。之所以叫C++,是因為人們想通過C語言的++運算符來體現(xiàn)其是C語言的進(jìn)化版本。我們今天就來為大家詳細(xì)介紹一個其中的基礎(chǔ)概念,關(guān)于C++函數(shù)指針的具體內(nèi)容。

在C/C++中,數(shù)據(jù)指針是最直接,也最常用的,因此,理解起來也比較容易。而函數(shù)指針,作為運行時動態(tài)調(diào)用(比如回調(diào)函數(shù) CallBack Function)是一種常見的,而且是很好用的手段。

我們先簡單的說一下C++函數(shù)指針。

常規(guī)函數(shù)指針

  1. void(*fp)(); 

fp 是一個典型的函數(shù)指針,用于指向無參數(shù),無返回值的函數(shù)。

  1. void(*fp2)(int); 

fp2 也是一個C++函數(shù)指針,用于指向有一個整型參數(shù),無返回值的函數(shù)。
當(dāng)然,有經(jīng)驗人士一般都會建議使用typedef來定義函數(shù)指針的類型,如:

  1. typedef void(* FP)();  
  2. FP fp3; // 和上面的fp一樣的定義。 

C++函數(shù)指針之所以讓初學(xué)者畏懼,最主要的原因是它的括號太多了;某些用途的函數(shù)指針,往往會讓人陷在括號堆中出不來,這里就不舉例了,因為不是本文討論的范圍;typedef 方法可以有效的減少括號的數(shù)量,以及理清層次,所以受到推薦。本文暫時只考慮簡單的函數(shù)指針,因此暫不用到typedef。

假如有如下兩個函數(shù):

  1. void f1()  
  2. {  
  3. std::cout << "call f " << std::endl;  
  4. }  
  5. void f2(int a)  
  6. {  
  7. std::cout << "call f2( " << a << " )" << std::endl;  

現(xiàn)在需要通過C++函數(shù)指針來調(diào)用,我們需要給指針指定函數(shù):

  1. fp = &f1; // 也可以用:fp = f1;  
  2. fp2= &f2; // 也可以用:fp2f2;  
  3. void (*fp3)() = &f1; // 也可以用:void (*fp3)() = f1;   
  4. //調(diào)用時如下:  
  5. fp(); // 或 (*fp)();  
  6. fp2(1); // 或 (*fp2)(1);  
  7. fp3(); // 或 (*fp3)(); 

對于此兩種調(diào)用方法,效果完全一樣,我推薦用前一種。后一種不僅僅是多打了鍵盤,而且也損失了一些靈活性。這里暫且不說它。

C++強(qiáng)調(diào)類型安全。也就是說,不同類型的變量是不能直接賦值的,否則輕則警告,重則報錯。這是一個很有用的特性,常常能幫我們找到問題。因此,有識之士認(rèn)為,C++中的任何一外警告都不能忽視。甚至有人提出,編譯的時候不能出現(xiàn)任何警告信息,也就是說,警告應(yīng)該當(dāng)作錯誤一樣處理。

比如,我們把f1賦值給fp2,那么C++編譯器(vc7.1)就會報錯:

  1. fp2 = &f1; // error C2440: “=” : 
    無法從“void (__cdecl *)(void)”轉(zhuǎn)換為“void (__cdecl *)(int)”  
  2. fp1 = &f1; // OK 

這樣,編譯器可以幫我們找出編碼上的錯誤,節(jié)省了我們的排錯時間。

考慮一下C++標(biāo)準(zhǔn)模板庫的sort函數(shù):

  1. // 快速排序函數(shù)  
  2. template<typename RandomAccessIterator, typename BinaryPredicate> 
  3. void sort(  
  4. RandomAccessIterator _First, // 需排序數(shù)據(jù)的***個元素位置  
  5. RandomAccessIterator _Last, // 需排序數(shù)據(jù)的***一個元素位置(不參與排序)  
  6. BinaryPredicate _Comp // 排序使用的比較算法(可以是C++函數(shù)指針、函數(shù)對象等)  
  7. ); 

比如,我們有一個整型數(shù)組:

  1. int n[5] = {3,2,1,8,9}; 

要對它進(jìn)行升序排序,我們需定義一個比較函數(shù):

  1. bool less(int a, int b)  
  2. {  
  3. return a < b;   

然后用:

  1. sort(n, n+5, less); 

要是想對它進(jìn)行降序排序,我們只要換一個比較函數(shù)就可以了。C/C++的標(biāo)準(zhǔn)模板已經(jīng)提供了less和great函數(shù),因此我們可以直接用下面的語句來比較:

  1. sort(n, n+5, great); 

這樣,不需要改變sort函數(shù)的定義,就可以按任意方法進(jìn)行排序,是不是很靈活?

這種用法以C++的標(biāo)準(zhǔn)模板庫(STL)中非常流行。另外,操作系統(tǒng)中也經(jīng)常使用回調(diào)(CallBack)函數(shù),實際上,所謂回調(diào)函數(shù),本質(zhì)就是C++函數(shù)指針。

看起來很簡單吧,這是最普通的C語言指針的用法。本來這是一個很美妙的事情,但是當(dāng)C++來臨時,世界就開始變了樣。

【編輯推薦】

  1. Visual C++應(yīng)用程序編譯技巧說明
  2. 概括C++的學(xué)習(xí)感想
  3. 學(xué)習(xí)C++從哪入手?
  4. 學(xué)習(xí)C++靜態(tài)成員注意事宜
  5. 深度剖析C++中的C++類型
責(zé)任編輯:曹凱 來源: 博客園
相關(guān)推薦

2010-02-03 15:40:11

C++地址運算符

2010-04-02 16:53:34

Oracle內(nèi)存結(jié)構(gòu)

2010-01-27 16:56:42

Android內(nèi)核

2009-08-28 15:16:18

C#泛型集合

2010-03-25 11:30:25

2010-01-13 16:15:47

VB.NET消息隊列

2010-04-08 10:02:15

Oracle體系結(jié)構(gòu)

2010-01-28 16:19:39

Android She

2009-11-26 14:33:58

Cisco路由器IOS

2010-03-26 18:31:50

Python前景Python庫

2010-01-22 18:24:28

VB.NET重構(gòu)

2010-01-28 16:30:16

Android數(shù)據(jù)傳遞

2010-02-26 09:50:57

WCF傳輸安全機(jī)制

2010-02-25 17:57:26

WCF服務(wù)合同

2010-02-26 13:21:42

WCF通道形狀

2010-07-20 13:07:13

SQL Server存

2009-08-17 13:49:23

C#正則表達(dá)式提取

2010-06-17 16:12:43

WAP協(xié)議

2009-12-30 17:23:49

Silverlight

2010-03-25 14:27:52

Python語法
點贊
收藏

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