成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

C++類型轉換基本概念淺談

開發 后端
C++類型轉換總共可以分為兩種,一個是顯式的類型轉換,另一種則是隱式的類型轉換。今天我們將會針對這些內容進行一個詳細介紹。

C++編程語言的應用,可以幫助開發人員大大提高程序開發效率。我們今天為大家介紹的有關C++類型轉換的相關內容,就是其中一個基礎應用技巧。希望大家可以充分掌握這方面的知識,以方便將來的引用。#t#

下面討論假設你已經了解C語言程序設計和初步的C++的知識。一般來說,類型轉換分為兩種,即顯式(Explicit)和隱式(Implicit)。

隱式類型轉換:其中,隱式的C++類型轉換相信大家都曾經用過甚至乎經常用,例如說把一個整形的變量賦給一個浮點數,或者在一個聲明采用整形參數的函數中,以浮點數作為參數。在這些類型中,也許你可能忽略掉,但實際上你是在做類型轉換,這不過是由系統自動完成而已。

顯式類型轉換:在C里面,你可以用(<data_type>)<Variable>這樣的形式,例如用(int)('c')這樣的手段來將一個字符變量或常量轉換成一個整形。這種稱為顯式類型轉換。

然后是類型兼容的問題,相信在所有的C或者C++入門教程里面都會涉及到這樣的課題,例如說你可以把一個浮點數轉換成一個整型來用,但是你不可以將一個整數指針轉換成一個浮點數來用,等等。實際上,對于類型轉換之間,轉換的兼容性是一個比較復雜的概念,但是由于這些復雜的類型轉換機構,使得C編程獲得了更大的靈活性。但是,在C++的OOP(面向對象編程)觀點看來,這無疑是一個很嚴重的漏洞,利用它,可以突破所有C++辛辛苦苦建立起來的類封裝,甚至是常數限制。

其實,最為尖銳的問題,就體現在了指針類型的強制轉換中。

希望讀者還記得C里面的malloc函數和void指針,在C里面,你可以暢通無阻地將一個void指針(當然,這甚至可以為任意類型的指針)轉換成任何的指針,然后讓指向并修改內存中的任意一段內存,在C里面,在動態內存分配處理上<malloc.h>上面就是這樣處理的。

但是,C++意識到了他其實是一個重大的漏洞,因為編程者可能在不經意間使用了這些危險的C++類型轉換,利用它不經意地訪問并修改了內存中一些你并不想修改但非常重要的數據單元,從而導致嚴重的崩潰。因此,在C++中,采取了幾個重要的手段來彌補這個漏洞:

首先,C++用 new 和 delete 關鍵字取締了原來拗口并且容易出錯的 malloc 方法,為動態分配內存提供了另一個方案來避免類型轉換;

其次,C++引進了常量模式(const),使得對于定義為 const 的變量和指針不可能被(輕易地)修改,編譯系統會截獲他們并給出錯誤信息;

在者,類封裝的訪問權限也很好的改善了這個情況。

但是,我們的使用者可能會發問:“假如我非得要用這些C++類型轉換,以完成一些特殊的工作的時候,應該怎么辦?”

答案肯定是有的,這就是 ISO C++ 提供的幾種顯示轉換,它可以突破類封裝甚至是常量限制。

這樣看來,C++ 對于它的封裝性,其實并不是絕對規定性的,它可以破例,即使用以下的關鍵字。但是他要求使用它的程序員必須清楚地知道他自己在干什么,因此對于強制類型轉換提供了四個模式。這樣有另一個好處,因為當程序員遇上錯誤的時候,這類危險的操作絕對是首選的嫌疑犯,通過查找這類關鍵字可以迅速的定位你的錯誤。下面是這四類顯示轉換的關鍵字:

static_cast: 用于良性轉換(一般的轉換,包括自動轉換),轉換的時候甚至可以不用這個關鍵字;

const_cast: 用于const/volatile與非const/volatile之間的轉換;

reinterpret_cast: 高度危險的重翻譯轉換,但可以實現最靈活的C++類型轉換;

dynamic_cast: 用于類型安全的向下轉換。

下面詳細討論前面三種類型轉換:

上面的顯示類型轉換函數都是要求用模版格式的,例如下文中下劃線的地方注意:

 

  1. // static_cast: 良性及適度良性轉換,安全級:高  
  2. int num1=50; int a[20];  
  3. long num2 = static_cast<long>(num1); 
    // 寬化轉換,沒有信息丟失  
  4. char num3 = static_cast<char>(num3); 
    // 窄化轉換,有信息丟失,具體轉換規則請參考相關教程  
  5. void* p = static_cast<void*>(a); 
    // 使用void*的強制變換,允許  
  6. float* q = static_cast<float*>(p); 
    // 使用void*的強制變換,允許  
  7. // float* r = static_cast<float*>(a); 
    // 錯誤,沒有經過void*的強制指針類型變換,不允許 

 

