www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]C++11的模板類型判斷——std::is_same和std::decay問題提出:有一個模板函數(shù),函數(shù)在處理int型和double型時需要進行特殊的處理,那么怎么在編譯期知道傳入的參數(shù)的數(shù)據(jù)類型是i

C++11的模板類型判斷——std::is_same和std::decay

問題提出:有一個模板函數(shù),函數(shù)在處理int型和double型時需要進行特殊的處理,那么怎么在編譯期知道傳入的參數(shù)的數(shù)據(jù)類型是int型還是double型呢?
如:

#includetemplatevoid?typeCheck(TYPE?data)
{
????//do?something?check?data?type
????//std::cout<<?out?put?the?type
}

這里就需要用到C++11的type_traits頭文件了,type_traits頭文件定義了很多類型檢查相關(guān)的方法,上面的例子具體用到了其中兩個結(jié)構(gòu):

std::is_same 判斷類型是否一致

位于頭文件中

這個結(jié)構(gòu)體作用很簡單,就是兩個一樣的類型會返回true

bool?isInt?=?std::is_same::value;?//為true

下面是官方的例子:

#include#include#includevoid?print_separator()
{
????std::cout?<<?"-----n";
}

int?main()
{
????std::cout?<<?std::boolalpha;

????std::cout?<<?std::is_same::value?<<?'n';???//?true
????std::cout?<<?std::is_same::value?<<?'n';???//?false
????std::cout?<<?std::is_same::value?<<?'n';?//?false

????print_separator();

????std::cout?<<?std::is_same::value?<<?"n";??????????//?true
????std::cout?<<?std::is_same::value?<<?"n";?//?false
????std::cout?<<?std::is_same::value?<<?"n";???//?true

????print_separator();

????//?unlike?other?types?'char'?is?not?'unsigned'?and?not?'signed'
????std::cout?<<?std::is_same::value?<<?"n";??????????//?true
????std::cout?<<?std::is_same::value?<<?"n";?//?false
????std::cout?<<?std::is_same::value?<<?"n";???//?false
}

通過std::is_same即可判斷兩個類型是否一樣,特別在模板里面,在不清楚模板的參數(shù)時,此功能可以對一些特定的參數(shù)類型進行特殊的處理。

這里說個題外話,大家是否通過std::is_same發(fā)現(xiàn),char既不是unsigned char也不是signed char,char就是char,這和int是signed int的縮寫是不一樣的,char的表達范圍可能等同于signed char,也可能等同于unsigned char,取決于編譯器,一般是等同于signed char,但這個僅僅是范圍等同,就像32位上int和long范圍是一樣的,但不是同一個類型。

因為用途不同,char用于表達字符,理論上不應(yīng)該關(guān)心其正負(fù)的實現(xiàn),而signed char 和 unsigned char 用于表達數(shù)值,或可移植的char。

回到正文,std::is_same可以判斷兩種類似是否一樣,那么用在模板里就是利器了,本位一開始提到的那個問題就可以這樣寫:

#includetemplatetypeCheck(TYPE?data)
{
????if(std::is_same::value)
????{
????????std::cout<<"int?type";
????????//do?something?int?
????}
????else
????{
????????//.........
????}
}

視乎很美好,再看一個示例:

//?is_same?example
#include#include#includetypedef?int?integer_type;
struct?A?{?int?x,y;?};
struct?B?{?int?x,y;?};
typedef?A?C;

int?main()?{
??????std::cout?<<?std::boolalpha;
??????std::cout?<<?"is_same:"?<<?std::endl;
??????std::cout?<<?"int,?const?int:?"?<<?std::is_same::value?<<?std::endl;//false
??????std::cout?<<?"int,?int&:?"?<<?std::is_same::value?<<?std::endl;//false
??????std::cout?<<?"int,?const?int&:?"?<<?std::is_same::value?<<?std::endl;//false
??????std::cout?<<?"int,?integer_type:?"?<<?std::is_same::value?<<?std::endl;//true
??????std::cout?<<?"A,?B:?"?<<?std::is_same::value?<<?std::endl;//false
??????std::cout?<<?"A,?C:?"?<<?std::is_same::value?<<?std::endl;//true
??????std::cout?<<?"signed?char,?std::int8_t:?"?<<?std::is_same::value?<<?std::endl;//true
??????return?0;
}

輸出:

is_same:
int,?const?int:?false
int,?int&:?false
int,?const?int&:?false
int,?integer_type:?true
A,?B:?false
A,?C:?true
signed?char,?std::int8_t:?true

發(fā)現(xiàn)std::is_same的判斷是很嚴(yán)格的
但是有時候在編輯模板的時候又發(fā)現(xiàn)用std::is_same的判斷太過嚴(yán)格,還是之前的例子:

#include#include#includetemplatevoid?typeCheck(TYPE?data);

int?_tmain(int?argc,?_TCHAR*?argv[])
{
????int?a?=?1;
????const?int&?b?=?a;
????int&?c?=?a;
????int?d[12];
????const?int&?e?=?d[7];
????typeCheck(a);//int?type
????typeCheck(b);//int?type
????typeCheck(c);//int?type
????typeCheck(d[7]);//int?type
????typeCheck(e);//int?type
????typeCheck(8);//int?type
????system("pause");
????return?0;
}

templatevoid?typeCheck(TYPE?data)
{
????if(std::is_same::value)
????{
????????std::cout<<"int?type"<<std::endl;
????}
????else?if(std::is_same::value)
????{
????????std::cout<<"string?type"<<std::endl;
????}
????else
????{
????????std::cout<<"other?type";
????}
}

輸出:

int?type
int?type
int?type
int?type
int?type
int?type

測試后發(fā)現(xiàn),雖然變量b,c使用引用,但std::is_same還是能識別出來的,但是?。?
如果我顯示的指定模板參數(shù)類型時情況有不一樣了:

#include#include#includetemplatevoid?typeCheck(TYPE?data);

int?_tmain(int?argc,?_TCHAR*?argv[])
{
????int?a?=?1;
????const?int&?b?=?a;
????int&?c?=?a;
????int?d[12];

????typeCheck(a);????????//int?type
????typeCheck(b);//other?type
????typeCheck(c);????????//other?type
????typeCheck(d[7]);//other?type
????typeCheck(8);????????????????//int?type
????system("pause");
????return?0;
}

templatevoid?typeCheck(TYPE?data)
{
????if(std::is_same::value)
????{
????????std::cout<<"int?type"<<std::endl;
????}
????else?if(std::is_same::value)
????{
????????std::cout<<"string?type"<<std::endl;
????}
????else
????{
????????std::cout<<"other?type";
????}
}

輸出:

int?type
other?type
other?type
other?type
int?type

瞬間結(jié)果就不一樣了,這很好了解,從上面可知道,std::is_same對int和const intint &const int&等都是區(qū)別對待的,但在寫模板函數(shù)時,經(jīng)常會強制指定常引用進行傳參,以免進行數(shù)據(jù)拷貝,這時候is_same就做出了不相等的判斷,但是有時候其實我們還是希望TYPE和const TYPE& 是能認(rèn)為是一樣的,這時就需要std::decay進行退化處理

std::decay 退化類型的修飾

std::decay就是對一個類型進行退化處理,他的實現(xiàn)如下:

template<?class?T?>
struct?decay?{
private:
????typedef?typename?std::remove_reference::type?U;
public:
????typedef?typename?std::conditional<?
????????std::is_array::value,
????????typename?std::remove_extent::type*,
????????typename?std::conditional<?
????????????std::is_function::value,
????????????typename?std::add_pointer::type,
????????????typename?std::remove_cv::type
????????>::type
????>::type?type;
};

看著比較抽象,其實就是把各種引用啊什么的修飾去掉,把cosnt int&退化為int,這樣就能通過std::is_same正確識別出加了引用的類型了
上面的例子改為:

#include?"stdafx.h"
#include#include#includetemplatevoid?typeCheck(TYPE?data);

int?_tmain(int?argc,?_TCHAR*?argv[])
{
????int?a?=?1;
????const?int&?b?=?a;
????int&?c?=?a;
????int?d[12];

????typeCheck(a);//int?type
????typeCheck(b);//int?type
????typeCheck(c);//int?type
????typeCheck(d[7]);//int?type
????typeCheck(8);//int?type
????system("pause");
????return?0;
}

templatevoid?typeCheck(TYPE?data)
{
????if(std::is_same<typename?std::decay::type,int>::value)
????{
????????std::cout<<"int?type"<<std::endl;
????}
????else
????{
????????std::cout<<"other?type"<<std::endl;
????}
}

在cppref有個更加詳細(xì)的例子:

#include#includetemplatestruct?decay_equiv?:?
????std::is_same<typename?std::decay::type,?U>::type?
{};

int?main()
{
????std::cout?<<?std::boolalpha
??????????????<<?decay_equiv::value?<<?'n'
??????????????<<?decay_equiv::value?<<?'n'
??????????????<<?decay_equiv::value?<<?'n'
??????????????<<?decay_equiv::value?<<?'n'
??????????????<<?decay_equiv::value?<<?'n'
??????????????<<?decay_equiv::value?<<?'n';
}

輸出:

true
true
true
true
true
true

總結(jié): 在模板里可以通過std::is_same判斷模板的類型,從而實現(xiàn)對不同類型的區(qū)別對待 在堆類型要求不是非常嚴(yán)格的情況下,可以使用std::decay把類型退化為基本形態(tài),結(jié)合std::is_same用,可以判斷出更多的情況

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