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

C++函數(shù)對(duì)象與函數(shù)指針不同之處

開(kāi)發(fā) 后端
C++函數(shù)對(duì)象和函數(shù)指針之間有何不同之處?它的應(yīng)用方式是否更加靈活,功能是否更加強(qiáng)大?在這里我們將會(huì)為大家詳細(xì)介紹。

C++編程語(yǔ)言中,有很多功能都與C語(yǔ)言相通,比如指針的應(yīng)用等等。在這里我們介紹的則是一種類似于函數(shù)指針的C++函數(shù)對(duì)象的相關(guān)介紹。C++函數(shù)對(duì)象不是函數(shù)指針。但是,在程序代碼中,它的調(diào)用方式與函數(shù)指針一樣,后面加個(gè)括號(hào)就可以了。這是入門級(jí)的隨筆,說(shuō)的是函數(shù)對(duì)象的定義,使用,以及與函數(shù)指針,成員函數(shù)指針的關(guān)系。

C++函數(shù)對(duì)象實(shí)質(zhì)上是一個(gè)實(shí)現(xiàn)了operator()--括號(hào)操作符--的類。例如:

  1. class Add  
  2. {  
  3. public:  
  4. int operator()(int a, int b)  
  5. {  
  6. return a + b;  
  7. }  
  8. };  
  9. Add add; // 定義函數(shù)對(duì)象  
  10. cout << add(3,2); // 5 

函數(shù)指針版本就是:

  1. int AddFunc(int a, int b)  
  2. {  
  3. return a + b;  
  4. }  
  5. typedef int (*Add) (int a, int b);  
  6. Add add = &AddFunc;  
  7. cout << add(3,2); // 5 

呵呵,除了定義方式不一樣,使用方式可是一樣的。都是:

  1. cout << add(3,2); 

既然C++函數(shù)對(duì)象與函數(shù)指針在使用方式上沒(méi)什么區(qū)別,那為什么要用函數(shù)對(duì)象呢?很簡(jiǎn)單,函數(shù)對(duì)象可以攜帶附加數(shù)據(jù),而指針就不行了。下面就舉個(gè)使用附加數(shù)據(jù)的例子:

  1. class less  
  2. {  
  3. public:  
  4. less(int num):n(num){}  
  5. bool operator()(int value)  
  6. {  
  7. return value < n;  
  8. }  
  9. private:  
  10. int n;  
  11. }; 

 

使用的時(shí)候:

  1. less isLess(10);  
  2. cout << isLess(9) << " " << isLess(12); // 輸出 1 0 

 

這個(gè)例子好象太兒戲了,換一個(gè):

  1. const int SIZE = 5;  
  2. int array[SIZE] = { 50, 30, 9, 7, 20};  
  3. // 找到小于數(shù)組array中小于10的第一個(gè)數(shù)的位置  
  4. int * pa = std::find_if(array, array + SIZE, less(10)); 
    // pa 指向 9 的位置  
  5. // 找到小于數(shù)組array中小于40的第一個(gè)數(shù)的位置  
  6. int * pb = std::find_if(array, array + SIZE, less(40)); 
    // pb 指向 30 的位置 

這里可以看出C++函數(shù)對(duì)象的方便了吧?可以把附加數(shù)據(jù)保存在函數(shù)對(duì)象中,是函數(shù)對(duì)象的優(yōu)勢(shì)所在。
它的弱勢(shì)也很明顯,它雖然用起來(lái)象函數(shù)指針,但畢竟不是真正的函數(shù)指針。在使用函數(shù)指針的場(chǎng)合中,它就無(wú)能為力了。例如,你不能將函數(shù)對(duì)象傳給qsort函數(shù)!因?yàn)樗唤邮芎瘮?shù)指針。

要想讓一個(gè)函數(shù)既能接受函數(shù)指針,也能接受函數(shù)對(duì)象,最方便的方法就是用模板。如:

  1. template<typename FUNC> 
  2. int count_n(int* array, int size, FUNC func)  
  3. {  
  4. int count = 0;  
  5. for(int i = 0; i < size; ++i)  
  6. if(func(array[i]))  
  7. count ++;  
  8. return count;  

這個(gè)函數(shù)可以統(tǒng)計(jì)數(shù)組中符合條件的數(shù)據(jù)個(gè)數(shù),如:

  1. const int SIZE = 5;  
  2. int array[SIZE] = { 50, 30, 9, 7, 20};  
  3. cout << count_n(array, SIZE, less(10)); // 2  
  4. 用函數(shù)指針也沒(méi)有問(wèn)題:  
  5. bool less10(int v)  
  6. {  
  7. return v < 10;  
  8. }  
  9. cout << count_n(array, SIZE, less10); // 2 

另外,C++函數(shù)對(duì)象還有一個(gè)函數(shù)指針無(wú)法匹敵的用法:可以用來(lái)封裝類成員函數(shù)指針!因?yàn)楹瘮?shù)對(duì)象可以攜帶附加數(shù)據(jù),而成員函數(shù)指針缺少一個(gè)類實(shí)體(類實(shí)例)指針來(lái)調(diào)用,因此,可以把類實(shí)體指針給函數(shù)對(duì)象保存起來(lái),就可以用于調(diào)用對(duì)應(yīng)類實(shí)體成員函數(shù)了。

 

  1. template<typename O> 
  2. class memfun  
  3. {  
  4. public:  
  5. memfun(void(O::*f)(const char*), O* o): pFunc(f), pObj(o){}  
  6. void operator()(const char* name)  
  7. {  
  8. (pObj->*pFunc)(name);  
  9. }  
  10. private:  
  11. void(O::*pFunc)(const char*);  
  12. O* pObj;  
  13. };  
  14. class A  
  15. {  
  16. public:  
  17. void doIt(const char* name)  
  18. { cout << "Hello " << name << "!";}  
  19. };  
  20. A a;  
  21. memfun<A> call(&A::doIt, &a); // 保存 a::doIt指針以便調(diào)用  
  22. call("Kitty"); // 輸出 Hello Kitty! 

 

大功告成了,終于可以方便保存成員函數(shù)指針,以備調(diào)用了。#t#

不過(guò),現(xiàn)實(shí)是殘酷的。函數(shù)對(duì)象雖然能夠保有存成員函數(shù)指針和調(diào)用信息,以備象函數(shù)指針一樣被調(diào)用,但是,它的能力有限,一個(gè)函數(shù)對(duì)象定義,最多只能實(shí)現(xiàn)一個(gè)指定參數(shù)數(shù)目的成員函數(shù)指針。

標(biāo)準(zhǔn)庫(kù)的mem_fun就是這樣的一個(gè)函數(shù)對(duì)象,但是它只能支持0個(gè)和1個(gè)參數(shù)這兩種成員函數(shù)指針。如 int A::func()或void A::func(int)、int A::func(double)等等,要想再多一個(gè)參數(shù)如:int A::func(int, double),不好意思,不支持。想要的話,只有我們自已寫(xiě)了。

而且,就算是我們自已寫(xiě),能寫(xiě)多少個(gè)?5個(gè)?10個(gè)?還是100個(gè)(這也太恐怖了)?

好在boost庫(kù)提供了boost::function類,它默認(rèn)支持10個(gè)參數(shù),最多能支持50個(gè)函數(shù)參數(shù)(多了,一般來(lái)說(shuō)這夠用了。但它的實(shí)現(xiàn)就是很恐怖的:用模板部份特化及宏定義,弄了幾十個(gè)模板參數(shù),偏特化(編譯期)了幾十個(gè)函數(shù)對(duì)象。

C++0x已經(jīng)被接受的一個(gè)提案,就是可變模板參數(shù)列表。用了這個(gè)技術(shù),就不需要偏特化無(wú)數(shù)個(gè)C++函數(shù)對(duì)象了,只要一個(gè)函數(shù)對(duì)象模板就可以解決問(wèn)題了。

責(zé)任編輯:曹凱 來(lái)源: 博客園
相關(guān)推薦

2010-02-04 09:26:23

C++模板函數(shù)重載

2010-02-03 09:52:52

C++指針與引用

2009-11-26 19:18:59

PHP函數(shù)implod

2009-08-20 10:39:00

Java與C#的不同之

2009-11-26 15:35:43

PHP函數(shù)eregi(

2010-03-10 10:58:12

python接口功能

2009-11-24 13:03:38

PHP函數(shù)array_

2009-12-15 18:47:56

Ruby框架OG

2010-04-20 16:07:25

Oracle DRCP

2012-08-31 11:21:12

云計(jì)算大數(shù)據(jù)

2012-08-23 13:36:27

2014-08-14 17:11:51

LinuxWindows

2023-08-10 17:23:10

LibreOfficOpenOffice

2021-03-09 16:38:48

加密貨幣比特幣貨幣

2010-04-08 11:11:16

Oracle查詢

2010-05-06 10:09:44

Oracle in

2010-09-27 10:43:35

無(wú)線路由器

2010-05-21 15:33:54

MySQL text

2023-11-27 08:00:36

開(kāi)發(fā)數(shù)據(jù)庫(kù)查詢

2010-02-01 13:08:46

C++函數(shù)指針C#托
點(diǎn)贊
收藏

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