——上面即為static_cast的用法,只能用于賦值兼容的C++類型轉換,否則不能使用,安全級最高,編譯器會攔截所有超出安全級別的類型轉換。

 

  1. // const_cast:用于const/volatile與非const/volatile之間的轉換,安全級:中  
  2. const int a = 50; volatile int b = 100;  
  3. int* p = const_cast<int*>(&a); *p = 51;  
  4. cout << "a=" << a << endl; // 正確的輸出a應該沒有變動,a=50 
  5. cout << "*p=" << *p <<endl
    // 但是神奇的是 *
    p=51,內存已經變了,但是不會刷新到const a上面  
  6. int* q = const_cast<int*>(&b); *q = 101;  
  7. cout << "b=" << b << endl
    // 用volatile的話,隨時刷新,因此輸出
    b=101,已經改變  
  8. cout << "*q=" << *q << endl; // 這時候*q自然也是*q=101 

 

——上面可以看到,如果使用const_cast進行顯式強制類型轉換,可以突破C++的常數限制,修改const指向的內存,因此有一定的危險性,但是一個程序員如果這樣做的話,基本上是會意識到這個問題的,因此也還有一定的安全性。

 

  1. // reinterpret_cast:最最危險的,也是最最靈活,最最萬能的轉換方式,安全級:低  
  2. char str[]="This is a string.";  
  3. float* r = reinterpret_cast<float*>(str); 
    // 使用reinterpret_cast的話,這也將是合法的 

 

——因此,為了安全的使用reinterpret_cast,必須在結束的時候把變量轉換成它原本的類型,可以想象,用一個float指針來操作一個char數組是一件多么無稽,也是多么危險的事情,因此,這樣的轉換方式不再萬不得已的時候不要使用,如果有需要使用的時候,先想想有沒有別的辦法。

但是畢竟,我們在某些場合,還是不得不使用這種方法,這種方法的靈活性甚至可以直接穿透一個繼承類的封裝,直接從內存訪問其保護成員變量,甚至可以穿透到基類的私有級別變量,要知道,用一般的方法,這根本不可能實現。

實際上,上面的顯示C++類型轉換只是一個習慣,其實大可以不作這樣的顯示類型轉換聲明,只不過后果可能比較嚴重,尤其是對經驗不豐富的程序員來說。可以想象當你的程序遇到奇怪的運行錯誤甚至是崩潰的時候,最大危險的地方很有可能就出現在這些莫名其妙的類型轉換中,假如在編碼的時候沒有讓自己充分地意識到這個問題,也許你的程序崩潰會傳染給你本人(你自己也一起崩潰(~_~)),但如果意識到了這類問題,并且在編碼中用上述提倡的顯式類型轉換標識你的代碼,這樣也許你會很快的查找到錯誤的所在。

C的這種靈活性也許正成為了它最為人所詬病的地方,靈活性是一面雙刃劍,也許體會到這種用法的優點,才算是從C上升到了C++

責任編輯:曹凱 來源: 博客園
相關推薦

2010-02-04 17:39:48

C++字符串類型

2010-02-03 13:22:07

C++時間

2010-02-05 12:57:20

C++ kdevelo

2010-02-02 10:33:22

C++引用

2010-02-02 13:41:01

C++類繼承

2010-02-02 15:30:05

C++ include

2010-02-01 17:24:41

C++循環語句

2010-02-03 14:36:47

C++仿函數

2010-02-05 17:34:37

C++函數模板

2010-02-06 14:04:58

C++內存使用機制

2010-02-04 13:56:24

C++類模板特化

2010-02-04 10:08:00

C++靜態成員函數

2010-02-01 14:07:12

C++多態性

2010-02-04 14:01:43

C++非類型類模板參數

2010-02-06 15:58:10

C++集合初始化

2011-07-14 10:39:08

強制類型轉換函數C++

2010-02-04 17:32:43

C++中C風格字符串

2010-03-01 14:50:30

WCF行為類型

2017-05-02 14:45:11

深度學習機器學習人工神經網絡

2011-03-28 11:05:17

ODBC
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一级在线观看 | 欧美一区二区三区在线视频 | 国产偷录视频叫床高潮对白 | 在线免费国产视频 | 国产69精品久久99不卡免费版 | 91久久久久久久久久久 | 亚洲不卡在线观看 | 国产精品99久久久久久久久久久久 | 成人性生交大片免费看中文带字幕 | 亚洲精品在线看 | 久久久免费毛片 | 国产欧美在线观看 | 国产成人精品一区二区三区视频 | 久草.com | 伊人伊成久久人综合网站 | 亚洲巨乳自拍在线视频 | 91人人视频在线观看 | 在线中文字幕第一页 | 一区免费 | 国产偷录视频叫床高潮对白 | 国产视频1区 | 免费一级黄色录像 | 国产97人人超碰caoprom | 97精品国产97久久久久久免费 | 一区二区三区四区在线 | 九九热视频这里只有精品 | 美日韩免费视频 | 国产在线不卡视频 | 国精产品一区二区三区 | 欧美在线a | 麻豆av一区二区三区久久 | 一区二区免费看 | 精品一二三区视频 | 成人在线免费 | 欧美一区二区三区在线视频 | cao在线| 国产高清在线精品一区二区三区 | 国产精品日产欧美久久久久 | 日韩最新网址 | 一区二区激情 | 中文字幕在线看人 |