青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我輩豈是蓬蒿人!

C++ && keyWordSpotting

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  11 Posts :: 0 Stories :: 4 Comments :: 0 Trackbacks

常用鏈接

留言簿(9)

我參與的團隊

搜索

  •  

積分與排名

  • 積分 - 7323
  • 排名 - 1369

最新評論

閱讀排行榜

評論排行榜

http://www.cprogramming.com/tutorial/stl/iterators.html

The concept of an iterator is fundamental to understanding the C++ Standard Template Library (STL) because iterators provide a means for accessing data stored in container classes such a vector, map, list, etc.

You can think of an iterator as pointing to an item that is part of a larger container of items. For intance, all containers support a function called begin, which will return an iterator pointing to the beginning of the container (the first element) and function, end, that returns an iterator corresponding to having reached the end of the container. In fact, you can access the element by "dereferencing" the iterator with a *, just as you would dereference a pointer.

To request an iterator appropriate for a particular STL templated class, you use the syntax

1?std::class_name<template_parameters>::iterator?name

where name is the name of the iterator variable you wish to create and the class_name is the name of the STL container you are using, and the template_paramters are the parameters to the template used to declare objects that will work with this iterator. Note that because the STL classes are part of the std namespace, you will need to either prefix every container class type with "std::", as in the example, or include "using namespace std;" at the top of your program.

For instance, if you had an STL vector storing integers, you could create an iterator for it as follows:
1std::vector<int>?myIntVector;
2std::vector<int>::iterator?myIntVectorIterator;
Different operations and containers support different types of iterator behavior. In fact, there are several different classes of iterators, each with slightly different properties. First, iterators are distinguished by whether you can use them for reading or writing data in the container. Some types of iterators allow for both reading and writing behavior, though not necessarily at the same time.

Some of the most important are the forward, backward and the bidirectional iterators. Both of these iterators can be used as either input or output iterators, meaning you can use them for either writing or reading. The forward iterator only allows movement one way -- from the front of the container to the back. To move from one element to the next, the increment operator, ++, can be used.

For instance, if you want to access the elements of an STL vector, it's best to use an iterator instead of the traditional C-style code. The strategy is fairly straightforward: call the container's begin function to get an iterator, use ++ to step through the objects in the container, access each object with the * operator ("*iterator") similar to the way you would access an object by dereferencing a pointer, and stop iterating when the iterator equals the container's end iterator. You can compare iterators using != to check for inequality, == to check for equality. (This only works for one twhen the iterators are operating on the same container!)

The old approach (avoid)
?1?using?namespace?std;
?2?
?3?vector<int>?myIntVector;
?4?
?5?//?Add?some?elements?to?myIntVector
?6?myIntVector.push_back(1);
?7?myIntVector.push_back(4);
?8?myIntVector.push_back(8);
?9?
10?for(int?y=0;?y<myIntVector.size();?y++)
11?{
12?????cout<<myIntVector[y]<<"?";??//Should?output?1?4?8
13?}
The STL approach (use this)
?1?using?namespace?std;
?2?
?3?vector<int>?myIntVector;
?4?vector<int>::iterator?myIntVectorIterator;
?5?
?6?//?Add?some?elements?to?myIntVector
?7?myIntVector.push_back(1);
?8?myIntVector.push_back(4);
?9?myIntVector.push_back(8);
10?
11?for(myIntVectorIterator?=?myIntVector.begin();?
12?????????myIntVectorIterator?!=?myIntVector.end();
13?????????myIntVectorIterator++)
14?{
15?????cout<<*myIntVectorIterator<<"?";????//Should?output?1?4?8
16?}
17?
As you might imagine, you can use the decrement operator, --, when working with a bidirectional iterator or a backward operator.

Iterators are often handy for specifying a particular range of things to operate on. For instance, the range item.begin(), item.end() is the entire container, but smaller slices can be used. This is particularly easy with one other, extremely general class of iterator, the random access iterator, which is functionally equivalent to a pointer in C or C++ in the sense that you can not only increment or decrement but also move an arbitrary distance in constant time (for instance, jump multiple elements down a vector).

For instance, the iterators associated with vectors are random access iterators so you could use arithmetic of the form
iterator + n
where n is an integer. The result will be the element corresponding to the nth item after the item pointed to be the current iterator. This can be a problem if you happen to exceed the bounds of your iterator by stepping forward (or backward) by too many elements.

