📄 qvaluelistiterator.html
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><!-- /home/reggie/tmp/qt-3.0-reggie-5401/qt-x11-commercial-3.0.5/doc/qvaluelist.doc:746 --><html><head><meta http-equiv="Content-Type" content="text/html; charset=gb2312"><meta name="Translator" content="Cavendish"><meta name="Qt zh_CN Documents Website" content="http://www.qiliang.net/qt"><title>QValueListIterator类</title><style type="text/css"><!--h3.fn,span.fn { margin-left: 1cm; text-indent: -1cm; }a:link { color: #004faf; text-decoration: none }a:visited { color: #672967; text-decoration: none }body { background: #ffffff; color: black; font-family: "Times New Roman" }--></style></head><body><table border="0" cellpadding="0" cellspacing="0" width="100%"><tr bgcolor="#E5E5E5"><td valign=center> <a href="index.html"><font color="#004faf">主页</font></a> | <a href="classes.html"><font color="#004faf">所有的类</font></a> | <a href="mainclasses.html"><font color="#004faf">主要的类</font></a> | <a href="annotated.html"><font color="#004faf">注释的类</font></a> | <a href="groups.html"><font color="#004faf">分组的类</font></a> | <a href="functions.html"><font color="#004faf">函数</font></a></td><td align="right" valign="center"><img src="logo32.png" align="right" width="64" height="32" border="0"></td></tr></table><h1 align=center>QValueListIterator类参考</h1><p>QValueListIterator类提供了QValueList的迭代器。<a href="#details">详情请见……</a><p><tt>#include <<a href="qvaluelist-h.html">qvaluelist.h</a>></tt><p><a href="qvaluelistiterator-members.html">所有成员函数的列表。</a><h2>公有成员s</h2><ul><li><div class=fn>typedef T <a href="#value_type"><b>value_type</b></a></div></li><li><div class=fn>typedef T * <a href="#pointer"><b>pointer</b></a></div></li><li><div class=fn>typedef T & <a href="#reference"><b>reference</b></a></div></li><li><div class=fn><a href="#QValueListIterator"><b>QValueListIterator</b></a> ()</div></li><li><div class=fn><a href="#QValueListIterator-3"><b>QValueListIterator</b></a> ( const QValueListIterator<T> & it )</div></li><li><div class=fn>bool <a href="#operator-eq-eq"><b>operator==</b></a> ( const QValueListIterator<T> & it ) const</div></li><li><div class=fn>bool <a href="#operator!-eq"><b>operator!=</b></a> ( const QValueListIterator<T> & it ) const</div></li><li><div class=fn>const T & <a href="#operator*-2"><b>operator*</b></a> () const</div></li><li><div class=fn>T & <a href="#operator*"><b>operator*</b></a> ()</div></li><li><div class=fn>QValueListIterator<T> & <a href="#operator++"><b>operator++</b></a> ()</div></li><li><div class=fn>QValueListIterator<T> <a href="#operator++-2"><b>operator++</b></a> ( int )</div></li><li><div class=fn>QValueListIterator<T> & <a href="#operator--"><b>operator--</b></a> ()</div></li><li><div class=fn>QValueListIterator<T> <a href="#operator---2"><b>operator--</b></a> ( int )</div></li></ul><hr><a name="details"></a><h2>详细描述</h2>QValueListIterator类提供了<a href="qvaluelist.html">QValueList</a>的迭代器。<p> <p> 迭代器就是一个可以访问容器类项的类——就是数组中索引的广义化。一个指针“const char *”和一个索引“int[]”都是迭代器,并且这个通用的思想就是为任何数据结构都提供这样的功能。<p> QValueListIterator类是QValueList实例的迭代器。你可以通过使用QValueList中定义的<tt>iterator</tt>来创建合适的迭代器类型。<p> 在QValueList中唯一可以用来访问项的方法就是使用迭代器。<p> 实例(全部代码可以参考QValueList):<pre> EmployeeList::iterator it; for ( it = list.begin(); it != list.end(); ++it ) cout << (*it).surname().latin1() << ", " << (*it).forename().latin1() << " earns " << (*it).salary() << endl; // 输出: // Doe, John earns 50000 // Williams, Jane earns 80000 // Hawthorne, Mary earns 90000 // Jones, Tom earns 60000 </pre> <p> <a href="qvaluelist.html">QValueList</a>对性能和内存使用已经高度优化了。这也就是说,你必须谨慎使用,QValueList不知道所有关于它的迭代器并且迭代器也不知道它们属于哪一个列表。这使得事情变得很快,但是如果你不注意,你就会得到壮观的bug。在引用迭代器或者使用它们作为STL或者<a href="qtl.html">QTL</a>中的通用算法的参数时,请确认它们是有效的。<p> 使用未定义的迭代器是未定义的(你的程序也许将会崩溃)。很多Qt函数返回常量值列表,要遍历它们,你应该复制之后再遍历它们的副本。<p> 对于每一个Iterator都有一个ConstIterator。当在一个常量环境中访问QValueList或者如果列表的引用或指针本身是一个常量,那么你就必须使用ConstIterator。它的语义和Iterator一样,但是它返回的是常量引用。<p> <p>也可以参考<a href="qvaluelist.html">QValueList</a>、<a href="qvaluelistconstiterator.html">QValueListConstIterator</a>、<a href="qtl.html">Qt模板库类</a>和<a href="tools.html">非GUI类</a>。<hr><h2>成员类型文档</h2><h3 class=fn><a name="pointer"></a>QValueListIterator::pointer</h3> 值类型的指针。<h3 class=fn><a name="reference"></a>QValueListIterator::reference</h3> 值类型的引用。<h3 class=fn><a name="value_type"></a>QValueListIterator::value_type</h3> 值的类型,T。<hr><h2>成员函数文档</h2><h3 class=fn><a name="QValueListIterator"></a>QValueListIterator::QValueListIterator ()</h3><p> 创建未定义的迭代器。<h3 class=fn><a name="QValueListIterator-3"></a>QValueListIterator::QValueListIterator ( const <a href="qvaluelistiterator.html">QValueListIterator</a><T> & it )</h3>这是一个重载成员函数,提供了方便。它的行为基本上和上面的函数相同。<p> 构造一个迭代器<em>it</em>的复制。<h3 class=fn>bool <a name="operator!-eq"></a>QValueListIterator::operator!= ( const <a href="qvaluelistiterator.html">QValueListIterator</a><T> & it ) const</h3><p> 比较这个迭代器和<em>it</em>并且如果它们指向不同的项,返回真,否则返回假。<h3 class=fn>T & <a name="operator*"></a>QValueListIterator::operator* ()</h3><p> 星号操作符。返回当前迭代器项的引用。<h3 class=fn>const T & <a name="operator*-2"></a>QValueListIterator::operator* () const</h3>这是一个重载成员函数,提供了方便。它的行为基本上和上面的函数相同。<p> 星号操作符。返回当前迭代器项的引用。<h3 class=fn><a href="qvaluelistiterator.html">QValueListIterator</a><T> & <a name="operator++"></a>QValueListIterator::operator++ ()</h3><p> 前置++让当前项后的一项变为当前向并且返回原来的当前项。迭代器不能检测它是否到达了列表末尾。增加这个迭代器就会返回end()导致未定义的结果。<h3 class=fn><a href="qvaluelistiterator.html">QValueListIterator</a><T> <a name="operator++-2"></a>QValueListIterator::operator++ ( int )</h3>这是一个重载成员函数,提供了方便。它的行为基本上和上面的函数相同。<p> 后置++让当前项后的一项变为当前向并且返回原来的当前项。迭代器不能检测它是否到达了列表末尾。增加这个迭代器就会返回end()导致未定义的结果。<h3 class=fn><a href="qvaluelistiterator.html">QValueListIterator</a><T> & <a name="operator--"></a>QValueListIterator::operator-- ()</h3><p> 前置--让当前项前的一项变为当前向并且返回原来的当前项。迭代器不能检测它是否到达了列表开始。增加这个迭代器就会返回begin()导致未定义的结果。<h3 class=fn><a href="qvaluelistiterator.html">QValueListIterator</a><T> <a name="operator---2"></a>QValueListIterator::operator-- ( int )</h3>这是一个重载成员函数,提供了方便。它的行为基本上和上面的函数相同。<p> 后置--让当前项前的一项变为当前向并且返回原来的当前项。迭代器不能检测它是否到达了列表开始。增加这个迭代器就会返回begin()导致未定义的结果。<h3 class=fn>bool <a name="operator-eq-eq"></a>QValueListIterator::operator== ( const <a href="qvaluelistiterator.html">QValueListIterator</a><T> & it ) const</h3><p> 比较这个迭代器和<em>it</em>并且如果它们指向相同的项,返回真,否则返回假。<!-- eof --><hr><p>这个文件是<a href="index.html">Qt工具包</a>一部分。版权所有 © 1995-2002<a href="http://www.trolltech.com/">Trolltech</a>。保留所有权利。<p><address><hr><div align=center><table width=100% cellspacing=0 border=0><tr><td>Copyright © 2002 <a href="http://www.trolltech.com">Trolltech</a><td><a href="http://www.trolltech.com/trademarks.html">Trademarks</a><td><a href="zh_CN.html">译者:Cavendish</a><td align=right><div align=right>Qt 3.0.5版</div></table></div></address></body></html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -