如何應(yīng)用C++的函數(shù)對(duì)象
前言
C++函數(shù)對(duì)象是通過(guò)一張?zhí)摵瘮?shù)表來(lái)實(shí)現(xiàn)的。簡(jiǎn)稱為V-Table。在這個(gè)表中,主是要一個(gè)類的虛函數(shù)的地址表,這張表解決了繼承、重載的問(wèn)題,保證其容真實(shí)反應(yīng)實(shí)際的函數(shù)。
應(yīng)用
假如我們實(shí)現(xiàn)了這樣的一個(gè)單向鏈表:
class LinkedListNode {
int data_;
LinkedListNode *next_;
};
class LinkedList {
public:
void insert(LinkedListNode* &p);
void del(LinkedListNode *p);
private:
LinkedListNode *head_;
};
其中insert將p插入到head_為頭指針的鏈表中,而p對(duì)應(yīng)的內(nèi)存由外面分配好,調(diào)用的時(shí)候類似于這樣:
LinkedList list; LinkedListNode *p = new LinkedListNode(2, NULL); list.insert(p);
其中,p可能是通過(guò)new得到,也可能是malloc出來(lái)。好,問(wèn)題來(lái)了:
這個(gè)類的del函數(shù)應(yīng)該如何實(shí)現(xiàn)呢?如果節(jié)點(diǎn)是new出來(lái)的,我們得delete;如果是malloc出來(lái)的,我們得使用配套的free。否則,行為就是undefined。而且,用戶還可能實(shí)現(xiàn)了自己的定制的內(nèi)存分配回收例程。我們并不知道該內(nèi)存是如何分配得到的。這就是問(wèn)題所在。
解決方法是讓用戶將正確的、對(duì)應(yīng)的、適配的資源釋放例程傳遞進(jìn)來(lái),然而delete是expression,free是函數(shù),更悲劇的是不同用戶實(shí)現(xiàn)的資源回收函數(shù)原型不盡相同。如何做呢?函數(shù)對(duì)象是解決這個(gè)問(wèn)題的利器。
我們可以這樣:
template<typename CallBack>
class LinkedList
{
public:
void insert(LinkedListNode* &p);
void del(LinkedListNode *p);
private:
LinkedListNode *head_;
};
在del中:
void del(LinkedListNode *p)
{
//...
LinkedListNode *prev = get_prev(p);
prev->next_ = p->next_;
CallBack cb;
cb(p);//調(diào)用用戶提供的資源回收例程
}
用戶需要實(shí)現(xiàn)自己的CallBack類的operator()成員函數(shù)。如下所示:
class MyReclaimRoutine { public: void operator() (LinkedListNode *p) { delete p; //free(p) ? my_release_func(p) ? all up to you! } };
然后就萬(wàn)事大吉了:
LinkedList<MyReclaimRoutine> list; LinkedListNode *p = new LinkedListNode(2, NULL); list.insert(p); list.del(p);//ok! delete p will be called
總結(jié)
以上就是C++函數(shù)對(duì)象的應(yīng)用的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家學(xué)習(xí)C++的函數(shù)對(duì)象能有所幫助,如果有疑問(wèn)歡迎大家留言討論。
相關(guān)文章
C語(yǔ)言新手練習(xí)題之求第n個(gè)斐波那契數(shù)
斐波那契數(shù)列這一個(gè)大一上C語(yǔ)言就有的問(wèn)題大家應(yīng)該都不陌生,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言新手練習(xí)題之求第n個(gè)斐波那契數(shù)的相關(guān)資料,文中通過(guò)圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11
Qt實(shí)現(xiàn)邊加載數(shù)據(jù)邊顯示頁(yè)面的示例代碼
無(wú)論是MFC框架還是QT框架,實(shí)現(xiàn)加載數(shù)據(jù)的等待效果都是很麻煩的,不像WEB端輕輕松松一句代碼就搞定了。本文將通過(guò)Qt實(shí)現(xiàn)邊加載數(shù)據(jù)邊顯示頁(yè)面的功能,需要的可以參考一下2022-01-01
opencv3/C++實(shí)現(xiàn)光流點(diǎn)追蹤
今天小編就為大家分享一篇opencv3/C++實(shí)現(xiàn)光流點(diǎn)追蹤,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12

