您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“C++中命名的強制類型轉(zhuǎn)換方法”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
總結(jié)
命名的強制類型轉(zhuǎn)換:
形式:
cast-name<type>(expression);
type是強制轉(zhuǎn)換的類型,expression是強制轉(zhuǎn)換的值。如果type是引用類型,則結(jié)果是左值。case-name是C++四種轉(zhuǎn)換類型static_cast、dynamic_cast、const_cast和reinterpret_cast的一種。
static_cast
可以被用于強制隱形轉(zhuǎn)換(例如,non-const對象轉(zhuǎn)換為const對象,int轉(zhuǎn)型為double,等等)作用于對象,它還可以用于很多這樣的轉(zhuǎn)換的反向轉(zhuǎn)換 (例如,void*指針轉(zhuǎn)型為有類型指針,基類指針轉(zhuǎn)型為派生類指針),但是它不能將一個const對象轉(zhuǎn)型為non-const對象(只有 const_cast能做到),它最接近于C-style的轉(zhuǎn)換。應(yīng)用到類的指針上,意思是說它允許子類類型的指針轉(zhuǎn)換為父類類型的指針(這是一個有效的隱式轉(zhuǎn)換),同時,也能夠執(zhí)行相反動作:轉(zhuǎn)換父類為它的子類。
int i; float j = 10.2; i = const_cast<int>(j); // 將j轉(zhuǎn)換int型賦值給i,損失了一定的精度
const_cast
一般用于強制消除對象的常量性。它是唯一能做到這一點的C++風(fēng)格的強制轉(zhuǎn)型。這個轉(zhuǎn)換能剝離一個對象的const屬性,也就是說允許你對常量進行修改。不能使用const_cast改變表達式的類型, const_cast的類型只能是指針,引用或指向?qū)ο箢惓蓡T的指針
const int constant = 21; int* modifier = const_cast<int*>(&constant); // 舊版的寫法 int* modifier = (int*)(&constant) *modifier = 7; std::cout << modifier << std::endl; // 測試輸出的地址為0x61feec std::cout << &constant << std::endl; // 測試輸出的地址為0x61feec std::cout << *modifier << std::endl; // 輸出的值為 7 std::cout << constant << std::endl; // 輸出的值為 21 // 上面可以看出,兩個指針指向同一塊地址,但是解引用的結(jié)果確不相同。 // const的值,是不能真的被改變。但是可以對可以對modifier進行重新賦值
const_cast常用的情況:
/* 我們可能調(diào)用了一個參數(shù)不是const的函數(shù),而我們要傳進去的實際參數(shù)確實const的,但是我們知道這個函數(shù)是不會對參數(shù)做修改的。于是我們就需要使用const_cast去除const限定,以便函數(shù)能夠接受這個實際參數(shù) */ #include <iostream> using namespace std; void Printer (int* val,string seperator = "\n") { cout << val << seperator; } int main(void) { const int consatant = 20; //Printer(consatant); //Error: invalid conversion from 'int' to 'int*' Printer(const_cast<int *>(&consatant)); return 0; }
reinterpret_cast
**作用于底層二進制。**是特意用于底層的強制轉(zhuǎn)型,導(dǎo)致實現(xiàn)依賴(就是說,不可移植)的結(jié)果,例如,將一個指針轉(zhuǎn)型為一個整數(shù)。這樣的強制類型在底層代碼以外應(yīng)該極為罕見。操作結(jié)果只是簡單的從一個指針到別的指針的值得二進制拷貝。在類型之間指向的內(nèi)容不做任何類型的檢查和轉(zhuǎn)換。將一個指針轉(zhuǎn)換成其他類型的指針。reinterpret_cast被作為二進制轉(zhuǎn)換重新解釋(沒有數(shù)位損失)。
int j; int *p = new(int); // j = p; // error: invalid conversion from 'int*' to 'int' [-fpermissive] j = reinterpret_cast<int>(p); //將指針類型,轉(zhuǎn)換成int型 std::cout << j << std::endl; // 輸出int型的結(jié)果
dynamic_cast
主要用于執(zhí)行“安全的向下轉(zhuǎn)型(safe downcasting)”,也就是說,要確定一個對象是否是一個繼承體系中的一個特定類型。支持父類指針到子類指針的轉(zhuǎn)換,這種轉(zhuǎn)換時最安全的轉(zhuǎn)換。它 是唯一不能用舊風(fēng)格語法執(zhí)行的強制類型轉(zhuǎn)換,也是唯一可能有重大運行時代價的強制轉(zhuǎn)換。
【擴展】 舊版的強制類型轉(zhuǎn)換
在早期的C++語言中,顯示地進行強制類型轉(zhuǎn)換包含兩種形式:
type (expr); // 函數(shù)形式的強制類型轉(zhuǎn)換 (type) expr; // 變量類型的強制類型轉(zhuǎn)換
根據(jù)涉及的類型不同,舊式的強制類型轉(zhuǎn)換分別與static_cast、const_cast或reinterpret_cast有相似的行為。當(dāng)我們在某處執(zhí)行舊式的強制類型轉(zhuǎn)換時,如果能換成static_cast、const_cast也合法,則其行為與對應(yīng)的命名轉(zhuǎn)換一致。如果替換不合法,則舊式指針強制轉(zhuǎn)換類型與reinterpret_cast類似的功能。
如:
char *pc = (char*)ip; // ip是指向整數(shù)的指針 char *pc = reinterpret_cast<char*>(ip) // 等價與上面的式子
“C++中命名的強制類型轉(zhuǎn)換方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。