The following code demonstrates both the use of random access iterators and exceeding the bounds of the array (don't run it!):
1?vector<int>?myIntVector;
2?vector<int>::iterator?myIntVectorIterator;
3?myIntVectorIterator?=?myIntVector.begin()?+?2;
You can also use the standard arithmetic shortcuts for addition and subtraction, += and -=, with random access iterators. Moreover, with random access iterators you can use <, >, <=, and >= to compare iterator positions within the container.

Iterators are also useful for some functions that belong to container classes that require operating on a range of values. A simple but useful example is the erase function. The vector template supports this function, which takes a range as specified by two iterators -- every element in the range is erased. For instance, to erase an entire vector:
1?vector<int>::iterator?myIntVectorIterator;
2?myIntVector.erase(myIntVectorIterator.begin(),?myIntVectorIterator.end());
which would delete all elements in the vector. If you only wanted to delete the first two elements, you could use
1myIntVector.erase(myIntVectorIterator.begin(),?myIntVectorIterator.begin()+2);
Note that various container class support different types of iterators -- the vector class, which has served as our model for iterators, supports a random access iterator, the most general kind. Another container, the list container (to be discussed later), only supports bidirectional iterators.

So why use iterators? First, they're a flexible way to access the data in containers that don't have obvious means of accessing all of the data (for instance, maps [to be discussed later]). They're also quite flexible -- if you change the underlying container, it's easy to change the associated iterator so long as you only use features associated with the iterator supported by both classes. Finally, the STL algorithms defined in <algorithm> (to be discussed later) use iterators.

Summary

The Good
  • The STL provides iterators as a convenient abstraction for accessing many different types of containers.
  • Iterators for templated classes are generated inside the class scope with the syntax
    class_name<parameters>::iterator
    
  • Iterators can be thought of as limited pointers (or, in the case of random access iterators, as nearly equivalent to pointers)
The Gotchas
  • Iterators do not provide bounds checking; it is possible to overstep the bounds of a container, resulting in segmentation faults
  • Different containers support different iterators, so it is not always possible to change the underlying container type without making changes to your code
  • Iterators can be invalidated if the underlying container (the container being iterated over) is changed significantly
posted on 2006-08-13 19:04 keyws 閱讀(556) 評論(0)  編輯 收藏 引用 所屬分類: STL

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产三级精品三级| 久久精选视频| 欧美一区二区三区婷婷月色 | 国产伦精品一区二区| 欧美福利在线观看| 欧美精品一区二区三区视频| 欧美另类在线观看| 欧美三级在线播放| 国产亚洲在线| 亚洲视频网在线直播| 日韩一级在线| 亚洲综合成人婷婷小说| 欧美有码在线观看视频| 久久天天躁狠狠躁夜夜av| 免费不卡在线视频| 亚洲免费高清| 久久精品亚洲乱码伦伦中文| 久久综合精品一区| 欧美三区在线| 尤物网精品视频| 亚洲网友自拍| 美日韩精品视频免费看| 亚洲精品女av网站| 一区二区三区国产| 美日韩精品免费| 男女激情视频一区| 国产亚洲欧美日韩日本| 在线欧美小视频| 亚洲天堂免费在线观看视频| 久久天堂成人| 亚洲尤物视频网| 欧美肥婆bbw| 国产亚洲欧美在线| 亚洲视频精选| 亚洲国内精品| 久久夜色撩人精品| 国产精品伊人日日| 一本久道久久综合狠狠爱| 麻豆精品在线观看| 亚洲一区二区在线观看视频| 欧美黄色片免费观看| 一区二区在线视频| 亚洲综合视频网| 亚洲精品激情| 男女精品网站| 亚洲电影成人| 久久综合狠狠综合久久综合88| 亚洲视频网站在线观看| 欧美精品情趣视频| 亚洲精品视频二区| 亚洲第一在线综合在线| 久久亚洲综合网| 精品福利电影| 快播亚洲色图| 久久综合九色综合欧美就去吻| 国产精品一区二区男女羞羞无遮挡| 一区二区三区成人| 9色porny自拍视频一区二区| 欧美激情1区2区3区| 亚洲日本久久| 亚洲国产中文字幕在线观看| 牛人盗摄一区二区三区视频| 经典三级久久| 欧美jizz19hd性欧美| 久久美女艺术照精彩视频福利播放| 国产乱码精品一区二区三区忘忧草| 欧美亚洲一区二区三区| 亚洲欧美精品在线观看| 国产欧美日韩免费看aⅴ视频| 欧美一区二区在线看| 亚洲欧美韩国| 精品69视频一区二区三区| 美女黄毛**国产精品啪啪| 免费一级欧美片在线观看| 一区二区三区国产精华| 亚洲无亚洲人成网站77777| 国产精品系列在线播放| 久久久久久久999精品视频| 久久国产精品一区二区三区四区| 激情久久久久久久| 亚洲电影在线免费观看| 欧美天天综合网| 久久免费黄色| 欧美**人妖| 亚洲在线日韩| 日韩视频一区二区三区在线播放| 亚洲欧美国产日韩中文字幕| 国产日韩欧美| 欧美福利一区二区三区| 欧美女同在线视频| 久久精品国产久精国产思思| 玖玖玖国产精品| 中文在线不卡视频| 久久精品国产综合| 亚洲午夜精品| 老鸭窝亚洲一区二区三区| 一区二区三区免费观看| 欧美一区二区三区免费看| 亚洲九九九在线观看| 午夜精品成人在线| 亚洲精品在线观看免费| 亚洲欧美另类在线| 亚洲精品资源美女情侣酒店| 亚洲综合清纯丝袜自拍| 亚洲美女毛片| 欧美亚洲综合在线| 一区二区三区日韩| 蜜臀av性久久久久蜜臀aⅴ| 亚洲在线视频| 欧美精品高清视频| 欧美阿v一级看视频| 国产精品丝袜久久久久久app| 欧美国产精品日韩| 韩国三级电影久久久久久| 一区二区三区国产精华| 亚洲精品九九| 巨乳诱惑日韩免费av| 久久精品国产久精国产一老狼| 欧美理论在线| 亚洲黄色成人网| 亚洲国产成人久久综合| 欧美在线观看视频| 欧美在线观看视频| 国产精品日韩二区| av成人动漫| 亚洲一区在线播放| 欧美日本一道本在线视频| 欧美成人日本| 91久久线看在观草草青青| 久久夜色精品国产欧美乱| 久久视频一区| 国产农村妇女毛片精品久久麻豆| 一区二区三区成人| 亚洲欧美色一区| 国产精品久久久久一区| 亚洲九九精品| 亚洲精选久久| 欧美日韩精品免费观看视一区二区| 亚洲国产成人porn| 日韩午夜黄色| 欧美日韩一区二区视频在线| 亚洲美女一区| 亚洲综合色丁香婷婷六月图片| 欧美日韩一区二区在线观看视频| 亚洲人屁股眼子交8| 夜夜爽夜夜爽精品视频| 欧美色中文字幕| 午夜一级在线看亚洲| 久久久青草青青国产亚洲免观| 好看的亚洲午夜视频在线| 久久夜色精品| 日韩视频一区二区三区在线播放 | 亚洲精品国产精品乱码不99 | 伊伊综合在线| 蜜桃av一区二区| 亚洲精品久久久久久一区二区| 亚洲免费播放| 欧美色区777第一页| 亚洲香蕉成视频在线观看| 欧美亚洲免费在线| 狠狠狠色丁香婷婷综合久久五月| 久久久国产亚洲精品| 亚洲国产91精品在线观看| 日韩视频在线一区二区三区| 国产精品九九久久久久久久| 久久精品国产一区二区电影| 亚洲电影天堂av| 亚洲免费在线电影| 精品999成人| 欧美日韩国产成人在线91| 亚洲欧美成人一区二区三区| 玖玖精品视频| 亚洲一区免费看| 国内一区二区三区在线视频| 欧美激情黄色片| 午夜精品久久久久久99热| 免费在线观看成人av| 一区二区av在线| 激情久久中文字幕| 欧美日韩另类字幕中文| 欧美一级成年大片在线观看| 亚洲国产成人午夜在线一区 | 欧美一区二区黄色| 亚洲国产成人av在线| 国产麻豆精品theporn| 久久天天躁狠狠躁夜夜av| 一区二区久久久久| 欧美成人午夜影院| 欧美一区二区大片| 亚洲天天影视| 亚洲精品韩国| 激情av一区| 国产精品夜色7777狼人| 欧美日本一区二区高清播放视频| 亚洲午夜av在线| 亚洲高清久久网| 久久精品色图| 欧美一区二区| 亚洲专区在线| 在线中文字幕日韩|