qmap-h.html

来自「QT 下载资料仅供参考」· HTML 代码 · 共 918 行 · 第 1/2 页

HTML
918
字号
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><!-- /home/reggie/tmp/qt-3.0-reggie-5401/qt-x11-commercial-3.0.5/include/qmap.h:1 --><html><head><meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"><title>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: #ffffff; color: black; }--></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">Home</font></a> | <a href="classes.html"><font color="#004faf">All&nbsp;Classes</font></a> | <a href="mainclasses.html"><font color="#004faf">Main&nbsp;Classes</font></a> | <a href="annotated.html"><font color="#004faf">Annotated</font></a> | <a href="groups.html"><font color="#004faf">Grouped&nbsp;Classes</font></a> | <a href="functions.html"><font color="#004faf">Functions</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>qmap.h</h1><p>This is the verbatim text of the qmap.h include file. It is provided only for illustration; the copyright remains with Trolltech.<hr><pre>/****************************************************************************** $Id:  qt/qmap.h   3.0.5   edited Jun 7 04:20 $**** 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 "qglobal.h"#include "qshared.h"#include "qdatastream.h"#include "qpair.h"#include "qtl.h"#include "qvaluelist.h"#endif // QT_H#ifndef QT_NO_STL#include &lt;iterator&gt;#include &lt;map&gt;#endif//#define QT_CHECK_MAP_RANGEstruct Q_EXPORT 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 QMapIterator{ public:    /**     * Typedefs     */    typedef QMapNode&lt; K, T &gt;* NodePtr;#ifndef QT_NO_STL    typedef std::bidirectional_iterator_tag  iterator_category;#endif    typedef T          value_type;#ifndef QT_NO_STL    typedef ptrdiff_t  difference_type;#else    typedef int difference_type;#endif    typedef T*         pointer;    typedef T&amp;         reference;    /**     * 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; }    // UDT for T = x*    // 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();    int dec();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;Q_INLINE_TEMPLATES int QMapIterator&lt;K,T&gt;::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;}template &lt;class K, class T&gt;Q_INLINE_TEMPLATES int QMapIterator&lt;K,T&gt;::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;}template&lt;class K, class T&gt;class QMapConstIterator{ public:    /**     * Typedefs     */    typedef QMapNode&lt; K, T &gt;* NodePtr;#ifndef QT_NO_STL    typedef std::bidirectional_iterator_tag  iterator_category;#endif    typedef T          value_type;#ifndef QT_NO_STL    typedef ptrdiff_t  difference_type;#else    typedef int difference_type;#endif    typedef const T*   pointer;    typedef const T&amp;   reference;    /**     * 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; }    // UDT for T = x*    // 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();    int dec();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;    }};template &lt;class K, class T&gt;Q_INLINE_TEMPLATES int QMapConstIterator&lt;K,T&gt;::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;}template &lt;class K, class T&gt;Q_INLINE_TEMPLATES int QMapConstIterator&lt;K,T&gt;::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;}class Q_EXPORT QMapPrivateBase : public QShared{public:    QMapPrivateBase() {	node_count = 0;    }    QMapPrivateBase( const QMapPrivateBase* _map) {	node_count = _map-&gt;node_count;    }    /**     * Implementations of basic tree algorithms     */    void rotateLeft( QMapNodeBase* x, QMapNodeBase*&amp; root);    void rotateRight( QMapNodeBase* x, QMapNodeBase*&amp; root );    void rebalance( QMapNodeBase* x, QMapNodeBase*&amp; root );    QMapNodeBase* removeAndRebalance( QMapNodeBase* z, QMapNodeBase*&amp; root,				      QMapNodeBase*&amp; leftmost,				      QMapNodeBase*&amp; rightmost );    /**     * Variables     */    int node_count;};template &lt;class Key, class T&gt;class QMapPrivate : public QMapPrivateBase{public:    /**     * Typedefs     */    typedef QMapIterator&lt; Key, T &gt; Iterator;    typedef QMapConstIterator&lt; Key, T &gt; ConstIterator;    typedef QMapNode&lt; Key, T &gt; Node;    typedef QMapNode&lt; Key, T &gt;* NodePtr;    /**     * Functions     */    QMapPrivate();    QMapPrivate( const QMapPrivate&lt; Key, T &gt;* _map );    ~QMapPrivate() { clear(); delete header; }    NodePtr copy( NodePtr p );    void clear();    void clear( NodePtr p );    Iterator begin()	{ return Iterator( (NodePtr)(header-&gt;left ) ); }    Iterator end()	{ return Iterator( header ); }    ConstIterator begin() const { return ConstIterator( (NodePtr)(header-&gt;left ) ); }    ConstIterator end() const { return ConstIterator( header ); }    ConstIterator find(const Key&amp; k) const;    void remove( Iterator it ) {	NodePtr del = (NodePtr) removeAndRebalance( it.node, header-&gt;parent, header-&gt;left, header-&gt;right );	delete del;	--node_count;    }#ifdef QT_QMAP_DEBUG    void inorder( QMapNodeBase* x = 0, int level = 0 ){	if ( !x )	    x = header-&gt;parent;	if ( x-&gt;left )	    inorder( x-&gt;left, level + 1 );    //cout &lt;&lt; level &lt;&lt; " Key=" &lt;&lt; key(x) &lt;&lt; " Value=" &lt;&lt; ((NodePtr)x)-&gt;data &lt;&lt; endl;	if ( x-&gt;right )	    inorder( x-&gt;right, level + 1 );    }#endif#if 0    Iterator insertMulti(const Key&amp; v){	QMapNodeBase* y = header;	QMapNodeBase* x = header-&gt;parent;	while (x != 0){	    y = x;	    x = ( v &lt; key(x) ) ? x-&gt;left : x-&gt;right;	}	return insert(x, y, v);    }#endif    Iterator insertSingle( const Key&amp; k );    Iterator insert( QMapNodeBase* x, QMapNodeBase* y, const Key&amp; k );protected:    /**     * Helpers     */    const Key&amp; key( QMapNodeBase* b ) const { return ((NodePtr)b)-&gt;key; }    /**

⌨️ 快捷键说明

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