欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++?Boost?weak_ptr智能指針超詳細(xì)講解

 更新時間:2022年11月17日 11:03:38   作者:無水先生  
智能指針是一種像指針的C++對象,但它能夠在對象不使用的時候自己銷毀掉。雖然STL提供了auto_ptr,但是由于不能同容器一起使用(不支持拷貝和賦值操作),因此很少有人使用。它是Boost各組件中,應(yīng)用最為廣泛的一個

一、提要

在 C++11 中,boost::weak_ptr是另一類智能指針,一般是用COM組件生成、調(diào)用,本文闡述這種指針的特點(diǎn)和用法。

二、特別智能指針(Special Smart Pointers)

到目前為止介紹的每個智能指針都可以在不同的場景中單獨(dú)使用。但是,boost::weak_ptr 僅在與 boost::shared_ptr 結(jié)合使用時才有意義。 boost::weak_ptr 在 boost/weak_ptr.hpp 中定義。

示例1.Usingboost::weak_ptr

#include <boost/shared_ptr.hpp>
#include <boost/weak_ptr.hpp>
#include <thread>
#include <functional>
#include <iostream>
void reset(boost::shared_ptr<int> &sh)
{
  sh.reset();
}
void print(boost::weak_ptr<int> &w)
{
  boost::shared_ptr<int> sh = w.lock();
  if (sh)
    std::cout << *sh << '\n';
}
int main()
{
  boost::shared_ptr<int> sh{new int{99}};
  boost::weak_ptr<int> w{sh};
  std::thread t1{reset, std::ref(sh)};
  std::thread t2{print, std::ref(w)};
  t1.join();
  t2.join();
}

boost::weak_ptr 必須使用 boost::shared_ptr 進(jìn)行初始化。它最重要的成員函數(shù)是 lock()。 lock() 返回一個 boost::shared_ptr ,它與用于初始化弱指針的共享指針共享所有權(quán)。如果共享指針為空,則返回的指針也將為空。

boost::weak_ptr 是有意義的,只要一個函數(shù)需要與一個由共享指針管理的對象一起工作,但對象的生命周期不依賴于函數(shù)本身。該函數(shù)只能使用該對象,只要它由程序中其他位置的至少一個共享指針擁有。如果共享指針被重置,則對象無法保持活動狀態(tài),因?yàn)橄鄳?yīng)函數(shù)內(nèi)有一個額外的共享指針。

示例 1 在 main() 中創(chuàng)建了兩個線程。第一個線程執(zhí)行函數(shù) reset(),該函數(shù)接收對共享指針的引用。第二個線程執(zhí)行函數(shù) print(),該函數(shù)接收對弱指針的引用。這個弱指針之前已經(jīng)用共享指針初始化了。

程序啟動后,reset() 和 print() 會同時執(zhí)行。但是,無法預(yù)測執(zhí)行順序。這會導(dǎo)致當(dāng)對象被 print() 訪問時,reset() 會破壞該對象的潛在問題。

弱指針通過以下方式解決了這個問題:調(diào)用 lock() 返回一個共享指針,該指針指向一個有效對象(如果在調(diào)用時存在一個有效對象)。如果不是,則共享指針設(shè)置為 0,相當(dāng)于一個空指針。

boost::weak_ptr 本身對對象的生命周期沒有任何影響。為了安全地訪問 print() 函數(shù)中的對象,lock() 返回一個 boost::shared_ptr。這保證了即使不同的線程嘗試釋放對象,由于返回的共享指針,它仍將繼續(xù)存在。

示例2 .使用boost::intrusive_ptr

#include <boost/intrusive_ptr.hpp>
#include <atlbase.h>
#include <iostream>
void intrusive_ptr_add_ref(IDispatch *p) { p->AddRef(); }
void intrusive_ptr_release(IDispatch *p) { p->Release(); }
void check_windows_folder()
{
  CLSID clsid;
  CLSIDFromProgID(CComBSTR{"Scripting.FileSystemObject"}, &clsid);
  void *p;
  CoCreateInstance(clsid, 0, CLSCTX_INPROC_SERVER, __uuidof(IDispatch), &p);
  boost::intrusive_ptr<IDispatch> disp{static_cast<IDispatch*>(p), false};
  CComDispatchDriver dd{disp.get()};
  CComVariant arg{"C:\\Windows"};
  CComVariant ret{false};
  dd.Invoke1(CComBSTR{"FolderExists"}, &arg, &ret);
  std::cout << std::boolalpha << (ret.boolVal != 0) << '\n';
}
int main()
{
  CoInitialize(0);
  check_windows_folder();
  CoUninitialize();
}

通常,boost::intrusive_ptr 的工作方式與 boost::shared_ptr 相同。但是,雖然 boost::shared_ptr 會跟蹤引用特定對象的共享指針的數(shù)量,但開發(fā)人員在使用 boost::intrusive_ptr 時必須這樣做。如果其他類已經(jīng)跟蹤引用,這可能是有意義的。

boost::intrusive_ptr 在 boost/intrusive_ptr.hpp 中定義。

示例 2 使用 COM 提供的功能,因此只能在 Windows 上構(gòu)建和運(yùn)行。 COM 對象是 boost::intrusive_ptr 的一個很好的例子,因?yàn)樗鼈兏櫼盟鼈兊闹羔樀臄?shù)量。內(nèi)部引用計數(shù)器可以通過成員函數(shù) AddRef() 和 Release() 遞增或遞減 1。一旦計數(shù)器達(dá)到 0,COM 對象就會自動銷毀。

