您好,登錄后才能下訂單哦!
這篇文章主要介紹“C++中為什么不要泄漏任何資源”,在日常操作中,相信很多人在C++中為什么不要泄漏任何資源問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C++中為什么不要泄漏任何資源”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
Even a slow growth in resources will, over time, exhaust the availability of those resources. This is particularly important for long-running programs, but is an essential piece of responsible programming behavior.
即使是資源的緩慢增長,經過一定時間之后,也會最終耗盡該資源的可用性。這對長時間運行的程序特別重要,也是重要編程活動中必不可少的一部分。
Example, bad(反面事例)
void f(char* name){ FILE* input = fopen(name, "r"); // ... if (something) return; // bad: if something == true, a file handle is leaked // ... fclose(input);}
譯者注:由于某種原因,代碼在fclose之前退出執行時,會導致文件無法關閉。
Prefer RAII:(使用RAII的更好示例)
void f(char* name){ ifstream input {name}; // ... if (something) return; // OK: no leak // ...}
譯者注:
資源獲取即初始化(Resource Acquisition Is Initialization),或稱 RAII,是一種 C++ 編程技術,它將必須在使用前請求的資源(分配的堆內存、執行線程、打開的套接字、打開的文件、鎖定的互斥體、磁盤空間、數據庫連接等——任何存在受限供給中的事物)的生命周期綁定與一個對象的生存期相綁定。
Note(注意)
泄漏也常被成為“任何沒有被清理的東西”。更加重要的分類是“任何不會被清理的東西”。例如從堆中分配一個對象然后丟失了最后一個指向那個對象指針。這個規則不應該被理解為這樣的要求:即長生命周期對象必須被在程序停止運轉時釋放。例如,利用進程停止運行時保證的關閉文件,釋放內存處理的做法會簡化代碼,但是依賴嚴格清理規則的做法可以簡單而且更安全。
推行生命周期安全規則群可以排除資源泄漏。和RAII提供的資源安全機制一起使用的話,可以(通過不產生垃圾)排除“垃圾收集”的需求。再結合執行類型和邊界規則群,你可以得到完全的類型和資源安全,一切都由工具保證。
Enforcement(執行建議)
Look at pointers: Classify them into non-owners (the default) and owners. Where feasible, replace owners with standard-library resource handles (as in the example above). Alternatively, mark an owner as such using owner
from the GSL.
關注指針:按照所有者的有無(缺省為無)進行分類。如果可能,將所有者替換為標準庫中的資源句柄(例如上面的示例)。使用GSL中的owner關鍵字標識所有者。
Look for naked new
and delete
關注直接的new和delete
Look for known resource allocating functions returning raw pointers (such as fopen
, malloc
, and strdup
)
關注已知的返回原始指針的資源分配函數(例如fopen,malloc和strdup)
到此,關于“C++中為什么不要泄漏任何資源”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。