91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

RAII慣用法是什么

發布時間:2021-06-22 15:57:58 來源:億速云 閱讀:189 作者:chen 欄目:編程語言

這篇文章主要講解了“RAII慣用法是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“RAII慣用法是什么”吧!

軟件開發中,會用到各種各樣的資源。狹義的資源指內存,而廣義的資源包括文件、網絡連接、數據庫連接、信號量、事件、線程、內存等,甚至可以是狀態。資源獲取后由于種種原因導致***不能釋放的資源稱為資源泄漏。針對資源泄漏,提出了各種各樣的軟件機制和程序設計慣用法,如垃圾收集、RRID[1]、RAII、確定性資源清理等。

RAII是C++語言的一種管理資源、避免泄漏的慣用法。C++標準保證任何情況下,已構造的對象最終會銷毀,即它的析構函數最終會被調用。簡單的說,RAII 的做法是使用一個對象,在其構造時獲取資源,在對象生命期控制對資源的訪問使之始終保持有效,***在對象析構的時候釋放資源。

本文簡單介紹RAII的分類以及如何使用RAII,以使代碼安全地管理資源。

RAII的分類

根據RAII對資源的所有權可分為常性類型和變性類型,代表者分別是boost:shared_ptr<>[2]和std::auto_ptr<>;從所管資源的初始化位置上可分為外部初始化類型和內部初始化類型。

常性類型是指獲取資源的地點是構造函數,釋放點是析構函數,并且在這兩點之間的一段時間里,任何對該RAII類型實例的操縱都不應該從它手里奪走資源的所有權。變性類型是指可以中途被設置為接管另一個資源,或者干脆被置為不擁有任何資源。外部初始化類型是指資源在外部被創建,并被傳給RAII實例的構造函數,后者進而接管了其所有權。boost:shared_ptr<>和std::auto_ptr<>都是此類型。與之相對的是內部初始化類型。

其中,常性且內部初始化的類型是最為純粹的RAII形式,最容易理解,最容易編碼。

RAII實際應用

每當處理需要配對的獲取/釋放函數調用的資源時,都應該將資源封裝在一個對象中,實現自動資源釋放。例如,我們無需直接調用一對非成員函數OpenPort/ClosePort,而是可以考慮定義常性且內部初始化的RAII概念的“端口”操作類:

class Port{  public:  Port(const string& destination);//調用OpenPort  ~Port();//調用ClosePort  };  void DoSomething(){  Port port1(“server1:80”);  &hellip;  }  shared_ptr<Port> post2 = /*&hellip;*/; //port2在***一個引用它的  //shared_ptr離開作用域后關閉

通過使用上述RAII類型,可以避免程序員忘記關閉端口而引起的泄漏,還可以確保異常發生時棧展開過程中自動釋放端口資源。

RAII與STL容器

STL容器是基于值語義的,在容器內部,對象是常被復制的。如果RAII類型需要存入STL容器,需要作一些處理。

class Resource   {   public:   Resource() {/*分配資源*/}   ~ Resource() {/*釋放資源*/}   private:   int handle;   };   std::map< Identifier, Resource > resourceMap;

以上代碼中STL容器對Resource的復制將導致運行期錯誤。***的方法是讓RAII類型繼承于boost::noncopyable[2],而后在容器中使用引用計數的指針:

class Resource : public boost::noncopyable   {   public:   Resource() {/*分配資源*/}   ~ Resource() {/*釋放資源*/}   private:   int handle;   };   typedef boost::shared_ptr<Resource> PointerToResourceType;   typedef std::map< Identifier, PointerToResourceType> ResourceMapType;   ResourceMapType resourceMap;

作為替代,還可以使用非拷貝行為的容器:boost::ptr_map<Identifier,Resource> map;

域守衛類

廣義的資源可代表狀態。這時,域守衛類(scoping classes)所帶來的安全價值是無法衡量的。例如:對于在多線程應用中用于同步線程的Mutex,ScopedLock類用于實現鎖/解鎖的操作:

class ScopedLock {  public:  explicit ScopedLock (Mutex& m) : mutex(m) { mutex.lock(); locked = true; }  ~ScopedLock () { if (locked) mutex.unlock(); }  void unlock() { locked = false; mutex.unlock(); }  private:  ScopedLock (const ScopedLock&);  ScopedLock& operator= (const ScopedLock&);  Mutex& mutex;  bool locked;  };

當ScopedLock實例對象被創建時,mutex就被鎖定了,而當實例作用域生命期結束時mutex隱式釋放。通過這種方法避免了忘記釋放的鎖,從而避免了此原因所引起的死鎖和崩潰。

{  ScopedLock locker(mtx);  &hellip;  } // 自動釋放

為每一種資源建立一個RAII類型會使代碼顯得冗長且容易出錯。使用ScopeGuard模板類能夠寫出簡單、異常安全和避免資源泄漏的代碼。

{  void *buffer = std::malloc(1024);  ScopeGuard freeIt = MakeGuard(std::free, buffer);  FILE *fp = std::fopen("afile.txt");  ScopeGuard closeIt = MakeGuard(std::fclose, fp);  &hellip;  }

總結

RAII的核心思想是使用對象管理資源,對象“消亡”則自動釋放資源。理解和使用RAII能使軟件設計更清晰,代碼更健壯。與大名鼎鼎的垃圾收集(GC)不同的是,RAII可管理廣義的資源,而垃圾收集只關注“內存泄漏”,不關心諸如文件句柄、同步對象等一些系統資源的泄漏問題。RAII能使程序員確定資源釋放的時機,這也正是C++/CLI引入確定性資源清理的原因。

感謝各位的閱讀,以上就是“RAII慣用法是什么”的內容了,經過本文的學習后,相信大家對RAII慣用法是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

特克斯县| 永胜县| 荥经县| 精河县| 张北县| 资讯| 大化| 清丰县| 天祝| 当雄县| 南通市| 平利县| 大安市| 连南| 肃南| 灵石县| 永泰县| 临颍县| 陆丰市| 比如县| 江安县| 汉源县| 丹棱县| 仁寿县| 肇庆市| 胶州市| 芜湖县| 阿荣旗| 搜索| 原平市| 太白县| 南雄市| 金湖县| 土默特左旗| 平阴县| 应用必备| 聂拉木县| 龙山县| 扎兰屯市| 罗田县| 乐亭县|