程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> 淺析C++中boost.variant的幾種訪問辦法

淺析C++中boost.variant的幾種訪問辦法

編輯:關於C++

淺析C++中boost.variant的幾種訪問辦法。本站提示廣大學習愛好者:(淺析C++中boost.variant的幾種訪問辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是淺析C++中boost.variant的幾種訪問辦法正文


Boost.Variant

Variant庫包括一個不同於union的泛型類,用於在存儲和操作來自於不同類型的對象。這個庫的一個特點是支持類型平安的訪問,增加了不同數據類型的類型轉換代碼的共同問題。

Variant 庫如何改良你的順序?

     •對用戶指定的多品種型的停止類型平安的存儲和取回

     •在規范庫容器中存儲不同類型的辦法

     •變量訪問的編譯期反省

     •高效的、基於棧的變量存儲

Variant 庫關注的是對一組限定類型的類型平安存儲及取回,即非無類的結合。Boost.Variant 庫與 Boost.Any 有許多共同之外,但在功用上也有不同的思索。在每天的編程中通常都會需求用到非無類的結合(不同的類型)。堅持類型平安的一個典型辦法是運用籠統基類,但這不總是可以做到的;即便可以做得,堆分配和虛擬函數的代價也能夠太高。你也可以嘗試用不平安的無類類型,如 void* (它會招致不幸),或許是類型平安得有限制的可變類型,如 Boost.Any. 這裡我們將看到 Boost.Variant,它支持限定的可變類型,即元從來自於一組支持的類型。

上面將淺談variant的幾種訪問辦法,一同來學習學習吧。

運用boost::get

boost::variant<int, std::string> v;
v = "Hello world";
std::cout << boost::get<std::string>(v) << std::endl;

運用boost::get來訪問,需求給出原始類型,並且這樣做不平安,若類型錯誤,順序將會拋出異常。

運用RTTI

void var_print(boost::variant<int, std::string>& v) 
{ 
  if (v.type() == typeid(int)) 
  { 
    std::cout << get<int>(v) << std::endl; 
  }
  else if (v.type() == typeid(std::string)) 
  { 
    std::cout << get<std::string>(v) << std::endl; 
  } 
  // Else do nothing
} 
int main() 
{ 
  boost::variant<int, std::string> v;
  v = "Hello world"; 
  var_print(v);
  return 0;
}

運用RTTI技術可以防止類型訪問錯誤而順序異常的狀況,但是這樣做有點不優雅,每添加一個類型,都需求修正if-else構造,並且運用RTTI會對順序功能有一定影響。

運用訪問者形式

class var_visitor : public boost::static_visitor<void>
{
public:
  void operator()(int& i) const
  {
    std::cout << i << std::endl;
  }
  void operator()(std::string& str) const
  {
    std::cout << str << std::endl;
  }
};
int main() 
{ 
  boost::variant<int, std::string> v;
  v = "Hello world"; 
  boost::apply_visitor(var_visitor(), v);
  return 0;
}

運用該形式,需求定義一個類並承繼於boost::static_visitor,在類外面需求重載()操作符,經過boost::apply_visitor來訪問原始類型的值,這樣做還是有些繁瑣,每添加一個類型,都需求在var_visitor外面添加一個函數,但比運用RTTI外面的修正if-else構造好得多,由於運用訪問者形式至多是遵照開放-封鎖准繩的,即對寫開放,對修正封鎖。

運用模板函數

class var_visitor : public boost::static_visitor<void>
{
public:
  template<typename T>
  void operator()(T& i) const
  {
    std::cout << i << std::endl;
  }
};
int main() 
{ 
  boost::variant<int, std::string> v;
  v = "Hello world"; 
  boost::apply_visitor(var_visitor(), v);
  return 0;
}

operator()改成了模板函數的益處就是不必關懷variant支持多少類型。

總結

以上就是這篇文章的全部內容,希望本文的內容對大家學習或許運用C++能有所協助,假如有疑問大家可以留言交流。謝謝大家對的支持。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved