C++迭代器和顯示類型轉(zhuǎn)換方式
1.迭代器
其實迭代器很簡單,沒有我們想象中的那么復雜。
以前要讀寫數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù),一般是通過移動指針來進行的,但是在編寫指針的過程中難免會出現(xiàn)野指針等情況出現(xiàn),而且指針用起來也相對復雜。
這時候,神奇的迭代器出現(xiàn)了。
迭代器是指針的一個泛化,在容器和算法之間充當橋梁的作用。
區(qū)別于指針,迭代器本身重載的“++”和“–”操作符,能夠直接指向前驅(qū)和后繼節(jié)點。
2.顯式類型轉(zhuǎn)換
將一種類型轉(zhuǎn)換成另一種類型,在程序中很常見,轉(zhuǎn)換后的類型變量,它的內(nèi)部存儲方式一般也隨之改變。
C++提供了四種顯式的類型轉(zhuǎn)換操作函數(shù)reinterpret_cast、const_cast、static_cast和dynamic_cast。
前三個類型的轉(zhuǎn)換是在編譯的時候進行類型轉(zhuǎn)換,最后一個則是在運行的時候進行類型轉(zhuǎn)換,并可返回轉(zhuǎn)換成功與否的標志。
2.1 reinterpret_cast
**reinterpret_cast類型轉(zhuǎn)換函數(shù)將一個類型的指針轉(zhuǎn)換為另一個類型的指針。
**這種轉(zhuǎn)換不用修改指針變量值數(shù)據(jù)存放格式(不改變指針變量的值),也不能把const指針轉(zhuǎn)換成void*指針,只需在編譯時重新解釋指針的類型就行。
double d = 9.3;
double *pd = &d;
int *pi = reinterpret_cast<int* >(pd); //相當于隱式轉(zhuǎn)換int *pi = (int*)pd;
class A{};
class B{};
A *pa = new A;
B *pb = reinterpret_cast<B* >(pa); //相當于隱式轉(zhuǎn)換B* pb = (B* )pa;
long j = reinterpret_cast<long>(pi); //相當于long j = (long)pi;
2.2const_cast
const_cast用于去除指針變量的常量屬性,將它轉(zhuǎn)換為一個對應指針類型的普通變量,反過來也成立。
const int* pci =0;
int *pj = const_cast<int *>(pci); //相當于int* pj = (int*)pci;
const A* pca = new A;
A* pa = const_cast<A*>(pca); //相當于A* pa = (A*)pca;
const_cast只是針對于指針操作,無法將非指針的常變量轉(zhuǎn)換為普通變量。
int* pi = 0;
const int* pcj = const_cast<const int* >(pi);//將普通指針轉(zhuǎn)換為常量指針
int i=0;
const int cj = const_cast<const int>(i);//非指針轉(zhuǎn)換為const指針,不能通過編譯!
const int ck = (const int)i;//隱式轉(zhuǎn)換,可通過編譯
2.3 static_cast
static_cast一般用于基本類型之間和具有繼承關(guān)系之間的類型轉(zhuǎn)換,這種轉(zhuǎn)換一般會更改變量的內(nèi)部表示方式。
一般不用于指針類型轉(zhuǎn)換。
int i = 0;
double d = static_cast<double>(i);//將i的int型轉(zhuǎn)換為double型然后賦值給d;
int j = static_cast<int>(j); //將double型轉(zhuǎn)換為int 型然后賦值給j;
class Base{};
class Derived:Base{};
Derived d;
Base b = static_cast<Base>(d);//將子類對象d轉(zhuǎn)換為父類然后賦值給b;
2.4 dynamic_cast
與上面三個不同,dynamic_cast是在運行的時候進行轉(zhuǎn)換分析的,上面三個是在編譯時進行。
dynamic_cast只能在繼承類對象的指針之間或引用之間進行類型轉(zhuǎn)換。
進行轉(zhuǎn)換時,會根據(jù)當前運行對象的運行時類型信息,判斷類型對象之間是否轉(zhuǎn)換合法。
dynamic_cast的指針轉(zhuǎn)換失敗,可通過是否為null指針檢測;引用轉(zhuǎn)換失敗則拋出一個bad_cast異常。
#include <QCoreApplication>
#include <iostream>
#include<stdio.h>
#include<typeinfo.h>
using namespace std;
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
class Base{};
class Derived:public Base{};
//子類指針pd轉(zhuǎn)化為父類指針pb
Derived* pd = new Derived;
Base* pb = dynamic_cast<Base* >(pd);
if(!pb)
{
cout << "類型轉(zhuǎn)換失敗" << endl;
}
else
{
cout << "類型轉(zhuǎn)換成功" << endl;
}
//子類引用轉(zhuǎn)化為父類引用
Derived d;
Base& b = dynamic_cast<Base& >(d);
//沒有繼承關(guān)系,但被轉(zhuǎn)化的類有虛函數(shù)
class A{
virtual ~A(){}
};
class B{};
A* pa = new A;
B* pc = dynamic_cast<B* >(pa);//有虛函數(shù)的對象指針,可以轉(zhuǎn)化
if(!pc)
{
cout << "類型轉(zhuǎn)換成功" << endl;
}
else
{
cout << "類型轉(zhuǎn)換失敗" << endl;
}
return a.exec();
}
運行結(jié)果:

dynamic_cast不只是應用于類型轉(zhuǎn)換,**通常利用它做運行時對象類型檢查的特性,在程序中檢測當前內(nèi)存對象的類型信息,**以決定下一步操作,使程序更靈活機動。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
c語言?數(shù)據(jù)存儲與原碼?反碼?補碼詳細解析
不知道你是否和我一樣好奇,學習編程語言的同時想,各個數(shù)據(jù)類型是怎樣在我們的內(nèi)存中儲存的呢,如果你仔細深入了解的話,你會了解其中的樂趣,了解科學家們的偉大,了解c語言2022-02-02
VS2017+Qt5+Opencv3.4調(diào)用攝像頭拍照并存儲
本文主要介紹了VS2017+Qt5+Opencv3.4調(diào)用攝像頭拍照并存儲,實現(xiàn)了視頻,拍照,保存這三個功能。具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-05-05

