C++類型轉(zhuǎn)換運算符的實例詳解
C++類型轉(zhuǎn)換運算符的實例詳解
C++中有4個類型轉(zhuǎn)換運算符,使裝換過程更規(guī)范
dynamic_cast;
const_cast;
static_cast;
reinterpret_cast;
一、dynamic_cast
該運算符我在之前的文章中已經(jīng)介紹過了
http://www.dhdzp.com/article/123252.htm
總之,該運算符的語法如下:
dynamic_cast < type-name> (expression)
如果轉(zhuǎn)型失敗則返回0,即空指針。
該運算符的用途是,使得能夠在類層次結(jié)構(gòu)中進行向上轉(zhuǎn)換(由于 is-a關(guān)系,這樣的類型轉(zhuǎn)換時安全的),而不允許其他轉(zhuǎn)換。
二、const_cast
const_cast運算符用于執(zhí)行只有一種用途的類型轉(zhuǎn)換,即改變值為const 或 volatile,其語法與dynamic_cast運算符相同。
const_cast < type-name > (expression)
如果類型的其他方面也被修改,則上述類型轉(zhuǎn)換將出錯。也就是說,除了const或volatile特征(有或無)可以不同外,type_name 和expression的類型必須相同
另外const_cast不是萬能的。它可以修改指向一個值的指針,但修改const值的結(jié)果是不確定的。
using std::cout;
using std::endl;
void change(const int *pt, int n);
int main()
{
int pop1 = 38383;
const int pop2 = 2000;
cout << "pop1,pop2: " << pop1 << " , " << pop2 << endl;
change(&pop1, -103);
change(&pop2, -103);
cout << " pop1, pop2: " << pop1 << " , " << pop2 << endl;
system("pause");
return 0;
}
void change(const int *pt, int n) {
int *pc;
pc = const_cast<int *>(pt);
*pc += n;
}
運行結(jié)果:
pop1,pop2: 38383 , 2000 pop1, pop2: 38280 , 2000 請按任意鍵繼續(xù). . .
可以看到調(diào)用change()時,修改了pop1,但沒有修改pop2。咋change()中,指正被聲明為const int * ,因此不能用來修改指向的 int 。指針pc刪除了 const特性,因此可用來修改指向的值,但僅當執(zhí)行的值不少const時才行,因此,pc可用來修改pop1,單不能修改pop2.
三、static_cast
static_cast運算符的語法與其他類型轉(zhuǎn)換運算符相同
static_cast< type-name > (expression)
僅當 type-name可被隱式轉(zhuǎn)換為expression所屬類型或expression可被隱式轉(zhuǎn)換為type-name所屬的類型時,上述轉(zhuǎn)換才是合法的,否則將出錯。
High bar; Low blow; ... High *pb = static_cast<High *>( &blow) //合法 Low *pl = static_cast< Low *> (&bar) //合法 Pond *pmer = static_cast< Pond * > (& blow) ;//非法
四、reinterpret_cast
reinterpret_cast運算符用于天生危險的類型轉(zhuǎn)換。
用法:
reinterpret_cast < type-name >(expression)
示例:
struct dat {short a;short b;} ;
long value = 0xA224B118;
dat * pd = reinterpret_cast <dat *> (&value);
cout <<hex <<pd->a ; //顯示前2個字節(jié)的值
然而,reinterpret_cast運算符并不支持所有的類型轉(zhuǎn)換。例如,可以將指針類型轉(zhuǎn)換為足以存儲指針表示的整形,但不能將指針轉(zhuǎn)換為更小的整型或浮點型。另一個限制是,不能將函數(shù)指針轉(zhuǎn)換為數(shù)據(jù)指針,反之亦然。
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
詳解C++模擬實現(xiàn)priority_queue(仿函數(shù))
本文主要介紹了關(guān)于C++中優(yōu)先級隊列的模擬實現(xiàn),以及仿函數(shù)的使用,優(yōu)先級隊列是一種容器適配器,其第一個元素總是最大的,仿函數(shù)本質(zhì)是一個類,重載了operator(),可改變比較邏輯,同時,文中還介紹了如何進行類的比較,如日期類或其指針的比較,以及庫中sort函數(shù)的使用方法2024-10-10
探討:用兩個棧實現(xiàn)一個隊列(我作為面試官的小結(jié))
作為面試官的我,經(jīng)常拿這道用兩個棧實現(xiàn)一個隊列的面試題來考面試者,通過對面試者的表現(xiàn)和反應,有一些統(tǒng)計和感受,在此做個小結(jié)2013-05-05
Qt串口通信開發(fā)之QSerialPort模塊Qt串口通信接收數(shù)據(jù)不完整的解決方法
這篇文章主要介紹了Qt串口通信開發(fā)之QSerialPort模塊Qt串口通信接收數(shù)據(jù)不完整的解決方法,需要的朋友可以參考下2020-03-03
C++利用數(shù)組(一維/二維)處理批量數(shù)據(jù)的方法
對于簡單的問題,使用簡單的數(shù)據(jù)類型就可以了,但是對于有些需要處理的數(shù)據(jù),只用以上簡單的數(shù)據(jù)類型是不夠的,難以反映出數(shù)據(jù)的特點,也難以有效的進行處理,本文小編給大家介紹了C++利用數(shù)組(一維/二維)處理批量數(shù)據(jù)的方法,需要的朋友可以參考下2023-10-10

