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

關(guān)于C++的強制類型轉(zhuǎn)換淺析

 更新時間:2017年09月10日 10:52:14   作者:Dawn_sf  
C++的強制類型轉(zhuǎn)換是我們在日常開發(fā)中經(jīng)常會遇到的,下面這篇文章主要給大家介紹了關(guān)于C++強制類型轉(zhuǎn)換的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

一說起強制類型轉(zhuǎn)換大家都很熟悉,相信很多學(xué)習(xí)完C++的朋友還在使用C語言的強制類型的方式 (類型)變量.

C++其實也具有自己的一套強制類型轉(zhuǎn)換它們分明是:static_cast  reinterpret_cast  const_cast  dynamic_cast四種類型.

那么肯定會有人好奇C++是不是閑,C語言的強制類型用的舒舒服服的,為什么要新推出來這幾個?

新類型的強制轉(zhuǎn)換可以提供更好的控制強制轉(zhuǎn)換過程,允許控制各種不同種類的強制轉(zhuǎn)換。C++中風(fēng)格是static_cast<type>。C++風(fēng)格的強制轉(zhuǎn)換其他的好處是,它們能更清晰的表明它們要干什么。程序員只要掃一眼這樣的代碼,就能立即知道一個強制轉(zhuǎn)換的目

的。

static_cast                                                                                              

static_cast用于非多態(tài)類型的轉(zhuǎn)換(靜態(tài)轉(zhuǎn)換),任何標(biāo)準(zhǔn)轉(zhuǎn)換都可以用它,但它不能用于兩個不相關(guān)的類型進行轉(zhuǎn)換.

何為不相關(guān)類型? 比如int 和 double char short就是相關(guān)類型. 和int*就是不相關(guān)類型.

我們來看一看static_cast的用法.  例如,通過將一個運算對象強制轉(zhuǎn)換成double類型就能使表達式執(zhí)行浮點數(shù)除法:

  double slope = static_cast<double>(j) / i;

當(dāng)static_cast需要把一個較大的算術(shù)類型賦值給較小的類型時,static_cast非常有用。此時,強制類型轉(zhuǎn)換告訴程序的讀者和編譯器:我們知道并且不在乎潛在的精度損失。一般來說,如果編譯器發(fā)現(xiàn)一個的算術(shù)類型試圖賦值給較小的類型,就會給出警告信息;但是當(dāng)我們執(zhí)行了顯式的類型轉(zhuǎn)換后,警告信息就會被關(guān)閉了。

reinterpret_cast                                                                                        

reinterpret_cast有著和C風(fēng)格的強制轉(zhuǎn)換同樣的能力。它可以轉(zhuǎn)化任何內(nèi)置的數(shù)據(jù)類型為其他任何的數(shù)據(jù)類型,也可以轉(zhuǎn)化任何指針類型為其他的類型。它甚至可以轉(zhuǎn)化內(nèi)置的數(shù)據(jù)類型為指針,無須考慮類型安全或者常量的情形。不到萬不得已絕對用。

因為reinterpret_cast是一個蠻bug的操作,下面我來演示一下.

typedef void (* FUNC)(); 
int DoSomething (int i) 
{ 
  cout<<"DoSomething" <<endl; 
  return 0; 
} 
void Test () 
{ 
  // reinterpret_cast可以編譯器以FUNC的定義方式去看待 DoSomething函數(shù) 
  // 所以非常的BUG,下面轉(zhuǎn)換函數(shù)指針的代碼是不可移植的,所以不建議這樣用 
  // C++不保證所有的函數(shù)指針都被一樣的使用,所以這樣用有時會產(chǎn)生不確定的結(jié)果 
  FUNC f = reinterpret_cast< FUNC>(DoSomething ); 
  f(); 
} 

當(dāng)你這樣運行的時候,你會發(fā)現(xiàn)通過函數(shù)指針沒有傳參數(shù)調(diào)用這個有參數(shù)的函數(shù)居然可以調(diào)用,這就很尷尬了,所以我告訴你不到萬不得已就不要使用reinterpret_cast

