C++ 的類型轉換詳解
一、C++ 類型轉換
1.靜態(tài)類型轉換
1.語法格式
static_cast<目標類型> (標識符)
2.轉化規(guī)則
在一個方向上可以作隱式轉換,在另外一個方向上就可以作靜態(tài)轉換。
int a = 10; int b = 3; cout<<static_cast<float>(a)/b<<endl; //float = int int = float return 0;
int *p; void *q; p = static_cast<int*>(q);
char *p = static_cast<char*>(malloc(100));
2.重解釋類型轉換
1.語法格式
reinterpret_cast<目標類型> (標識符)
2.轉化規(guī)則
將數(shù)據(jù)以二進制存在形式的重新解釋,在雙方向上都不可以隱式類型轉換的,則需要重解釋類型轉換
#include <iostream>
#include <string.h>
using namespace std;
int main()
{
int x = 0x12345648;
char *p = reinterpret_cast<char*>(&x);
//char*p = static_cast<char*>(&x); error
printf("%x\n",*p);
int a[5] = {1,2,3,4,5};
int *q = reinterpret_cast<int*>(a+1);
printf("%x\n",*q);
return 0;
}

3.常類型轉換
1.語法格式
const_cast<目標類型> (標識符) //目標類類型只能是指針或引用。
2.語法規(guī)則
用來移除對象的常量性使用 const_cast 去除 const 限定的,目的不是為了修改它的內容,使用 const_cast 去除 const 限定,通常是為了函數(shù)能夠接受這個實際參數(shù)。
#include <iostream>
using namespace std;
void func(int & ref) //別人己經(jīng)寫好的程序或類庫
{
cout<<ref<<endl;
}
int main(void)
{
const int m = 1;
func(const_cast<int&>(m));
return 0;
}
脫掉const后的引用或指針可以改嗎
#include <iostream>
using namespace std;
int main()
{
const int x = 200;
int & a =const_cast<int&>(x); // int &a = x;
a = 300;
cout<<a<<x<<endl;
cout<<&a<<"---"<<&x<<endl;
int *p =const_cast<int*>(&x); // int *p = &x;
*p = 400;
cout<<a<<*p<<endl;
cout<<p<<"---"<<&x<<endl;
struct A
{
int data;
};
const A xx = {1111};
A &a1 = const_cast< A&>(xx);
a1.data = 222;
cout<<a1.data<<xx.data<<endl;
A *p1 = const_cast<A*>(&xx);
p1->data = 333;
cout<<p1->data<<xx.data<<endl;
return 0;
}

結論:可以改變 const 自定義類的成員變量,但是對于內置數(shù)據(jù)類型,卻表現(xiàn)未定義行為
3.const 常變量(補充)
C++中 const 定義的變量稱為常變量。變量的形式,常量的作用,用作常量,常用于取代#define 宏常量
4.動態(tài)類型轉換
1.語法格式
dynamic_cast<目標類型> (標識符)
用于多態(tài)中的父子類之間的強制轉化
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
for循環(huán)中刪除map中的元素valgrind檢測提示error:Invalid read of size 8
這篇文章主要介紹了for循環(huán)中刪除map中的元素valgrind檢測提示error:Invalid read of size 8 的相關資料,需要的朋友可以參考下2016-07-07
C++實現(xiàn)LeetCode(23.合并k個有序鏈表)
這篇文章主要介紹了C++實現(xiàn)LeetCode(23.合并k個有序鏈表),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下2021-07-07

