亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++?Boost?Conversion超詳細(xì)講解

 更新時(shí)間:2022年11月24日 14:35:31   作者:無(wú)水先生  
Boost是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱。Boost庫(kù)是一個(gè)可移植、提供源代碼的C++庫(kù),作為標(biāo)準(zhǔn)庫(kù)的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱

一、說(shuō)明

Boost.Conversion 在頭文件 boost/cast.hpp 中定義了轉(zhuǎn)換運(yùn)算符 boost::polymorphic_cast 和 boost::polymorphic_downcast。它們旨在更精確地處理類型轉(zhuǎn)換——通常使用 dynamic_cast 完成。

庫(kù)由兩個(gè)文件組成。分別在boost/cast.hpp文件中定義了boost::polymorphic_castboost::polymorphic_downcast這兩個(gè)類型轉(zhuǎn)換操作符, 在boost/lexical_cast.hpp文件中定義了boost::lexical_cast。

二、示例和代碼

boost::polymorphic_castboost::polymorphic_downcast是為了使原來(lái)用dynamic_cast實(shí)現(xiàn)的類型轉(zhuǎn)換更加具體。具體細(xì)節(jié),如下例所示。

struct father 
{ 
  virtual ~father() { }; 
}; 
struct mother 
{ 
  virtual ~mother() { }; 
}; 
struct child : 
  public father, 
  public mother 
{ 
}; 
void func(father *f) 
{ 
  child *c = dynamic_cast<child*>(f); 
} 
int main() 
{ 
  child *c = new child; 
  func(c); 
  father *f = new child; 
  mother *m = dynamic_cast<mother*>(f); 
} 

本例使用dynamic_cast類型轉(zhuǎn)換操作符兩次: 在func()函數(shù)中,它將指向父類的指針轉(zhuǎn)換為指向子類的指針。在main()中, 它將一個(gè)指向父類的指針轉(zhuǎn)為指向另一個(gè)父類的指針。第一個(gè)轉(zhuǎn)換稱為向下轉(zhuǎn)換(downcast),第二個(gè)轉(zhuǎn)換稱為交叉轉(zhuǎn)換(cross cast)。

通過(guò)使用 Boost.Conversion 的類型轉(zhuǎn)換操作符,可以將向下轉(zhuǎn)換和交叉轉(zhuǎn)換區(qū)分開來(lái)。

#include <boost/cast.hpp> 
struct father 
{ 
  virtual ~father() { }; 
}; 
struct mother 
{ 
  virtual ~mother() { }; 
}; 
struct child : 
  public father, 
  public mother 
{ 
}; 
void func(father *f) 
{ 
  child *c = boost::polymorphic_downcast<child*>(f); 
} 
int main() 
{ 
  child *c = new child; 
  func(c); 
  father *f = new child; 
  mother *m = boost::polymorphic_cast<mother*>(f); 
} 

boost::polymorphic_downcast
 類型轉(zhuǎn)換操作符只能用于向下轉(zhuǎn)換。 它內(nèi)部使用 
static_cast
 實(shí)現(xiàn)類型轉(zhuǎn)換。 由于 
static_cast
 并不動(dòng)態(tài)檢查類型轉(zhuǎn)換是否合法,所以 
boost::polymorphic_downcast
 應(yīng)該只在類型轉(zhuǎn)換是安全的情況下使用。 在調(diào)試(debug builds)模式下, 
boost::polymorphic_downcast
 實(shí)際上在 
assert ()
函數(shù)中使用
 dynamic_cast
 驗(yàn)證類型轉(zhuǎn)換是否合法。 請(qǐng)注意這種合法性檢測(cè)只在定義了
NDEBUG
宏的情況下執(zhí)行,這通常是在調(diào)試模式下。

向下轉(zhuǎn)換最好使用boost::polymorphic_downcast, 那么boost::polymorphic_cast就是交叉轉(zhuǎn)換所需要的了。 由于dynamic_cast是唯一能實(shí)現(xiàn)交叉轉(zhuǎn)換的類型轉(zhuǎn)換操作符,boost::polymorphic_cast內(nèi)部使用了它。 由于boost::polymorphic_cast能夠在錯(cuò)誤的時(shí)候拋出std::bad_cast類型的異常,所以優(yōu)先使用這個(gè)類型轉(zhuǎn)換操作符還是很有必要的。相反,dynamic_cast在類型轉(zhuǎn)換失敗使將返回0。 避免手工驗(yàn)證返回值,boost::polymorphic_cast提供了自動(dòng)化的替代方式。

boost::polymorphic_downcastboost::polymorphic_cast只在指針必須轉(zhuǎn)換的時(shí)候使用;否則,必須使用dynamic_cast執(zhí)行轉(zhuǎn)換。 由于boost::polymorphic_downcast是基于static_cast,所以它不能夠,比如說(shuō),將父類對(duì)象轉(zhuǎn)換為子類對(duì)象。 如果轉(zhuǎn)換的類型不是指針,則使用boost::polymorphic_cast執(zhí)行類型轉(zhuǎn)換也沒有什么意義,而在這種情況下使用dynamic_cast還會(huì)拋出一個(gè)std::bad_cast異常。

