File: qlinkedlistiterator.html

package info (click to toggle)
qt4-x11 4%3A4.8.2%2Bdfsg-11
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 701,696 kB
  • sloc: cpp: 2,686,179; ansic: 375,485; python: 25,859; sh: 19,349; xml: 17,091; perl: 14,765; yacc: 5,383; asm: 5,038; makefile: 1,259; lex: 555; ruby: 526; objc: 347; cs: 112; pascal: 112; php: 54; sed: 34
file content (174 lines) | stat: -rw-r--r-- 15,772 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en_US" lang="en_US">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!-- qiterator.qdoc -->
  <title>Qt 4.8: QLinkedListIterator Class Reference</title>
  <link rel="stylesheet" type="text/css" href="style/offline.css" />
</head>
<body>
<div class="header" id="qtdocheader">
  <div class="content"> 
    <a href="index.html" class="qtref"><span>Qt Reference Documentation</span></a>
  </div>
  <div class="breadcrumb toolblock">
    <ul>
      <li class="first"><a href="index.html">Home</a></li>
      <!--  Breadcrumbs go here -->
<li><a href="modules.html">Modules</a></li>
<li><a href="qtcore.html">QtCore</a></li>
<li>QLinkedListIterator</li>
    </ul>
  </div>
</div>
<div class="content mainContent">
<div class="toc">
<h3><a name="toc">Contents</a></h3>
<ul>
<li class="level1"><a href="#public-functions">Public Functions</a></li>
<li class="level1"><a href="#details">Detailed Description</a></li>
</ul>
</div>
<h1 class="title">QLinkedListIterator Class Reference</h1>
<!-- $$$QLinkedListIterator-brief -->
<p>The QLinkedListIterator class provides a Java-style const iterator for <a href="qlinkedlist.html">QLinkedList</a>. <a href="#details">More...</a></p>
<!-- @@@QLinkedListIterator -->
<pre class="cpp"> <span class="preprocessor">#include &lt;QLinkedListIterator&gt;</span></pre><ul>
<li><a href="qlinkedlistiterator-members.html">List of all members, including inherited members</a></li>
</ul>
<a name="public-functions"></a>
<h2>Public Functions</h2>
<table class="alignedsummary">
<tr><td class="memItemLeft rightAlign topAlign"> </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#QLinkedListIterator">QLinkedListIterator</a></b> ( const QLinkedList&lt;T&gt; &amp; <i>list</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#findNext">findNext</a></b> ( const T &amp; <i>value</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#findPrevious">findPrevious</a></b> ( const T &amp; <i>value</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#hasNext">hasNext</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#hasPrevious">hasPrevious</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const T &amp; </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#next">next</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const T &amp; </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#peekNext">peekNext</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const T &amp; </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#peekPrevious">peekPrevious</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const T &amp; </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#previous">previous</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#toBack">toBack</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#toFront">toFront</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QLinkedListIterator &amp; </td><td class="memItemRight bottomAlign"><b><a href="qlinkedlistiterator.html#operator-eq">operator=</a></b> ( const QLinkedList&lt;T&gt; &amp; <i>list</i> )</td></tr>
</table>
<a name="details"></a>
<!-- $$$QLinkedListIterator-description -->
<div class="descr">
<h2>Detailed Description</h2>
<p>The QLinkedListIterator class provides a Java-style const iterator for <a href="qlinkedlist.html">QLinkedList</a>.</p>
<p><a href="qlinkedlist.html">QLinkedList</a> has both <a href="containers.html#java-style-iterators">Java-style iterators</a> and <a href="containers.html#stl-style-iterators">STL-style iterators</a>. The Java-style iterators are more high-level and easier to use than the STL-style iterators; on the other hand, they are slightly less efficient.</p>
<p>QLinkedListIterator&lt;T&gt; allows you to iterate over a <a href="qlinkedlist.html">QLinkedList</a>&lt;T&gt;. If you want to modify the list as you iterate over it, use <a href="qmutablelinkedlistiterator.html">QMutableLinkedListIterator</a>&lt;T&gt; instead.</p>
<p>The QLinkedListIterator constructor takes a <a href="qlinkedlist.html">QLinkedList</a> as argument. After construction, the iterator is located at the very beginning of the list (before the first item). Here's how to iterate over all the elements sequentially:</p>
<pre class="cpp"> <span class="type"><a href="qlinkedlist.html">QLinkedList</a></span><span class="operator">&lt;</span><span class="type">float</span><span class="operator">&gt;</span> list;
 <span class="operator">.</span><span class="operator">.</span><span class="operator">.</span>
 <span class="type">QLinkedListIterator</span><span class="operator">&lt;</span><span class="type">float</span><span class="operator">&gt;</span> i(list);
 <span class="keyword">while</span> (i<span class="operator">.</span>hasNext())
     <a href="qtglobal.html#qDebug">qDebug</a>() <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span><a href="qlinkedlistiterator.html#next">next</a>();</pre>
