您好,登錄后才能下訂單哦!
這篇文章給大家介紹C+與C語言有什么關系,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
錯誤1: 沒有明確的結束方法
幾乎可以完全肯定地說,對于大多數C++編程人員而言,C#與C++***的不同之處就在于碎片收集。這也意味著編程人員再也無需擔心內存泄露和確保刪除所有沒有用的指針。但我們再也無法準確地控制殺死無用的對象這個過程。事實上,在C#中沒有明確的destructor.
假如使用非可治理性資源,在不使用這些資源后,必須明確地釋放它。對資源的隱性控制是由Finalize方法(也被稱為finalizer)提供的,當對象被銷毀時,它就會被碎片收集程序調用收回對象所占用的資源。finalizer該當只釋放被銷毀對象占用的非可治理性資源,而不應牽涉到其他對象。
詳細介紹C++編程實例說明
闡述C++的編程工具幾大重要元素
深度剖析C++開發工具種種問題
漫談C++編程的編程技巧與技巧
淺析C++程序設計學習與實驗系統
假如在程序中只使用了可治理性資源,那就無需也不應當執行Finalize方法,只要在非可治理性資源的處理中才會用到Finalize方法。由于finalizer需要占用一定的資源,因此應當只在需要它的方法中執行finalizer.直接調用一個對象的Finalize方法是絕對不答應的(除非是在子類的Finalize中調用基礎類的Finalize.),碎片收集程序會主動地調用Finalize.
從語法上看,C#中的destructor與C++非常相似,但其實它們是完全不同的。C++語法中的destructor只是定義Finalize方法的捷徑。因此,下面的二段代碼是有區別的:
~MyClass() { // 需要完成的任務 } MyClass.Finalize() {// 需要完成的任務 base.Finalize(); }
錯誤2:Finalize和Dispose使用誰?
從上面的論述中我們已經很清楚,顯性地調用finalizer是不答應的,它只能被碎片收集程序調用。假如期望盡快地釋放一些不再使用的數量有限的非可治理性資源(如文件句柄),則該當使用IDisposable界面,這一界面有個Dispose方法,它能夠幫你完成這個任務。Dispose是無需等待Finalize被調用而能夠釋放非可治理性資源的方法。
假如已經使用了Dispose方法,則應當阻止碎片收集程序再對相應的對象執行Finalize方法。為此,需要調用靜態方法GC.SuppressFinalize,并將相應對象的指針傳遞給它作為參數,Finalize方法就能調用Dispose方法了。據此,我們能夠得到如下的代碼:
public void Dispose() { // 完成清理操作 // 通知GC不要再調用Finalize方法 GC.SuppressFinalize(this); } public override void Finalize() { Dispose(); base.Finalize(); }
對于有些對象,可能調用Close方法就更合適(例如,對于文件對象調用Close就比Dispose更合適),可以通過創建一個private屬性的Dispose方法和public屬性的Close方法,并讓Close調用Dispose來實現對某些對象調用Close方法。
由于不能確定一定會調用Dispose,而且finalizer的執行也是不確定的(我們無法控制GC會在何時運行),C#提供了一個Using語句來保證Dispose方法會在盡可能早的時間被調用。一般的方法是定義使用哪個對象,然后用括號為這些對象指定一個活動的范圍,當碰到最內層的括號時,Dispose方法就會被主動調用,對該對象進行處理。
對于有些對象,可能調用Close方法就更合適(例如,對于文件對象調用Close就比Dispose更合適),可以通過創建一個private屬性的Dispose方法和public屬性的Close方法,并讓Close調用Dispose來實現對某些對象調用C++語法方法。
關于C+與C語言有什么關系就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。