前言
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)歡迎大家留言討論。
新聞熱點(diǎn)
疑難解答