<p>The <a href="qlinkedlistiterator.html#next">next</a>() function returns the next item in the list and advances the iterator. Unlike STL-style iterators, Java-style iterators point <i>between</i> items rather than directly <i>at</i> items. The first call to <a href="qlinkedlistiterator.html#next">next</a>() advances the iterator to the position between the first and second item, and returns the first item; the second call to <a href="qlinkedlistiterator.html#next">next</a>() advances the iterator to the position between the second and third item, and returns the second item; and so on.</p>
<p class="centerAlign"><img src="images/javaiterators1.png" alt="" /></p><p>Here's how to iterate over the elements in reverse order:</p>
<pre class="cpp"> <span class="type">QLinkedListIterator</span><span class="operator">&lt;</span><span class="type">float</span><span class="operator">&gt;</span> i(list);
 i<span class="operator">.</span><a href="qlinkedlistiterator.html#toBack">toBack</a>();
 <span class="keyword">while</span> (i<span class="operator">.</span>hasPrevious())
     <a href="qtglobal.html#qDebug">qDebug</a>() <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span><a href="qlinkedlistiterator.html#previous">previous</a>();</pre>
<p>If you want to find all occurrences of a particular value, use <a href="qlinkedlistiterator.html#findNext">findNext</a>() or <a href="qlinkedlistiterator.html#findPrevious">findPrevious</a>() in a loop.</p>
<p>Multiple iterators can be used on the same list. If the list is modified while a QLinkedListIterator is active, the QLinkedListIterator will continue iterating over the original list, ignoring the modified copy.</p>
</div>
<p><b>See also </b><a href="qmutablelinkedlistiterator.html">QMutableLinkedListIterator</a> and <a href="qlinkedlist-const-iterator.html">QLinkedList::const_iterator</a>.</p>
<!-- @@@QLinkedListIterator -->
<div class="func">
<h2>Member Function Documentation</h2>
<!-- $$$QLinkedListIterator[overload1]$$$QLinkedListIteratorconstQLinkedList<T>& -->
<h3 class="fn"><a name="QLinkedListIterator"></a>QLinkedListIterator::<span class="name">QLinkedListIterator</span> ( const <span class="type"><a href="qlinkedlist.html">QLinkedList</a></span>&lt;<span class="type">T</span>&gt; &amp; <i>list</i> )</h3>
<p>Constructs an iterator for traversing <i>list</i>. The iterator is set to be at the front of the list (before the first item).</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#operator-eq">operator=</a>().</p>
<!-- @@@QLinkedListIterator -->
<!-- $$$findNext[overload1]$$$findNextconstT& -->
<h3 class="fn"><a name="findNext"></a><span class="type">bool</span> QLinkedListIterator::<span class="name">findNext</span> ( const <span class="type">T</span> &amp; <i>value</i> )</h3>
<p>Searches for <i>value</i> starting from the current iterator position forward. Returns true if <i>value</i> is found; otherwise returns false.</p>
<p>After the call, if <i>value</i> was found, the iterator is positioned just after the matching item; otherwise, the iterator is positioned at the back of the container.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#findPrevious">findPrevious</a>().</p>
<!-- @@@findNext -->
<!-- $$$findPrevious[overload1]$$$findPreviousconstT& -->
<h3 class="fn"><a name="findPrevious"></a><span class="type">bool</span> QLinkedListIterator::<span class="name">findPrevious</span> ( const <span class="type">T</span> &amp; <i>value</i> )</h3>
<p>Searches for <i>value</i> starting from the current iterator position backward. Returns true if <i>value</i> is found; otherwise returns false.</p>
<p>After the call, if <i>value</i> was found, the iterator is positioned just before the matching item; otherwise, the iterator is positioned at the front of the container.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#findNext">findNext</a>().</p>
<!-- @@@findPrevious -->
<!-- $$$hasNext[overload1]$$$hasNext -->
<h3 class="fn"><a name="hasNext"></a><span class="type">bool</span> QLinkedListIterator::<span class="name">hasNext</span> () const</h3>
<p>Returns true if there is at least one item ahead of the iterator, i.e&#x2e; the iterator is <i>not</i> at the back of the container; otherwise returns false.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#hasPrevious">hasPrevious</a>() and <a href="qlinkedlistiterator.html#next">next</a>().</p>
<!-- @@@hasNext -->
<!-- $$$hasPrevious[overload1]$$$hasPrevious -->
<h3 class="fn"><a name="hasPrevious"></a><span class="type">bool</span> QLinkedListIterator::<span class="name">hasPrevious</span> () const</h3>
<p>Returns true if there is at least one item behind the iterator, i.e&#x2e; the iterator is <i>not</i> at the front of the container; otherwise returns false.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#hasNext">hasNext</a>() and <a href="qlinkedlistiterator.html#previous">previous</a>().</p>
<!-- @@@hasPrevious -->
<!-- $$$next[overload1]$$$next -->
<h3 class="fn"><a name="next"></a>const <span class="type">T</span> &amp; QLinkedListIterator::<span class="name">next</span> ()</h3>
<p>Returns the next item and advances the iterator by one position.</p>
<p>Calling this function on an iterator located at the back of the container leads to undefined results.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#hasNext">hasNext</a>(), <a href="qlinkedlistiterator.html#peekNext">peekNext</a>(), and <a href="qlinkedlistiterator.html#previous">previous</a>().</p>
<!-- @@@next -->
<!-- $$$peekNext[overload1]$$$peekNext -->
<h3 class="fn"><a name="peekNext"></a>const <span class="type">T</span> &amp; QLinkedListIterator::<span class="name">peekNext</span> () const</h3>
<p>Returns the next item without moving the iterator.</p>
<p>Calling this function on an iterator located at the back of the container leads to undefined results.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#hasNext">hasNext</a>(), <a href="qlinkedlistiterator.html#next">next</a>(), and <a href="qlinkedlistiterator.html#peekPrevious">peekPrevious</a>().</p>
<!-- @@@peekNext -->
<!-- $$$peekPrevious[overload1]$$$peekPrevious -->
<h3 class="fn"><a name="peekPrevious"></a>const <span class="type">T</span> &amp; QLinkedListIterator::<span class="name">peekPrevious</span> () const</h3>
<p>Returns the previous item without moving the iterator.</p>
<p>Calling this function on an iterator located at the front of the container leads to undefined results.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#hasPrevious">hasPrevious</a>(), <a href="qlinkedlistiterator.html#previous">previous</a>(), and <a href="qlinkedlistiterator.html#peekNext">peekNext</a>().</p>
<!-- @@@peekPrevious -->
<!-- $$$previous[overload1]$$$previous -->
<h3 class="fn"><a name="previous"></a>const <span class="type">T</span> &amp; QLinkedListIterator::<span class="name">previous</span> ()</h3>
<p>Returns the previous item and moves the iterator back by one position.</p>
<p>Calling this function on an iterator located at the front of the container leads to undefined results.</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#hasPrevious">hasPrevious</a>(), <a href="qlinkedlistiterator.html#peekPrevious">peekPrevious</a>(), and <a href="qlinkedlistiterator.html#next">next</a>().</p>
<!-- @@@previous -->
<!-- $$$toBack[overload1]$$$toBack -->
<h3 class="fn"><a name="toBack"></a><span class="type">void</span> QLinkedListIterator::<span class="name">toBack</span> ()</h3>
<p>Moves the iterator to the back of the container (after the last item).</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#toFront">toFront</a>() and <a href="qlinkedlistiterator.html#previous">previous</a>().</p>
<!-- @@@toBack -->
<!-- $$$toFront[overload1]$$$toFront -->
<h3 class="fn"><a name="toFront"></a><span class="type">void</span> QLinkedListIterator::<span class="name">toFront</span> ()</h3>
<p>Moves the iterator to the front of the container (before the first item).</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#toBack">toBack</a>() and <a href="qlinkedlistiterator.html#next">next</a>().</p>
<!-- @@@toFront -->
<!-- $$$operator=[overload1]$$$operator=constQLinkedList<T>& -->
<h3 class="fn"><a name="operator-eq"></a><span class="type">QLinkedListIterator</span> &amp; QLinkedListIterator::<span class="name">operator=</span> ( const <span class="type"><a href="qlinkedlist.html">QLinkedList</a></span>&lt;<span class="type">T</span>&gt; &amp; <i>list</i> )</h3>
<p>Makes the iterator operate on <i>list</i>. The iterator is set to be at the front of the list (before the first item).</p>
<p><b>See also </b><a href="qlinkedlistiterator.html#toFront">toFront</a>() and <a href="qlinkedlistiterator.html#toBack">toBack</a>().</p>
<!-- @@@operator= -->
</div>
  <div class="ft">
    <span></span>
  </div>
</div> 
<div class="footer">
    <p>
      <acronym title="Copyright">&copy;</acronym> 2012 Nokia Corporation and/or its
      subsidiaries. Documentation contributions included herein are the copyrights of
      their respective owners.</p>
    <br />
    <p>
      The documentation provided herein is licensed under the terms of the
      <a href="http://www.gnu.org/licenses/fdl.html">GNU Free Documentation
      License version 1.3</a> as published by the Free Software Foundation.</p>
    <p>
      Documentation sources may be obtained from <a href="http://www.qt-project.org">
      www.qt-project.org</a>.</p>
    <br />
    <p>
      Nokia, Qt and their respective logos are trademarks of Nokia Corporation 
      in Finland and/or other countries worldwide. All other trademarks are property
      of their respective owners. <a title="Privacy Policy"
      href="http://en.gitorious.org/privacy_policy/">Privacy Policy</a></p>
</div>
</body>
</html>