⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qmap-h.html

📁 qtopiaphone英文帮助,用于初学者和开发人员,初学者可以用来学习,开发人员可以用来资料查询.
💻 HTML
📖 第 1 页 / 共 2 页
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>Qt Toolkit - qmap.h include file</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: white; color: black; }--></style></head><body bgcolor="#ffffff"><table width="100%"><tr><td><a href="index.html"><img width="100" height="100" src="qtlogo.png"alt="Home" border="0"><img width="100"height="100" src="face.png" alt="Home" border="0"></a><td valign="top"><div align="right"><img src="dochead.png" width="472" height="27"><br><a href="classes.html"><b>Classes</b></a>- <a href="annotated.html">Annotated</a>- <a href="hierarchy.html">Tree</a>- <a href="functions.html">Functions</a>- <a href="index.html">Home</a>- <a href="topicals.html"><b>Structure</b>  <font face="Arial,Helvetica,Geneva,Swiss,SunSans-Regular" align="center" size=32>Qte</font></a></div></table><h1 align=center>qmap.h</h1><br clear="all">This is the verbatim text of the qmap.h include file.  It isprovided only for illustration; the copyrightremains with Trolltech.<hr><pre>/****************************************************************************** &#36;Id&#58; qt/src/tools/qmap.h   2.3.8   edited 2004-05-12 $**** Definition of QMap class**** Created : 990406**** Copyright (C) 1992-2000 Trolltech AS.  All rights reserved.**** This file is part of the tools module of the Qt GUI Toolkit.**** This file may be distributed under the terms of the Q Public License** as defined by Trolltech AS of Norway and appearing in the file** LICENSE.QPL included in the packaging of this file.**** This file may be distributed and/or modified under the terms of the** GNU General Public License version 2 as published by the Free Software** Foundation and appearing in the file LICENSE.GPL included in the** packaging of this file.**** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition** licenses may use this file in accordance with the Qt Commercial License** Agreement provided with the Software.**** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.**** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for**   information about Qt Commercial License Agreements.** See http://www.trolltech.com/qpl/ for QPL licensing information.** See http://www.trolltech.com/gpl/ for GPL licensing information.**** Contact info@trolltech.com if any conditions of this licensing are** not clear to you.************************************************************************/#ifndef QMAP_H#define QMAP_H#ifndef QT_H#include "qshared.h"#include "qdatastream.h"#endif // QT_Hstruct QMapNodeBase{    enum Color { Red, Black };    QMapNodeBase* left;    QMapNodeBase* right;    QMapNodeBase* parent;    Color color;    QMapNodeBase* minimum() {        QMapNodeBase* x = this;        while ( x-&gt;left )            x = x-&gt;left;        return x;    }    QMapNodeBase* maximum() {        QMapNodeBase* x = this;        while ( x-&gt;right )            x = x-&gt;right;        return x;    }};template &lt;class K, class T&gt;struct QMapNode : public QMapNodeBase{    QMapNode( const K&amp; _key, const T&amp; _data ) { data = _data; key = _key; }    QMapNode( const K&amp; _key )      { key = _key; }    QMapNode( const QMapNode&lt;K,T&gt;&amp; _n ) { key = _n.key; data = _n.data; }    QMapNode() { }    T data;    K key;};template&lt;class K, class T&gt;class Q_EXPORT <a href="qmapiterator.html">QMapIterator</a>{ public:    /**     * Typedefs     */    typedef QMapNode&lt; K, T &gt;* NodePtr;    /**     * Variables     */    QMapNode&lt;K,T&gt;* node;    /**     * Functions     */    QMapIterator() : node( 0 ) {}    QMapIterator( QMapNode&lt;K,T&gt;* p ) : node( p ) {}    QMapIterator( const QMapIterator&lt;K,T&gt;&amp; it ) : node( it.node ) {}    bool operator==( const QMapIterator&lt;K,T&gt;&amp; it ) const { return node == it.node; }    bool operator!=( const QMapIterator&lt;K,T&gt;&amp; it ) const { return node != it.node; }    T&amp; operator*() { return node-&gt;data; }    const T&amp; operator*() const { return node-&gt;data; }    // Cannot have this - some compilers are too stupid    //T* operator-&gt;() const { return &amp;(node-&gt;data); }    const K&amp; key() const { return node-&gt;key; }    T&amp; data() { return node-&gt;data; }    const T&amp; data() const { return node-&gt;data; }private:    int inc() {        QMapNodeBase* tmp = node;        if ( tmp-&gt;right ) {            tmp = tmp-&gt;right;            while ( tmp-&gt;left )                tmp = tmp-&gt;left;        } else {            QMapNodeBase* y = tmp-&gt;parent;            while (tmp == y-&gt;right) {                tmp = y;                y = y-&gt;parent;            }            if (tmp-&gt;right != y)                tmp = y;        }        node = (NodePtr)tmp;        return 0;    }    int dec() {        QMapNodeBase* tmp = node;        if (tmp-&gt;color == QMapNodeBase::Red &amp;&amp;            tmp-&gt;parent-&gt;parent == tmp ) {            tmp = tmp-&gt;right;        } else if (tmp-&gt;left != 0) {            QMapNodeBase* y = tmp-&gt;left;            while ( y-&gt;right )                y = y-&gt;right;            tmp = y;        } else {            QMapNodeBase* y = tmp-&gt;parent;            while (tmp == y-&gt;left) {                tmp = y;                y = y-&gt;parent;            }            tmp = y;        }        node = (NodePtr)tmp;        return 0;    }public:    QMapIterator&lt;K,T&gt;&amp; operator++() {        inc();        return *this;    }    QMapIterator&lt;K,T&gt; operator++(int) {        QMapIterator&lt;K,T&gt; tmp = *this;        inc();        return tmp;    }    QMapIterator&lt;K,T&gt;&amp; operator--() {        dec();        return *this;    }    QMapIterator&lt;K,T&gt; operator--(int) {        QMapIterator&lt;K,T&gt; tmp = *this;        dec();        return tmp;    }};template&lt;class K, class T&gt;class Q_EXPORT <a href="qmapconstiterator.html">QMapConstIterator</a>{ public:    /**     * Typedefs     */    typedef QMapNode&lt; K, T &gt;* NodePtr;    /**     * Variables     */    QMapNode&lt;K,T&gt;* node;    /**     * Functions     */    QMapConstIterator() : node( 0 ) {}    QMapConstIterator( QMapNode&lt;K,T&gt;* p ) : node( p ) {}    QMapConstIterator( const QMapConstIterator&lt;K,T&gt;&amp; it ) : node( it.node ) {}    QMapConstIterator( const QMapIterator&lt;K,T&gt;&amp; it ) : node( it.node ) {}    bool operator==( const QMapConstIterator&lt;K,T&gt;&amp; it ) const { return node == it.node; }    bool operator!=( const QMapConstIterator&lt;K,T&gt;&amp; it ) const { return node != it.node; }    const T&amp; operator*()  const { return node-&gt;data; }    // Cannot have this - some compilers are too stupid    //const T* operator-&gt;() const { return &amp;(node-&gt;data); }    const K&amp; key() const { return node-&gt;key; }    const T&amp; data() const { return node-&gt;data; }private:    int inc() {        QMapNodeBase* tmp = node;        if ( tmp-&gt;right ) {            tmp = tmp-&gt;right;            while ( tmp-&gt;left )                tmp = tmp-&gt;left;        } else {            QMapNodeBase* y = tmp-&gt;parent;            while (tmp == y-&gt;right) {                tmp = y;                y = y-&gt;parent;            }            if (tmp-&gt;right != y)                tmp = y;        }        node = (NodePtr)tmp;        return 0;    }    int dec() {        QMapNodeBase* tmp = node;        if (tmp-&gt;color == QMapNodeBase::Red &amp;&amp;            tmp-&gt;parent-&gt;parent == tmp ) {            tmp = tmp-&gt;right;        } else if (tmp-&gt;left != 0) {            QMapNodeBase* y = tmp-&gt;left;            while ( y-&gt;right )                y = y-&gt;right;            tmp = y;        } else {            QMapNodeBase* y = tmp-&gt;parent;            while (tmp == y-&gt;left) {                tmp = y;                y = y-&gt;parent;            }            tmp = y;        }        node = (NodePtr)tmp;        return 0;    }public:    QMapConstIterator&lt;K,T&gt;&amp; operator++() {        inc();        return *this;    }    QMapConstIterator&lt;K,T&gt; operator++(int) {        QMapConstIterator&lt;K,T&gt; tmp = *this;        inc();        return tmp;    }    QMapConstIterator&lt;K,T&gt;&amp; operator--() {        dec();        return *this;    }    QMapConstIterator&lt;K,T&gt; operator--(int) {        QMapConstIterator&lt;K,T&gt; tmp = *this;        dec();        return tmp;    }};class Q_EXPORT QMapPrivateBase : public <a href="qshared.html">QShared</a>{public:    QMapPrivateBase() {        node_count = 0;    }    QMapPrivateBase( const QMapPrivateBase* _map) {        node_count = _map-&gt;node_count;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -