新聞中心
我們在上一篇文章中為大家介紹了產生C++堆對象禁用的具體實現(xiàn)方式,相信大家應該有所掌握。今天我們將會為大家介紹同屬于內存邏輯區(qū)域的C++棧對象的禁用方式。希望能讓大家進一步對這方面的應用技巧有一個深刻的認識。#t#

創(chuàng)新互聯(lián)是一家以重慶網站建設公司、網頁設計、品牌設計、軟件運維、營銷推廣、小程序App開發(fā)等移動開發(fā)為一體互聯(lián)網公司。已累計為混凝土攪拌罐等眾行業(yè)中小客戶提供優(yōu)質的互聯(lián)網建站和軟件開發(fā)服務。
創(chuàng)建C++棧對象時會移動棧頂指針以“挪出”適當大小的空間,然后在這個空間上直接調用對應的構造函數(shù)以形成一個棧對象,而當函數(shù)返回時,會調用其析構函數(shù)釋放這個對象,然后再調整棧頂指針收回那塊棧內存。在這個過程中是不需要operat or newdelete操作的,所以將operator newdelete設置為private不能達到目的。當然從上面的敘述中,你也許已經想到了:將構造函數(shù)或析構函數(shù)設為私有的,這樣系統(tǒng)就不能調用構造析構函數(shù)了,當然就不能在棧中生成對象了。
這樣的確可以,而且我也打算采用這種方案。但是在此之前,有一點需要考慮清楚,那就是,如果我們將構造函數(shù)設置為私有,那么我們也就不能用new來直接產生堆對象了,因為new在為對象分配空間后也會調用它的構造函數(shù)啊。所以,我打算只將析構函數(shù)設置為private。再進一步,將析構函數(shù)設為private除了會限制棧對象生成外,還有其它影響嗎?是的,這還會限制繼承。
如果一個類不打算作為基類,通常采用的方案就是將其析構函數(shù)聲明為private。
為了限制C++棧對象,卻不限制繼承,我們可以將析構函數(shù)聲明為protected,這樣就兩全其美了。如下代碼所示:
- class NoStackObject
- {
- protected
- ~NoStackObject() { }
- public
- void destroy()
- {
- delete this ;調用保護析構函數(shù)
- }
- };
接著,可以像這樣使用NoStackObject類:
- NoStackObject hash_ptr = new NoStackObject() ;
- ... ... 對hash_ptr指向的對象進行操作
- hash_ptr-destroy() ;
是不是覺得有點怪怪的,我們用new創(chuàng)建一個對象,卻不是用delete去刪除它,而是要用destroy方法。很顯然,用戶是不習慣這種怪異的使用方式的。所以,我決定將構造函數(shù)也設為private或protected。這又回到了上面曾試圖避免的問題,即不用new,那么該用什么方式來生成一個對象了?我們可以用間接的辦法完成,即讓這個類提供一個static成員函數(shù)專門用于產生該類型的堆對象。(設計模式中的singleton模式就可以用這種方式實現(xiàn)。)讓我們來看看:
- class NoStackObject
- {
- protected
- NoStackObject() { }
- ~NoStackObject() { }
- public
- static NoStackObject creatInstance()
- {
- return new NoStackObject() ;調用保護的構造函數(shù)
- }
- void destroy()
- {
- delete this ;調用保護的析構函數(shù)
- }
- };
現(xiàn)在可以這樣使用NoStackObject類了:
- NoStackObject hash_ptr = NoStackObjectcreatInstance() ;
- ... ... 對hash_ptr指向的對象進行操作
- hash_ptr-destroy() ;
- hash_ptr = NULL ; 防止使用懸掛指針
以上就是對C++棧對象進行限制的相關操作方法。
文章題目:C++棧對象產生禁用方式
分享網址:http://www.fisionsoft.com.cn/article/dheegce.html


咨詢
建站咨詢
