move std 函数 示例_C++ STL迭代器辅助函数
本節(jié)先講解 advance() 函數(shù),其他函數(shù)后續(xù)章節(jié)會做詳細介紹。
advance() 函數(shù)用于將迭代器前進(或者后退)指定長度的距離,其語法格式如下:
template void advance (InputIterator& it, Distance n);其中 it 指的是目標迭代器,n 通常為一個整數(shù)。
需要注意的是,如果 it 為輸入迭代器或者前向迭代器,則 n 必須為一個正數(shù),即表示將 it 右移(前進) n 個位置;反之,如果 it 為雙向迭代器或者隨機訪問迭代器,則 n 為正數(shù)時表示將 it 右移(前進) n 個位置,n 為負數(shù)時表示將 it 左移(后退) n 個位置。
另外,根據(jù) it 類型是否為隨機訪問迭代器,advance() 函數(shù)底層采用了不同的實現(xiàn)機制:
1.當 it 為隨機訪問迭代器時,由于該類型迭代器支持 p+n 或者 p-n(其中 p 就是一個隨機訪問迭代器)運算,advance() 函數(shù)底層采用的就是 it+n 操作實現(xiàn)的;
2.當 it 為其他類型迭代器時,它們僅支持進行 ++ 或者 -- 運算,這種情況下,advance() 函數(shù)底層是通過重復(fù)執(zhí)行 n 個 ++ 或者 -- 操作實現(xiàn)的。
值得一提的是,advance() 函數(shù)定義在頭文件,并位于 std 命名空間中。因此,程序在使用該函數(shù)之前,應(yīng)包含如下 2 行代碼:
#include using namespace std;示例:#include // std::cout#include // std::advance#include using namespace std;int main() { //創(chuàng)建一個 forward_list 容器 forward_list mylist{1,2,3,4}; //it為前向迭代器,其指向 mylist 容器中第一個元素 forward_list::iterator it = mylist.begin(); //借助 advance() 函數(shù)將 it 迭代器前進 2 個位置 advance(it, 2); cout << "*it = " << *it; return 0;}程序執(zhí)行結(jié)果為:
*it = 3此程序中,由于 it 為前向迭代器,其只能進行 ++ 操作,即只能前進(右移),所以 advance() 函數(shù)的第 2 個參數(shù)只能為正數(shù)。
下面程序以 vector 容器為例,演示了 advance() 函數(shù)的功能:
#include // std::cout#include // std::advance#include using namespace std;int main() { //創(chuàng)建一個 vector 容器 vector myvector{1,2,3,4}; //it為隨機訪問迭代器,其指向 myvector 容器中第一個元素 vector::iterator it = myvector.begin(); //借助 advance() 函數(shù)將 it 迭代器前進 2 個位置 advance(it, 2); cout << "1、*it = " << *it << endl; //繼續(xù)使用it,其指向 myvector 容器中最后一個元素之后的位置 it = myvector.end(); //借助 advance() 函數(shù)將 it 迭代器后退 3 個位置 advance(it, -3); cout << "2、*it = " << *it; return 0;}程序執(zhí)行結(jié)果為:
1、*it = 32、*it = 2注意,advance() 函數(shù)本身不會檢測 it 迭代器移動 n 個位置的可行性,如果 it 迭代器的移動位置超出了合理范圍,it 迭代器的指向?qū)o法保證,此時使用 *it 將會導(dǎo)致程序崩潰。
總結(jié)
以上是生活随笔為你收集整理的move std 函数 示例_C++ STL迭代器辅助函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 北理在线作业答案c语言,北理工19春《面
- 下一篇: android触摸效果,Android