雖然所有的類型轉(zhuǎn)換都可用dynamic_cast實(shí)現(xiàn),可boost::polymorphic_downcastboost::polymorphic_cast也不是真正隨意使用的。 Boost.Conversion 還提供了另外一種在實(shí)踐中很有用的類型轉(zhuǎn)換操作符。 體會(huì)一下下面的例子。

#include <boost/lexical_cast.hpp> 
#include <string> 
#include <iostream> 
int main() 
{ 
  std::string s = boost::lexical_cast<std::string>(169); 
  std::cout << s << std::endl; 
  double d = boost::lexical_cast<double>(s); 
  std::cout << d << std::endl; 
} 

類型轉(zhuǎn)換操作符boost::lexical_cast可將數(shù)字轉(zhuǎn)換為其他類型。 例子首先將整數(shù)169轉(zhuǎn)換為字符串,然后將字符串轉(zhuǎn)換為浮點(diǎn)數(shù)。

boost::lexical_cast內(nèi)部使用流(streams)執(zhí)行轉(zhuǎn)換操作。 因此,只有那些重載了operator<<()operator>>()這兩個(gè)操作符的類型可以轉(zhuǎn)換。 使用boost::lexical_cast的優(yōu)點(diǎn)是類型轉(zhuǎn)換出現(xiàn)在一行代碼之內(nèi),無(wú)需手工操作流(streams)。 由于流的用法對(duì)于類型轉(zhuǎn)換不能立刻理解代碼含義, 而boost::lexical_cast類型轉(zhuǎn)換操作符還可以使代碼更有意義,更加容易理解。

請(qǐng)注意boost::lexical_cast并不總是訪問(wèn)流(streams);它自己也優(yōu)化了一些數(shù)據(jù)類型的轉(zhuǎn)換。

如果轉(zhuǎn)換失敗,則拋出boost::bad_lexical_cast類型的異常,它繼承自std::bad_cast

#include <boost/lexical_cast.hpp> 
#include <string> 
#include <iostream> 
int main() 
{ 
  try 
  { 
    int i = boost::lexical_cast<int>("abc"); 
    std::cout << i << std::endl; 
  } 
  catch (boost::bad_lexical_cast &e) 
  { 
    std::cerr << e.what() << std::endl; 
  } 
} 

三、更多示例代碼

本例由于字符串 "abc" 不能轉(zhuǎn)換為int類型的數(shù)字而拋出異常。

示例 54.1。使用 dynamic_cast 向下和交叉投射

struct base1 { virtual ~base1() = default; };
struct base2 { virtual ~base2() = default; };
struct derived : public base1, public base2 {};
void downcast(base1 *b1)
{
  derived *d = dynamic_cast<derived*>(b1);
}
void crosscast(base1 *b1)
{
  base2 *b2 = dynamic_cast<base2*>(b1);
}
int main()
{
  derived *d = new derived;
  downcast(d);
  base1 *b1 = new derived;
  crosscast(b1);
}

Example54.1

示例 54.1 兩次使用了轉(zhuǎn)換運(yùn)算符 dynamic_cast:在 downcast() 中,它將指向基類的指針轉(zhuǎn)換為指向派生類的指針。在 crosscast() 中,它將指向基類的指針轉(zhuǎn)換為指向不同基類的指針。第一個(gè)轉(zhuǎn)換是向下轉(zhuǎn)換,第二個(gè)轉(zhuǎn)換是交叉轉(zhuǎn)換。 Boost.Conversion 中的轉(zhuǎn)換運(yùn)算符讓您可以區(qū)分向下轉(zhuǎn)換和交叉轉(zhuǎn)換。

示例 54.2。使用 polymorphic_downcast 和 polymorphic_cast 進(jìn)行向下和交叉轉(zhuǎn)換

#include <boost/cast.hpp>
struct base1 { virtual ~base1() = default; };
struct base2 { virtual ~base2() = default; };
struct derived : public base1, public base2 {};
void downcast(base1 *b1)
{
  derived *d = boost::polymorphic_downcast<derived*>(b1);
}
void crosscast(base1 *b1)
{
  base2 *b2 = boost::polymorphic_cast<base2*>(b1);
}
int main()
{
  derived *d = new derived;
  downcast(d);
  base1 *b1 = new derived;
  crosscast(b1);
}