??? 從 intrusive_ptr_add_ref() 和 intrusive_ptr_release() 調(diào)用兩個成員函數(shù) AddRef() 和 Release()。 Boost.Intrusive 希望開發(fā)人員定義這兩個函數(shù),當(dāng)引用計數(shù)器必須遞增或遞減時,它們會自動調(diào)用。傳遞給這些函數(shù)的參數(shù)是指向用于實(shí)例化類模板 boost::intrusive_ptr 的類型的指針。

此示例中使用的 COM 對象稱為 FileSystemObject,默認(rèn)情況下可在 Windows 上使用。它提供對底層文件系統(tǒng)的訪問,例如,檢查給定目錄是否存在。在示例 1.9 中,檢查了名為 C:\Windows 的目錄是否存在。其內(nèi)部工作方式僅取決于 COM,與 boost::intrusive_ptr 的功能無關(guān)。關(guān)鍵是一旦侵入指針 disp 在 check_windows_folder() 結(jié)束時超出范圍,函數(shù) intrusive_ptr_release() 就會被自動調(diào)用。這反過來會將 FileSystemObject 的內(nèi)部引用計數(shù)器減為 0 并銷毀該對象。

傳遞給 boost::intrusive_ptr 的構(gòu)造函數(shù)的參數(shù) false 會阻止 intrusive_ptr_add_ref() 被調(diào)用。當(dāng)使用 CoCreateInstance() 創(chuàng)建 COM 對象時,計數(shù)器已設(shè)置為 1。因此,不得使用 intrusive_ptr_add_ref() 遞增。

到此這篇關(guān)于C++ Boost weak_ptr智能指針超詳細(xì)講解的文章就介紹到這了,更多相關(guān)C++ Boost weak_ptr內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 冒泡算法的改進(jìn)具體實(shí)現(xiàn)

    冒泡算法的改進(jìn)具體實(shí)現(xiàn)

    這篇文章主要介紹了冒泡算法的改進(jìn)具體實(shí)現(xiàn),有需要的朋友可以參考一下
    2013-12-12
  • C語言驅(qū)動開發(fā)之判斷自身是否加載成功詳解

    C語言驅(qū)動開發(fā)之判斷自身是否加載成功詳解

    在驅(qū)動開發(fā)中我們有時需要得到驅(qū)動自身是否被加載成功的狀態(tài),這個功能看似沒啥用實(shí)際上在某些特殊場景中還是需要的。本文將通過示例詳細(xì)講講這一功能的實(shí)現(xiàn)方法,需要的可以參考下
    2022-10-10
  • C語言宏定義的擴(kuò)展定義講解

    C語言宏定義的擴(kuò)展定義講解

    這篇文章主要介紹了C語言宏定義的擴(kuò)展,宏定義是C語言提供的三種預(yù)處理功能的其中一種,這三種預(yù)處理包括:宏定義、文件包含、條件編譯
    2022-12-12
  • C++深入講解new與deleted關(guān)鍵字的使用

    C++深入講解new與deleted關(guān)鍵字的使用

    這篇文章主要介紹了C++中new與deleted關(guān)鍵字的使用,new在動態(tài)內(nèi)存中為對象分配空間并返回一個指向該對象的指針;delete接受一個動態(tài)對象的指針, 銷毀該對象, 并釋放與之關(guān)聯(lián)的內(nèi)存
    2022-05-05
  • 基于C++實(shí)現(xiàn)簡單日期計算器

    基于C++實(shí)現(xiàn)簡單日期計算器

    這篇文章主要介紹了基于C++實(shí)現(xiàn)簡單日期計算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • C語言歸排與計排深度理解

    C語言歸排與計排深度理解

    這篇文章主要為大家詳細(xì)的介紹了C語言中計數(shù)排序和歸并排序,歸并排序是創(chuàng)建在歸并操作上的一種有效的排序算法,計數(shù)排序不用比較兩個數(shù)的大小,感興趣的朋友可以參考閱讀
    2023-04-04
  • C++虛函數(shù)表和虛析構(gòu)介紹

    C++虛函數(shù)表和虛析構(gòu)介紹

    這篇文章主要介紹了C++虛函數(shù)表和虛析構(gòu),虛函數(shù)表是C++實(shí)現(xiàn)多態(tài)的基礎(chǔ),多態(tài)是面向?qū)ο蟮娜筇匦灾?,下面文章我們一起來看看詳?xì)內(nèi)容,需要的朋友可以參考一下
    2021-11-11
  • 簡單了解C++語言中的二元運(yùn)算符和賦值運(yùn)算符

    簡單了解C++語言中的二元運(yùn)算符和賦值運(yùn)算符

    這篇文章主要介紹了C++語言中的二元運(yùn)算符和賦值運(yùn)算符,文中列出了可重載的運(yùn)算符列表,需要的朋友可以參考下
    2016-01-01
  • C++逐步介紹日期類的使用

    C++逐步介紹日期類的使用

    下面小編就為大家?guī)硪黄狢++實(shí)現(xiàn)日期類(Date類)的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2022-07-07
  • C++深淺拷貝和寫時拷貝圖文詳解

    C++深淺拷貝和寫時拷貝圖文詳解

    這篇文章主要給大家介紹了關(guān)于C++深淺拷貝和寫時拷貝的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04

最新評論