C++11基于范圍的for循環(huán)代碼示例
范圍for的引入
int main(void)
{
int arr[] = { 1,2,3,4,5,6,7,8,9 };
int sz = sizeof(arr) / sizeof(arr[0]);
for (int i = 0; i < sz; i++)
{
cout << arr[i] << " ";
}
return 0;
}
在C++98里面遍歷一個(gè)數(shù)組,或者說是一個(gè)有范圍的集合而言,對(duì)應(yīng)程序員來說明循環(huán)的范圍是多余的。
因此C++11中引入了基于范圍的for循環(huán),for循環(huán)后面的括號(hào)由冒號(hào)“:”分為倆部分:第一部分是范圍內(nèi)用于迭代的變量,第二部分則表示被迭代的范圍。
for(declaration : range)
{}
declaration是變量聲明,用于存儲(chǔ)每次迭代中的元素值,可以是自定義的變量名,也可以是已有的變量名。
range是要遍歷的容器或者迭代的對(duì)象。
【注意】與普通循環(huán)類似,可以用continue來結(jié)束本次循環(huán),也可以用break來跳出整個(gè)循環(huán)。
int main(void)
{
int arr[] = { 1,2,3,4,5,6,7,8,9 };
int sz = sizeof(arr) / sizeof(arr[0]);
for (auto a : arr)
{
cout << a << " ";
}
return 0;
}
范圍for的使用條件
1.for循環(huán)迭代的范圍必須是確定的。
(1)對(duì)于數(shù)組而言,就是數(shù)組中第一個(gè)元素和最后一個(gè)元素的范圍
(2)對(duì)于類而言,應(yīng)該提供begin和end的方法,begin和end就是for循環(huán)迭代的范圍
2.迭代的對(duì)象要實(shí)現(xiàn)++和==的操作。
對(duì)于數(shù)組而言,就是數(shù)組中第一個(gè)元素和最后一個(gè)元素的范圍;對(duì)于類而言,應(yīng)該提供begin和end的方法,begin和end就是for循環(huán)迭代的范圍。
注意:以下代碼就有問題,因?yàn)?code>for的范圍不確定
void TestFor(int array[])
{
for(auto& e : array)
cout<< e <<endl;
}
迭代的對(duì)象要實(shí)現(xiàn)++和==的操作
關(guān)于這個(gè)問題,我將在后續(xù)文章進(jìn)行講解,敬請(qǐng)期待,現(xiàn)在先了解一下基礎(chǔ)概念
迭代器
迭代器(Iterator)是一種對(duì)象,用于遍歷容器中的元素。它提供了一種統(tǒng)一的訪問容器元素的方式,使得用戶可以通過相同的方式訪問不同類型的容器。
迭代器一般具有以下操作:
- 通過
*運(yùn)算符獲取當(dāng)前迭代器指向的元素 - 通過
++運(yùn)算符將迭代器向后移動(dòng)到下一個(gè)元素 - 通過
==運(yùn)算符判斷兩個(gè)迭代器是否相等 - 通過
!=運(yùn)算符判斷兩個(gè)迭代器是否不相等
使用范圍for循環(huán)時(shí),可以使用迭代器來表示集合的起始位置和結(jié)束位置,范圍for循環(huán)會(huì)自動(dòng)遍歷整個(gè)集合中的元素,不需要手動(dòng)控制迭代器的移動(dòng)和判斷。這樣就避免了使用傳統(tǒng)的for循環(huán)需要手動(dòng)管理迭代器的復(fù)雜性。
總結(jié)
到此這篇關(guān)于C++11基于范圍的for循環(huán)的文章就介紹到這了,更多相關(guān)C++基于范圍的for循環(huán)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實(shí)現(xiàn) vector 的四則運(yùn)算
本文給大家介紹的是在C++中實(shí)現(xiàn)高效的vector四則運(yùn)算的方法的相關(guān)資料,需要的朋友可以參考下2016-07-07
C++?qsort函數(shù)排序與冒泡模擬實(shí)現(xiàn)流程詳解
qsort是一個(gè)庫函數(shù),基于快速排序算法實(shí)現(xiàn)的一個(gè)排序的函數(shù),下面這篇文章主要給大家介紹了關(guān)于C語言qsort()函數(shù)使用的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10
C語言詳細(xì)分析講解內(nèi)存管理malloc realloc free calloc函數(shù)的使用
C語言內(nèi)存管理相關(guān)的函數(shù)主要有realloc、calloc、malloc、free等,下面這篇文章主要給大家介紹了關(guān)于C語言內(nèi)存管理realloc、calloc、malloc、free函數(shù)的相關(guān)資料,需要的朋友可以參考下2022-05-05
C++通用動(dòng)態(tài)抽象工廠的實(shí)現(xiàn)詳解
在面向?qū)ο蟮木幊讨?一般通過繼承和虛函數(shù)來提供抽象能力,下面這篇文章主要給大家介紹了關(guān)于C++通用動(dòng)態(tài)抽象工廠的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
詳解C++中賦值,關(guān)系,函數(shù)調(diào)用運(yùn)算符重載的實(shí)現(xiàn)
本文主要為大家講解一下三個(gè)C++中的運(yùn)算符重載,分別是賦值運(yùn)算符重載、關(guān)系運(yùn)算符重載和函數(shù)調(diào)用運(yùn)算符重載,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-06-06
MFC程序中使用QT開發(fā)界面的實(shí)現(xiàn)步驟
本文主要介紹了MFC程序中使用QT開發(fā)界面的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12