boost::polymorphic_downcast(參見示例 54.2)只能用于向下轉(zhuǎn)型,因?yàn)樗褂?static_cast 來(lái)執(zhí)行轉(zhuǎn)換。因?yàn)?static_cast 不會(huì)動(dòng)態(tài)檢查轉(zhuǎn)換的有效性,boost::polymorphic_downcast 必須僅在轉(zhuǎn)換安全時(shí)使用。在調(diào)試版本中,boost::polymorphic_downcast 使用 dynamic_cast 和 assert() 來(lái)確保類型轉(zhuǎn)換有效。只有在未定義宏 NDEBUG 時(shí)才會(huì)執(zhí)行此測(cè)試,這通常是調(diào)試版本的情況。

boost::polymorphic_cast 是交叉轉(zhuǎn)換所必需的。 boost::polymorphic_cast 使用 dynamic_cast,它是唯一可以執(zhí)行交叉轉(zhuǎn)換的轉(zhuǎn)換運(yùn)算符。最好使用 boost::polymorphic_cast 而不是 dynamic_cast,因?yàn)榍罢咴诔霈F(xiàn)錯(cuò)誤時(shí)拋出 std::bad_cast 類型的異常,而 dynamic_cast 在類型轉(zhuǎn)換失敗時(shí)返回空指針。

僅使用 boost::polymorphic_downcast 和 boost::polymorphic_cast 來(lái)轉(zhuǎn)換指針;否則,使用 dynamic_cast。因?yàn)?boost::polymorphic_downcast 是基于 static_cast 的,所以它不能將基類的對(duì)象轉(zhuǎn)換為派生類的對(duì)象。此外,使用 boost::polymorphic_cast 轉(zhuǎn)換指針以外的類型沒有意義,因?yàn)槿绻D(zhuǎn)換失敗,dynamic_cast 將拋出 std::bad_cast 類型的異常。

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

相關(guān)文章

  • Linux中使用VS Code編譯調(diào)試C++項(xiàng)目詳解

    Linux中使用VS Code編譯調(diào)試C++項(xiàng)目詳解

    最近因?yàn)轫?xiàng)目的需求,需要在Linux下開發(fā)C++相關(guān)項(xiàng)目,經(jīng)過(guò)一番摸索最終實(shí)現(xiàn)了,下面這篇文章就給大家簡(jiǎn)單總結(jié)了一下如何通過(guò)VS Code進(jìn)行編譯調(diào)試的一些注意事項(xiàng)。有需要的朋友們可以參考借鑒,下面來(lái)跟著小編一起看看吧。
    2016-12-12
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)不掛科指南之隊(duì)列詳解

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)不掛科指南之隊(duì)列詳解

    這篇博客主要介紹一下隊(duì)列的概念,并且采用 C 語(yǔ)言,編寫兩種存儲(chǔ)實(shí)現(xiàn)方式:順序存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ),當(dāng)然還有常規(guī)的隊(duì)列基本操作的實(shí)現(xiàn)算法
    2022-09-09
  • C語(yǔ)言實(shí)現(xiàn)SM4加解密方式

    C語(yǔ)言實(shí)現(xiàn)SM4加解密方式

    這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)SM4加解密方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • C++實(shí)現(xiàn)String類實(shí)例代碼

    C++實(shí)現(xiàn)String類實(shí)例代碼

    這篇文章主要介紹了C++實(shí)現(xiàn)String類實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)項(xiàng)目

    C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)項(xiàng)目

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)項(xiàng)目,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • c++中for雙循環(huán)的那些事

    c++中for雙循環(huán)的那些事

    本人很菜,今天看《C++編程思想》中的一道課后題中說(shuō)到這樣一個(gè)問(wèn)題。修改兩層嵌套的for循環(huán)的標(biāo)識(shí)符,觀察結(jié)果變化
    2013-05-05
  • 快速解決boost庫(kù)鏈接出錯(cuò)的問(wèn)題(分享)

    快速解決boost庫(kù)鏈接出錯(cuò)的問(wèn)題(分享)

    下面小編就為大家?guī)?lái)一篇快速解決boost庫(kù)鏈接出錯(cuò)的問(wèn)題(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • C++?LeetCode1827題解最少操作使數(shù)組遞增

    C++?LeetCode1827題解最少操作使數(shù)組遞增

    這篇文章主要為大家介紹了C++?LeetCode1827題解最少操作使數(shù)組遞增示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • C++中 set的用法

    C++中 set的用法

    這篇文章主要介紹了C++中 set的用法,set的內(nèi)部使用了紅黑樹對(duì)所有的元素進(jìn)行了排序。在樹結(jié)構(gòu)當(dāng)中,我們通常使用的都是<key, value>的形式。下面我們來(lái)看看該內(nèi)容的具體情況,需要的朋友也可以參考一下
    2021-11-11
  • 雙緩沖解決VC++繪圖時(shí)屏幕閃爍

    雙緩沖解決VC++繪圖時(shí)屏幕閃爍

    相信很多人在做圖形界面開發(fā)時(shí),常常會(huì)遇到屏幕閃爍的情況,當(dāng)然我也不例外,下面我們就來(lái)詳細(xì)探討下這個(gè)問(wèn)題的解決辦法
    2015-08-08

最新評(píng)論