const_cast

對于將常量對象轉(zhuǎn)化為非常量對象的行為,我們一般稱之為“去掉const性質(zhì)”。一旦我們?nèi)サ袅四硞€對象的const性質(zhì),編譯器就不再阻止我們對該對象進行寫操作了。如果對象本身不是一個常量,使用強制類型轉(zhuǎn)換獲得寫權(quán)限是合法的行為。然而如果對象是一個常量,再使用const_cast執(zhí)行寫操作就會產(chǎn)生未定義的后果。

舉個例子:

#include<iostream> 
#include<Windows.h> 
#include<assert.h> 
 
using namespace std; 
 
int main() 
{ 
 const int a = 2; 
 int *p = const_cast<int*>(&a); 
 *p = 3; 
 cout << a << endl; 
 system("pause"); 
 return 0; 
} 

我們有理由的認(rèn)為在內(nèi)存當(dāng)中a的值被修改為3,但是結(jié)果呢? 我們來看一看

這不科學(xué)啊?? 我們再打開監(jiān)視窗口看一下a的值.

我們都知道監(jiān)視窗口看到的都是從內(nèi)存當(dāng)中拿到的,但是為什么內(nèi)存當(dāng)中為3,打印出來就是2呢? 我來解釋一下.

C++編譯器具有優(yōu)化功能,當(dāng)你定一個const的常量的時候,系統(tǒng)覺得它不會被改變了,于是做一個優(yōu)化把該常量存到寄存器當(dāng)中,下次訪問的過程更快速一點. 所以當(dāng)顯示窗口讀取數(shù)據(jù)的時候,他會直接去寄存器當(dāng)中讀取數(shù)據(jù).而不是去內(nèi)存,所以導(dǎo)致我們明明該掉了a的值,卻打印不出來,但是如何解決這個問題呢??

c++有一個關(guān)鍵字: volatile 該關(guān)鍵字的作用防止編譯器優(yōu)化,這個時候要輸出a就會老老實實的回內(nèi)存去查看.

#include<iostream> 
#include<Windows.h> 
#include<assert.h> 
 
using namespace std; 
 
int main() 
{ 
 volatile const int a = 2; 
 int *p = const_cast<int*>(&a); 
 *p = 3; 
 cout << a << endl; 
 system("pause"); 
 return 0; 
} 

dynamic_cast                                                                                           

前三種的強制類型轉(zhuǎn)換,他們能做到的C語言的強制類型轉(zhuǎn)換也大多能做到,最后一種C語言的強制類型轉(zhuǎn)換就沒有辦法了.

在類的轉(zhuǎn)換時,在類層次間進行上行轉(zhuǎn)換時,dynamic_cast和static_cast的效果是一樣的。在進行下行轉(zhuǎn)換時,dynamic_cast具有類型檢查的功能,比static_cast更安全。當(dāng)用于多態(tài)類型時,它允許任意的隱式類型轉(zhuǎn)換以及相反過程. 不過,與static_cast不同,在后一種情況里(注:即隱式轉(zhuǎn)換的相反過程),dynamic_cast 會檢查操作是否有效. 也就是說, 它會檢查轉(zhuǎn)換是否會返回一個被請求的有效的完整對象。檢測在運行時進行. 如果被轉(zhuǎn)換的指針不是一個被請求的有效完整的對象指針,返回值為NULL. 對于引用 類型,會拋出bad_cast異常

你說這個強轉(zhuǎn)有啥用,其實對于我這種菜鳥還真的沒用過,不過我知道一個問題可以使用這樣的方法解決. 給你兩個類讓你分辨那個是子類那個是父類,我們來看看是如何解決的.

#include<iostream> 
#include<Windows.h> 
#include<assert.h> 
 
using namespace std; 
 
class AA 
{ 
public: 
 
 virtual void fun1() 
 { 
  cout << "hehe" << endl; 
 } 
public: 
 int a; 
}; 
 
class BB :public AA 
{ 
public: 
 
 virtual void fun1() 
 { 
  cout << "heh2e" << endl; 
 } 
public: 
 int c; 
}; 
int main() 
{ 
 AA* q = new AA(); 
 BB* p = new BB(); 
 AA* a; 
 BB* b; 
 
 b = dynamic_cast<BB*>(q); 
 if (b == NULL) 
 { 
  cout << "AA為基類" << endl; 
 } 
 else{ 
  cout << "AA為子類" << endl; 
 } 
 
 a = dynamic_cast<AA*>(p); 
 if (a == NULL) 
 { 
  cout << "BB為基類" << endl; 
 } 
 else 
 { 
  cout << "BB為子類" << endl; 
 } 
 system("pause"); 
 return 0; 
} 

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • Qt學(xué)習(xí)教程之對話框消失動畫效果

    Qt學(xué)習(xí)教程之對話框消失動畫效果

    這篇文章主要給大家介紹了關(guān)于Qt學(xué)習(xí)教程之對話框消失動畫效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • C++ primer超詳細(xì)講解泛型算法

    C++ primer超詳細(xì)講解泛型算法

    泛型編程,故如其名,是一個泛化的編程方式。其實現(xiàn)原理為程序員編寫一個函數(shù)/類的代碼示例,讓編譯器去填補出不同的函數(shù)實現(xiàn)
    2022-07-07
  • C語言學(xué)習(xí)筆記之VS2022安裝使用教程

    C語言學(xué)習(xí)筆記之VS2022安裝使用教程

    這篇文章主要介紹了C語言學(xué)習(xí)筆記之VS2022安裝使用教程,在VS2022中,在使用scanf函數(shù)編譯出錯,本文給大家提到了解決方法,需要的朋友可以參考下
    2022-05-05
  • 全排列算法的原理和實現(xiàn)代碼

    全排列算法的原理和實現(xiàn)代碼

    這篇文章主要介紹了全排列算法的原理和實現(xiàn)代碼,全排列是將一組數(shù)按一定順序進行排列,如果這組數(shù)有n個,那么全排列數(shù)為n!個,需要的朋友可以參考下
    2014-08-08
  • C語言實現(xiàn)掃雷游戲(含注釋詳解)

    C語言實現(xiàn)掃雷游戲(含注釋詳解)

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)掃雷游戲,含注釋,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 關(guān)于C++虛函數(shù)與靜態(tài)、動態(tài)綁定的問題

    關(guān)于C++虛函數(shù)與靜態(tài)、動態(tài)綁定的問題

    這篇文章主要介紹了C++虛函數(shù)與靜態(tài)、動態(tài)綁定,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • MFC之ComboBox控件用法實例教程

    MFC之ComboBox控件用法實例教程

    這篇文章主要介紹了MFC之ComboBox控件用法,包括了ComboBox控件常見的各類用法,非常具有實用價值,需要的朋友可以參考下
    2014-09-09
  • C/C++?活動預(yù)處理器詳解

    C/C++?活動預(yù)處理器詳解

    預(yù)處理器是一些指令,指示編譯器在實際編譯之前所需完成的預(yù)處理,預(yù)處理的作用就是在代碼被編譯前對代碼做某些替換,這篇文章主要介紹了C/C++?活動預(yù)處理器,需要的朋友可以參考下
    2022-11-11
  • C語言判斷字符串是否回文三種方法實例

    C語言判斷字符串是否回文三種方法實例

    回文就是字符串中心對稱,從左向右讀和從右向左讀的內(nèi)容是一樣的,下面這篇文章主要給大家介紹了關(guān)于C語言判斷字符串是否回文的三種方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • 一文詳解C++關(guān)鍵字nullptr及與NULL的區(qū)別

    一文詳解C++關(guān)鍵字nullptr及與NULL的區(qū)別

    這篇文章主要給大家詳細(xì)介紹了C++關(guān)鍵字nullptr,及?NULL與nullptr的區(qū)別,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06

最新評論