Sophie

Sophie

distrib > Fedora > 18 > x86_64 > by-pkgid > ff187cb994c94c614ecc64c5a8528b1b > files > 5481

qt-doc-4.8.5-10.fc18.noarch.rpm

<?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" />
<!-- qhash.cpp -->
  <title>Qt 4.8: QHash Class Reference</title>
  <link rel="stylesheet" type="text/css" href="style/style.css" />
  <script src="scripts/jquery.js" type="text/javascript"></script>
  <script src="scripts/functions.js" type="text/javascript"></script>
  <link rel="stylesheet" type="text/css" href="style/superfish.css" />
  <link rel="stylesheet" type="text/css" href="style/narrow.css" />
  <!--[if IE]>
<meta name="MSSmartTagsPreventParsing" content="true">
<meta http-equiv="imagetoolbar" content="no">
<![endif]-->
<!--[if lt IE 7]>
<link rel="stylesheet" type="text/css" href="style/style_ie6.css">
<![endif]-->
<!--[if IE 7]>
<link rel="stylesheet" type="text/css" href="style/style_ie7.css">
<![endif]-->
<!--[if IE 8]>
<link rel="stylesheet" type="text/css" href="style/style_ie8.css">
<![endif]-->

<script src="scripts/superfish.js" type="text/javascript"></script>
<script src="scripts/narrow.js" type="text/javascript"></script>

</head>
<body class="" onload="CheckEmptyAndLoadList();">
 <div class="header" id="qtdocheader">
    <div class="content"> 
    <div id="nav-logo">
      <a href="index.html">Home</a></div>
    <a href="index.html" class="qtref"><span>Qt Reference Documentation</span></a>
    <div id="narrowsearch"></div>
    <div id="nav-topright">
      <ul>
        <li class="nav-topright-home"><a href="http://qt.digia.com/">Qt HOME</a></li>
        <li class="nav-topright-dev"><a href="http://qt-project.org/">DEV</a></li>
        <li class="nav-topright-doc nav-topright-doc-active"><a href="http://qt-project.org/doc/">
          DOC</a></li>
        <li class="nav-topright-blog"><a href="http://blog.qt.digia.com/">BLOG</a></li>
      </ul>
    </div>
    <div id="shortCut">
      <ul>
        <li class="shortCut-topleft-inactive"><span><a href="index.html">Qt 4.8</a></span></li>
        <li class="shortCut-topleft-active"><a href="http://qt-project.org/doc/">ALL VERSIONS        </a></li>
      </ul>
     </div>
 <ul class="sf-menu" id="narrowmenu"> 
             <li><a href="#">API Lookup</a> 
                 <ul> 
                     <li><a href="classes.html">Class index</a></li> 
           <li><a href="functions.html">Function index</a></li> 
           <li><a href="modules.html">Modules</a></li> 
           <li><a href="namespaces.html">Namespaces</a></li> 
           <li><a href="qtglobal.html">Global Declarations</a></li> 
           <li><a href="qdeclarativeelements.html">QML elements</a></li> 
             </ul> 
             </li> 
             <li><a href="#">Qt Topics</a> 
                 <ul> 
                        <li><a href="qt-basic-concepts.html">Programming with Qt</a></li>  
                        <li><a href="qtquick.html">Device UIs &amp; Qt Quick</a></li>  
                        <li><a href="qt-gui-concepts.html">UI Design with Qt</a></li>  
                        <li><a href="supported-platforms.html">Supported Platforms</a></li>  
                        <li><a href="technology-apis.html">Qt and Key Technologies</a></li>  
                        <li><a href="best-practices.html">How-To's and Best Practices</a></li>  
              </ul> 
                 </li> 
                 <li><a href="#">Examples</a> 
                     <ul> 
                       <li><a href="all-examples.html">Examples</a></li> 
                       <li><a href="tutorials.html">Tutorials</a></li> 
                       <li><a href="demos.html">Demos</a></li> 
                       <li><a href="qdeclarativeexamples.html">QML Examples</a></li> 
                </ul> 
                     </li> 
                 </ul> 
    </div>
  </div>
  <div class="wrapper">
    <div class="hd">
      <span></span>
    </div>
    <div class="bd group">
      <div class="sidebar">
        <div class="searchlabel">
          Search index:</div>
        <div class="search" id="sidebarsearch">
          <form id="qtdocsearch" action="" onsubmit="return false;">
            <fieldset>
              <input type="text" name="searchstring" id="pageType" value="" />
 <div id="resultdialog"> 
 <a href="#" id="resultclose">Close</a> 
 <p id="resultlinks" class="all"><a href="#" id="showallresults">All</a> | <a href="#" id="showapiresults">API</a> | <a href="#" id="showarticleresults">Articles</a> | <a href="#" id="showexampleresults">Examples</a></p> 
 <p id="searchcount" class="all"><span id="resultcount"></span><span id="apicount"></span><span id="articlecount"></span><span id="examplecount"></span>&nbsp;results:</p> 
 <ul id="resultlist" class="all"> 
 </ul> 
 </div> 
            </fieldset>
          </form>
        </div>
        <div class="box first bottombar" id="lookup">
          <h2 title="API Lookup"><span></span>
            API Lookup</h2>
          <div  id="list001" class="list">
          <ul id="ul001" >
              <li class="defaultLink"><a href="classes.html">Class index</a></li>
              <li class="defaultLink"><a href="functions.html">Function index</a></li>
              <li class="defaultLink"><a href="modules.html">Modules</a></li>
              <li class="defaultLink"><a href="namespaces.html">Namespaces</a></li>
              <li class="defaultLink"><a href="qtglobal.html">Global Declarations</a></li>
              <li class="defaultLink"><a href="qdeclarativeelements.html">QML elements</a></li>
            </ul> 
          </div>
        </div>
        <div class="box bottombar" id="topics">
          <h2 title="Qt Topics"><span></span>
            Qt Topics</h2>
          <div id="list002" class="list">
            <ul id="ul002" >
               <li class="defaultLink"><a href="qt-basic-concepts.html">Programming with Qt</a></li> 
               <li class="defaultLink"><a href="qtquick.html">Device UIs &amp; Qt Quick</a></li> 
               <li class="defaultLink"><a href="qt-gui-concepts.html">UI Design with Qt</a></li> 
               <li class="defaultLink"><a href="supported-platforms.html">Supported Platforms</a></li>  
               <li class="defaultLink"><a href="technology-apis.html">Qt and Key Technologies</a></li> 
               <li class="defaultLink"><a href="best-practices.html">How-To's and Best Practices</a></li> 
            </ul>  
          </div>
        </div>
        <div class="box" id="examples">
          <h2 title="Examples"><span></span>
            Examples</h2>
          <div id="list003" class="list">
        <ul id="ul003">
              <li class="defaultLink"><a href="all-examples.html">Examples</a></li>
              <li class="defaultLink"><a href="tutorials.html">Tutorials</a></li>
              <li class="defaultLink"><a href="demos.html">Demos</a></li>
              <li class="defaultLink"><a href="qdeclarativeexamples.html">QML Examples</a></li>
            </ul> 
          </div>
        </div>
      </div>
      <div class="wrap">
        <div class="toolbar">
          <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>QHash</li>
            </ul>
          </div>
          <div class="toolbuttons toolblock">
            <ul>
              <li id="smallA" class="t_button">A</li>
              <li id="medA" class="t_button active">A</li>
              <li id="bigA" class="t_button">A</li>
              <li id="print" class="t_button"><a href="javascript:this.print();">
                <span>Print</span></a></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-types">Public Types</a></li>
<li class="level1"><a href="#public-functions">Public Functions</a></li>
<li class="level1"><a href="#related-non-members">Related Non-Members</a></li>
<li class="level1"><a href="#details">Detailed Description</a></li>
</ul>
</div>
<h1 class="title">QHash Class Reference</h1>
<!-- $$$QHash-brief -->
<p>The QHash class is a template class that provides a hash-table-based dictionary. <a href="#details">More...</a></p>
<!-- @@@QHash -->
<pre class="cpp"> <span class="preprocessor">#include &lt;QHash&gt;</span></pre><p><b>Inherited by: </b><a href="qmultihash.html">QMultiHash</a>.</p>
<p><b>Note:</b> All functions in this class are <a href="threads-reentrancy.html#reentrant">reentrant</a>.</p>
<ul>
<li><a href="qhash-members.html">List of all members, including inherited members</a></li>
</ul>
<a name="public-types"></a>
<h2>Public Types</h2>
<table class="alignedsummary">
<tr><td class="memItemLeft rightAlign topAlign"> class </td><td class="memItemRight bottomAlign"><b><a href="qhash-const-iterator.html">const_iterator</a></b></td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> class </td><td class="memItemRight bottomAlign"><b><a href="qhash-iterator.html">iterator</a></b></td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> typedef </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#ConstIterator-typedef">ConstIterator</a></b></td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> typedef </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#Iterator-typedef">Iterator</a></b></td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> typedef </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#difference_type-typedef">difference_type</a></b></td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> typedef </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#key_type-typedef">key_type</a></b></td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> typedef </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#mapped_type-typedef">mapped_type</a></b></td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> typedef </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#size_type-typedef">size_type</a></b></td></tr>
</table>
<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="qhash.html#QHashx">QHash</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#QHash-2">QHash</a></b> ( const QHash&lt;Key, T&gt; &amp; <i>other</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#dtor.QHash">~QHash</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#begin">begin</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const_iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#begin-2">begin</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> int </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#capacity">capacity</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#clear">clear</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const_iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#constBegin">constBegin</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const_iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#constEnd">constEnd</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const_iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#constFind">constFind</a></b> ( const Key &amp; <i>key</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#contains">contains</a></b> ( const Key &amp; <i>key</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> int </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#count">count</a></b> ( const Key &amp; <i>key</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> int </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#count-2">count</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#empty">empty</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#end">end</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const_iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#end-2">end</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#erase">erase</a></b> ( iterator <i>pos</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#find">find</a></b> ( const Key &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const_iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#find-2">find</a></b> ( const Key &amp; <i>key</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#insert">insert</a></b> ( const Key &amp; <i>key</i>, const T &amp; <i>value</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> iterator </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#insertMulti">insertMulti</a></b> ( const Key &amp; <i>key</i>, const T &amp; <i>value</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#isEmpty">isEmpty</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const Key </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#key">key</a></b> ( const T &amp; <i>value</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const Key </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#key-2">key</a></b> ( const T &amp; <i>value</i>, const Key &amp; <i>defaultKey</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QList&lt;Key&gt; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#keys">keys</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QList&lt;Key&gt; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#keys-2">keys</a></b> ( const T &amp; <i>value</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> int </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#remove">remove</a></b> ( const Key &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#reserve">reserve</a></b> ( int <i>size</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> int </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#size">size</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#squeeze">squeeze</a></b> ()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#swap">swap</a></b> ( QHash&lt;Key, T&gt; &amp; <i>other</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> T </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#take">take</a></b> ( const Key &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QList&lt;Key&gt; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#uniqueKeys">uniqueKeys</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QHash&lt;Key, T&gt; &amp; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#unite">unite</a></b> ( const QHash&lt;Key, T&gt; &amp; <i>other</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const T </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#value">value</a></b> ( const Key &amp; <i>key</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const T </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#value-2">value</a></b> ( const Key &amp; <i>key</i>, const T &amp; <i>defaultValue</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QList&lt;T&gt; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#values">values</a></b> () const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QList&lt;T&gt; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#values-2">values</a></b> ( const Key &amp; <i>key</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#operator-not-eq">operator!=</a></b> ( const QHash&lt;Key, T&gt; &amp; <i>other</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QHash&lt;Key, T&gt; &amp; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#operator-eq">operator=</a></b> ( const QHash&lt;Key, T&gt; &amp; <i>other</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> bool </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#operator-eq-eq">operator==</a></b> ( const QHash&lt;Key, T&gt; &amp; <i>other</i> ) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> T &amp; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#operator-5b-5d">operator[]</a></b> ( const Key &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> const T </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#operator-5b-5d-2">operator[]</a></b> ( const Key &amp; <i>key</i> ) const</td></tr>
</table>
<a name="related-non-members"></a>
<h2>Related Non-Members</h2>
<table class="alignedsummary">
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash">qHash</a></b> ( const QXmlNodeModelIndex &amp; <i>index</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-36">qHash</a></b> ( qint64 <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-37">qHash</a></b> ( QChar <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-38">qHash</a></b> ( const QByteArray &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-41">qHash</a></b> ( const QBitArray &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-42">qHash</a></b> ( const T * <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-43">qHash</a></b> ( const QPair&lt;T1, T2&gt; &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-11">qHash</a></b> ( const QString &amp; <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-26">qHash</a></b> ( char <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-27">qHash</a></b> ( uchar <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-28">qHash</a></b> ( signed char <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-29">qHash</a></b> ( ushort <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-30">qHash</a></b> ( short <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-31">qHash</a></b> ( uint <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-32">qHash</a></b> ( int <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-33">qHash</a></b> ( ulong <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-34">qHash</a></b> ( long <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> uint </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#qHash-35">qHash</a></b> ( quint64 <i>key</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QDataStream &amp; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#operator-lt-lt-15">operator&lt;&lt;</a></b> ( QDataStream &amp; <i>out</i>, const QHash&lt;Key, T&gt; &amp; <i>hash</i> )</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QDataStream &amp; </td><td class="memItemRight bottomAlign"><b><a href="qhash.html#operator-gt-gt-12">operator&gt;&gt;</a></b> ( QDataStream &amp; <i>in</i>, QHash&lt;Key, T&gt; &amp; <i>hash</i> )</td></tr>
</table>
<a name="details"></a>
<!-- $$$QHash-description -->
<div class="descr">
<h2>Detailed Description</h2>
<p>The QHash class is a template class that provides a hash-table-based dictionary.</p>
<p>QHash&lt;Key, T&gt; is one of Qt's generic <a href="containers.html">container classes</a>. It stores (key, value) pairs and provides very fast lookup of the value associated with a key.</p>
<p>QHash provides very similar functionality to <a href="qmap.html">QMap</a>. The differences are:</p>
<ul>
<li>QHash provides faster lookups than <a href="qmap.html">QMap</a>. (See <a href="containers.html#algorithmic-complexity">Algorithmic Complexity</a> for details.)</li>
<li>When iterating over a <a href="qmap.html">QMap</a>, the items are always sorted by key. With QHash, the items are arbitrarily ordered.</li>
<li>The key type of a <a href="qmap.html">QMap</a> must provide operator&lt;(). The key type of a QHash must provide operator==() and a global hash function called <a href="qhash.html#qHash">qHash</a>() (see the related non-member functions).</li>
</ul>
<p>Here's an example QHash with <a href="qstring.html">QString</a> keys and <tt>int</tt> values:</p>
<pre class="cpp"> <span class="type">QHash</span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span> hash;</pre>
<p>To insert a (key, value) pair into the hash, you can use operator[]():</p>
<pre class="cpp"> hash<span class="operator">[</span><span class="string">&quot;one&quot;</span><span class="operator">]</span> <span class="operator">=</span> <span class="number">1</span>;
 hash<span class="operator">[</span><span class="string">&quot;three&quot;</span><span class="operator">]</span> <span class="operator">=</span> <span class="number">3</span>;
 hash<span class="operator">[</span><span class="string">&quot;seven&quot;</span><span class="operator">]</span> <span class="operator">=</span> <span class="number">7</span>;</pre>
<p>This inserts the following three (key, value) pairs into the QHash: (&quot;one&quot;, 1), (&quot;three&quot;, 3), and (&quot;seven&quot;, 7). Another way to insert items into the hash is to use <a href="qhash.html#insert">insert</a>():</p>
<pre class="cpp"> hash<span class="operator">.</span><a href="qhash.html#insert">insert</a>(<span class="string">&quot;twelve&quot;</span><span class="operator">,</span> <span class="number">12</span>);</pre>
<p>To look up a value, use operator[]() or <a href="qhash.html#value">value</a>():</p>
<pre class="cpp"> <span class="type">int</span> num1 <span class="operator">=</span> hash<span class="operator">[</span><span class="string">&quot;thirteen&quot;</span><span class="operator">]</span>;
 <span class="type">int</span> num2 <span class="operator">=</span> hash<span class="operator">.</span><a href="qhash.html#value">value</a>(<span class="string">&quot;thirteen&quot;</span>);</pre>
<p>If there is no item with the specified key in the hash, these functions return a <a href="containers.html#default-constructed-values">default-constructed value</a>.</p>
<p>If you want to check whether the hash contains a particular key, use <a href="qhash.html#contains">contains</a>():</p>
<pre class="cpp"> <span class="type">int</span> timeout <span class="operator">=</span> <span class="number">30</span>;
 <span class="keyword">if</span> (hash<span class="operator">.</span>contains(<span class="string">&quot;TIMEOUT&quot;</span>))
     timeout <span class="operator">=</span> hash<span class="operator">.</span><a href="qhash.html#value">value</a>(<span class="string">&quot;TIMEOUT&quot;</span>);</pre>
<p>There is also a <a href="qhash.html#value">value</a>() overload that uses its second argument as a default value if there is no item with the specified key:</p>
<pre class="cpp"> <span class="type">int</span> timeout <span class="operator">=</span> hash<span class="operator">.</span><a href="qhash.html#value">value</a>(<span class="string">&quot;TIMEOUT&quot;</span><span class="operator">,</span> <span class="number">30</span>);</pre>
<p>In general, we recommend that you use <a href="qhash.html#contains">contains</a>() and <a href="qhash.html#value">value</a>() rather than operator[]() for looking up a key in a hash. The reason is that operator[]() silently inserts an item into the hash if no item exists with the same key (unless the hash is const). For example, the following code snippet will create 1000 items in memory:</p>
<pre class="cpp"> <span class="comment">// WRONG</span>
 <span class="type">QHash</span><span class="operator">&lt;</span><span class="type">int</span><span class="operator">,</span> <span class="type"><a href="qwidget.html">QWidget</a></span> <span class="operator">*</span><span class="operator">&gt;</span> hash;
 <span class="operator">.</span><span class="operator">.</span><span class="operator">.</span>
 <span class="keyword">for</span> (<span class="type">int</span> i <span class="operator">=</span> <span class="number">0</span>; i <span class="operator">&lt;</span> <span class="number">1000</span>; <span class="operator">+</span><span class="operator">+</span>i) {
     <span class="keyword">if</span> (hash<span class="operator">[</span>i<span class="operator">]</span> <span class="operator">=</span><span class="operator">=</span> okButton)
         cout <span class="operator">&lt;</span><span class="operator">&lt;</span> <span class="string">&quot;Found button at index &quot;</span> <span class="operator">&lt;</span><span class="operator">&lt;</span> i <span class="operator">&lt;</span><span class="operator">&lt;</span> endl;
 }</pre>
<p>To avoid this problem, replace <tt>hash[i]</tt> with <tt>hash.value(i)</tt> in the code above.</p>
<p>If you want to navigate through all the (key, value) pairs stored in a QHash, you can use an iterator. QHash provides both <a href="containers.html#java-style-iterators">Java-style iterators</a> (<a href="qhashiterator.html">QHashIterator</a> and <a href="qmutablehashiterator.html">QMutableHashIterator</a>) and <a href="containers.html#stl-style-iterators">STL-style iterators</a> (<a href="qhash-const-iterator.html">QHash::const_iterator</a> and <a href="qhash-iterator.html">QHash::iterator</a>). Here's how to iterate over a QHash&lt;<a href="qstring.html">QString</a>, int&gt; using a Java-style iterator:</p>
<pre class="cpp"> <span class="type"><a href="qhashiterator.html">QHashIterator</a></span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span> i(hash);
 <span class="keyword">while</span> (i<span class="operator">.</span>hasNext()) {
     i<span class="operator">.</span>next();
     cout <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span>key() <span class="operator">&lt;</span><span class="operator">&lt;</span> <span class="string">&quot;: &quot;</span> <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span>value() <span class="operator">&lt;</span><span class="operator">&lt;</span> endl;
 }</pre>
<p>Here's the same code, but using an STL-style iterator:</p>
<pre class="cpp"> <span class="type">QHash</span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span><span class="operator">::</span>const_iterator i <span class="operator">=</span> hash<span class="operator">.</span><a href="qhash.html#constBegin">constBegin</a>();
 <span class="keyword">while</span> (i <span class="operator">!</span><span class="operator">=</span> hash<span class="operator">.</span>constEnd()) {
     cout <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span>key() <span class="operator">&lt;</span><span class="operator">&lt;</span> <span class="string">&quot;: &quot;</span> <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span>value() <span class="operator">&lt;</span><span class="operator">&lt;</span> endl;
     <span class="operator">+</span><span class="operator">+</span>i;
 }</pre>
<p>QHash is unordered, so an iterator's sequence cannot be assumed to be predictable. If ordering by key is required, use a <a href="qmap.html">QMap</a>.</p>
<p>Normally, a QHash allows only one value per key. If you call <a href="qhash.html#insert">insert</a>() with a key that already exists in the QHash, the previous value is erased. For example:</p>
<pre class="cpp"> hash<span class="operator">.</span><a href="qhash.html#insert">insert</a>(<span class="string">&quot;plenty&quot;</span><span class="operator">,</span> <span class="number">100</span>);
 hash<span class="operator">.</span><a href="qhash.html#insert">insert</a>(<span class="string">&quot;plenty&quot;</span><span class="operator">,</span> <span class="number">2000</span>);
 <span class="comment">// hash.value(&quot;plenty&quot;) == 2000</span></pre>
<p>However, you can store multiple values per key by using <a href="qhash.html#insertMulti">insertMulti</a>() instead of <a href="qhash.html#insert">insert</a>() (or using the convenience subclass <a href="qmultihash.html">QMultiHash</a>). If you want to retrieve all the values for a single key, you can use values(const Key &amp;key), which returns a <a href="qlist.html">QList</a>&lt;T&gt;:</p>
<pre class="cpp"> <span class="type"><a href="qlist.html">QList</a></span><span class="operator">&lt;</span><span class="type">int</span><span class="operator">&gt;</span> values <span class="operator">=</span> hash<span class="operator">.</span><a href="qhash.html#values">values</a>(<span class="string">&quot;plenty&quot;</span>);
 <span class="keyword">for</span> (<span class="type">int</span> i <span class="operator">=</span> <span class="number">0</span>; i <span class="operator">&lt;</span> values<span class="operator">.</span>size(); <span class="operator">+</span><span class="operator">+</span>i)
     cout <span class="operator">&lt;</span><span class="operator">&lt;</span> values<span class="operator">.</span>at(i) <span class="operator">&lt;</span><span class="operator">&lt;</span> endl;</pre>
<p>The items that share the same key are available from most recently to least recently inserted. A more efficient approach is to call <a href="qhash.html#find">find</a>() to get the iterator for the first item with a key and iterate from there:</p>
<pre class="cpp"> <span class="type">QHash</span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span><span class="operator">::</span>iterator i <span class="operator">=</span> hash<span class="operator">.</span><a href="qhash.html#find">find</a>(<span class="string">&quot;plenty&quot;</span>);
 <span class="keyword">while</span> (i <span class="operator">!</span><span class="operator">=</span> hash<span class="operator">.</span>end() <span class="operator">&amp;</span><span class="operator">&amp;</span> i<span class="operator">.</span>key() <span class="operator">=</span><span class="operator">=</span> <span class="string">&quot;plenty&quot;</span>) {
     cout <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span>value() <span class="operator">&lt;</span><span class="operator">&lt;</span> endl;
     <span class="operator">+</span><span class="operator">+</span>i;
 }</pre>
<p>If you only need to extract the values from a hash (not the keys), you can also use <a href="containers.html#foreach">foreach</a>:</p>
<pre class="cpp"> <span class="type">QHash</span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span> hash;
 <span class="operator">.</span><span class="operator">.</span><span class="operator">.</span>
 <a href="qtglobal.html#foreach">foreach</a> (<span class="type">int</span> value<span class="operator">,</span> hash)
     cout <span class="operator">&lt;</span><span class="operator">&lt;</span> value <span class="operator">&lt;</span><span class="operator">&lt;</span> endl;</pre>
<p>Items can be removed from the hash in several ways. One way is to call <a href="qhash.html#remove">remove</a>(); this will remove any item with the given key. Another way is to use <a href="qmutablehashiterator.html#remove">QMutableHashIterator::remove</a>(). In addition, you can clear the entire hash using <a href="qhash.html#clear">clear</a>().</p>
<p>QHash's key and value data types must be <a href="containers.html#assignable-data-types">assignable data types</a>. You cannot, for example, store a <a href="qwidget.html">QWidget</a> as a value; instead, store a <a href="qwidget.html">QWidget</a> *. In addition, QHash's key type must provide operator==(), and there must also be a global <a href="qhash.html#qHash">qHash</a>() function that returns a hash value for an argument of the key's type.</p>
<p>Here's a list of the C++ and Qt types that can serve as keys in a QHash: any integer type (char, unsigned long, etc.), any pointer type, <a href="qchar.html">QChar</a>, <a href="qstring.html">QString</a>, and <a href="qbytearray.html">QByteArray</a>. For all of these, the <tt>&lt;QHash&gt;</tt> header defines a <a href="qhash.html#qHash">qHash</a>() function that computes an adequate hash value. If you want to use other types as the key, make sure that you provide operator==() and a <a href="qhash.html#qHash">qHash</a>() implementation.</p>
<p>Example:</p>
<pre class="cpp"> <span class="preprocessor">#ifndef EMPLOYEE_H</span>
 <span class="preprocessor">#define EMPLOYEE_H</span>

 <span class="keyword">class</span> Employee
 {
 <span class="keyword">public</span>:
     Employee() {}
     Employee(<span class="keyword">const</span> <span class="type"><a href="qstring.html">QString</a></span> <span class="operator">&amp;</span>name<span class="operator">,</span> <span class="keyword">const</span> <span class="type"><a href="qdate.html">QDate</a></span> <span class="operator">&amp;</span>dateOfBirth);
     <span class="operator">.</span><span class="operator">.</span><span class="operator">.</span>

 <span class="keyword">private</span>:
     <span class="type"><a href="qstring.html">QString</a></span> myName;
     <span class="type"><a href="qdate.html">QDate</a></span> myDateOfBirth;
 };

 <span class="keyword">inline</span> <span class="type">bool</span> <span class="keyword">operator</span><span class="operator">=</span><span class="operator">=</span>(<span class="keyword">const</span> Employee <span class="operator">&amp;</span>e1<span class="operator">,</span> <span class="keyword">const</span> Employee <span class="operator">&amp;</span>e2)
 {
     <span class="keyword">return</span> e1<span class="operator">.</span>name() <span class="operator">=</span><span class="operator">=</span> e2<span class="operator">.</span>name()
            <span class="operator">&amp;</span><span class="operator">&amp;</span> e1<span class="operator">.</span>dateOfBirth() <span class="operator">=</span><span class="operator">=</span> e2<span class="operator">.</span>dateOfBirth();
 }

 <span class="keyword">inline</span> <span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <a href="qhash.html#qHash">qHash</a>(<span class="keyword">const</span> Employee <span class="operator">&amp;</span>key)
 {
     <span class="keyword">return</span> <a href="qhash.html#qHash">qHash</a>(key<span class="operator">.</span>name()) <span class="operator">^</span> key<span class="operator">.</span>dateOfBirth()<span class="operator">.</span>day();
 }

 <span class="preprocessor">#endif // EMPLOYEE_H</span></pre>
<p>The <a href="qhash.html#qHash">qHash</a>() function computes a numeric value based on a key. It can use any algorithm imaginable, as long as it always returns the same value if given the same argument. In other words, if <tt>e1 == e2</tt>, then <tt>qHash(e1) == qHash(e2)</tt> must hold as well. However, to obtain good performance, the <a href="qhash.html#qHash">qHash</a>() function should attempt to return different hash values for different keys to the largest extent possible.</p>
<p>In the example above, we've relied on Qt's global qHash(const <a href="qstring.html">QString</a> &amp;) to give us a hash value for the employee's name, and XOR'ed this with the day they were born to help produce unique hashes for people with the same name.</p>
<p>Internally, QHash uses a hash table to perform lookups. Unlike Qt 3's <tt>QDict</tt> class, which needed to be initialized with a prime number, QHash's hash table automatically grows and shrinks to provide fast lookups without wasting too much memory. You can still control the size of the hash table by calling <a href="qhash.html#reserve">reserve</a>() if you already know approximately how many items the QHash will contain, but this isn't necessary to obtain good performance. You can also call <a href="qhash.html#capacity">capacity</a>() to retrieve the hash table's size.</p>
</div>
<p><b>See also </b><a href="qhashiterator.html">QHashIterator</a>, <a href="qmutablehashiterator.html">QMutableHashIterator</a>, <a href="qmap.html">QMap</a>, and <a href="qset.html">QSet</a>.</p>
<!-- @@@QHash -->
<div class="types">
<h2>Member Type Documentation</h2>
<!-- $$$ConstIterator -->
<h3 class="fn"><a name="ConstIterator-typedef"></a>typedef QHash::<span class="name">ConstIterator</span></h3>
<p>Qt-style synonym for <a href="qhash-const-iterator.html">QHash::const_iterator</a>.</p>
<!-- @@@ConstIterator -->
<!-- $$$Iterator -->
<h3 class="fn"><a name="Iterator-typedef"></a>typedef QHash::<span class="name">Iterator</span></h3>
<p>Qt-style synonym for <a href="qhash-iterator.html">QHash::iterator</a>.</p>
<!-- @@@Iterator -->
<!-- $$$difference_type -->
<h3 class="fn"><a name="difference_type-typedef"></a>typedef QHash::<span class="name">difference_type</span></h3>
<p>Typedef for ptrdiff_t. Provided for STL compatibility.</p>
<!-- @@@difference_type -->
<!-- $$$key_type -->
<h3 class="fn"><a name="key_type-typedef"></a>typedef QHash::<span class="name">key_type</span></h3>
<p>Typedef for Key. Provided for STL compatibility.</p>
<!-- @@@key_type -->
<!-- $$$mapped_type -->
<h3 class="fn"><a name="mapped_type-typedef"></a>typedef QHash::<span class="name">mapped_type</span></h3>
<p>Typedef for T. Provided for STL compatibility.</p>
<!-- @@@mapped_type -->
<!-- $$$size_type -->
<h3 class="fn"><a name="size_type-typedef"></a>typedef QHash::<span class="name">size_type</span></h3>
<p>Typedef for int. Provided for STL compatibility.</p>
<!-- @@@size_type -->
</div>
<div class="func">
<h2>Member Function Documentation</h2>
<!-- $$$QHash[overload1]$$$QHash -->
<h3 class="fn"><a name="QHashx"></a>QHash::<span class="name">QHash</span> ()</h3>
<p>Constructs an empty hash.</p>
<p><b>See also </b><a href="qhash.html#clear">clear</a>().</p>
<!-- @@@QHash -->
<!-- $$$QHash$$$QHashconstQHash<Key,T>& -->
<h3 class="fn"><a name="QHash-2"></a>QHash::<span class="name">QHash</span> ( const <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>other</i> )</h3>
<p>Constructs a copy of <i>other</i>.</p>
<p>This operation occurs in <a href="containers.html#constant-time">constant time</a>, because <a href="qhash.html">QHash</a> is <a href="implicit-sharing.html#implicitly-shared">implicitly shared</a>. This makes returning a <a href="qhash.html">QHash</a> from a function very fast. If a shared instance is modified, it will be copied (copy-on-write), and this takes <a href="containers.html#linear-time">linear time</a>.</p>
<p><b>See also </b><a href="qhash.html#operator-eq">operator=</a>().</p>
<!-- @@@QHash -->
<!-- $$$~QHash[overload1]$$$~QHash -->
<h3 class="fn"><a name="dtor.QHash"></a>QHash::<span class="name">~QHash</span> ()</h3>
<p>Destroys the hash. References to the values in the hash and all iterators of this hash become invalid.</p>
<!-- @@@~QHash -->
<!-- $$$begin[overload1]$$$begin -->
<h3 class="fn"><a name="begin"></a><span class="type"><a href="qhash-iterator.html">iterator</a></span> QHash::<span class="name">begin</span> ()</h3>
<p>Returns an <a href="containers.html#stl-style-iterators">STL-style iterator</a> pointing to the first item in the hash.</p>
<p><b>See also </b><a href="qhash.html#constBegin">constBegin</a>() and <a href="qhash.html#end">end</a>().</p>
<!-- @@@begin -->
<!-- $$$begin$$$begin -->
<h3 class="fn"><a name="begin-2"></a><span class="type"><a href="qhash-const-iterator.html">const_iterator</a></span> QHash::<span class="name">begin</span> () const</h3>
<p>This is an overloaded function.</p>
<!-- @@@begin -->
<!-- $$$capacity[overload1]$$$capacity -->
<h3 class="fn"><a name="capacity"></a><span class="type">int</span> QHash::<span class="name">capacity</span> () const</h3>
<p>Returns the number of buckets in the <a href="qhash.html">QHash</a>'s internal hash table.</p>
<p>The sole purpose of this function is to provide a means of fine tuning <a href="qhash.html">QHash</a>'s memory usage. In general, you will rarely ever need to call this function. If you want to know how many items are in the hash, call <a href="qhash.html#size">size</a>().</p>
<p><b>See also </b><a href="qhash.html#reserve">reserve</a>() and <a href="qhash.html#squeeze">squeeze</a>().</p>
<!-- @@@capacity -->
<!-- $$$clear[overload1]$$$clear -->
<h3 class="fn"><a name="clear"></a><span class="type">void</span> QHash::<span class="name">clear</span> ()</h3>
<p>Removes all items from the hash.</p>
<p><b>See also </b><a href="qhash.html#remove">remove</a>().</p>
<!-- @@@clear -->
<!-- $$$constBegin[overload1]$$$constBegin -->
<h3 class="fn"><a name="constBegin"></a><span class="type"><a href="qhash-const-iterator.html">const_iterator</a></span> QHash::<span class="name">constBegin</span> () const</h3>
<p>Returns a const <a href="containers.html#stl-style-iterators">STL-style iterator</a> pointing to the first item in the hash.</p>
<p><b>See also </b><a href="qhash.html#begin">begin</a>() and <a href="qhash.html#constEnd">constEnd</a>().</p>
<!-- @@@constBegin -->
<!-- $$$constEnd[overload1]$$$constEnd -->
<h3 class="fn"><a name="constEnd"></a><span class="type"><a href="qhash-const-iterator.html">const_iterator</a></span> QHash::<span class="name">constEnd</span> () const</h3>
<p>Returns a const <a href="containers.html#stl-style-iterators">STL-style iterator</a> pointing to the imaginary item after the last item in the hash.</p>
<p><b>See also </b><a href="qhash.html#constBegin">constBegin</a>() and <a href="qhash.html#end">end</a>().</p>
<!-- @@@constEnd -->
<!-- $$$constFind[overload1]$$$constFindconstKey& -->
<h3 class="fn"><a name="constFind"></a><span class="type"><a href="qhash-const-iterator.html">const_iterator</a></span> QHash::<span class="name">constFind</span> ( const <span class="type">Key</span> &amp; <i>key</i> ) const</h3>
<p>Returns an iterator pointing to the item with the <i>key</i> in the hash.</p>
<p>If the hash contains no item with the <i>key</i>, the function returns <a href="qhash.html#constEnd">constEnd</a>().</p>
<p>This function was introduced in Qt 4.1.</p>
<p><b>See also </b><a href="qhash.html#find">find</a>() and <a href="qmultihash.html#constFind">QMultiHash::constFind</a>().</p>
<!-- @@@constFind -->
<!-- $$$contains[overload1]$$$containsconstKey& -->
<h3 class="fn"><a name="contains"></a><span class="type">bool</span> QHash::<span class="name">contains</span> ( const <span class="type">Key</span> &amp; <i>key</i> ) const</h3>
<p>Returns true if the hash contains an item with the <i>key</i>; otherwise returns false.</p>
<p><b>See also </b><a href="qhash.html#count">count</a>() and <a href="qmultihash.html#contains">QMultiHash::contains</a>().</p>
<!-- @@@contains -->
<!-- $$$count[overload1]$$$countconstKey& -->
<h3 class="fn"><a name="count"></a><span class="type">int</span> QHash::<span class="name">count</span> ( const <span class="type">Key</span> &amp; <i>key</i> ) const</h3>
<p>Returns the number of items associated with the <i>key</i>.</p>
<p><b>See also </b><a href="qhash.html#contains">contains</a>() and <a href="qhash.html#insertMulti">insertMulti</a>().</p>
<!-- @@@count -->
<!-- $$$count$$$count -->
<h3 class="fn"><a name="count-2"></a><span class="type">int</span> QHash::<span class="name">count</span> () const</h3>
<p>This is an overloaded function.</p>
<p>Same as <a href="qhash.html#size">size</a>().</p>
<!-- @@@count -->
<!-- $$$empty[overload1]$$$empty -->
<h3 class="fn"><a name="empty"></a><span class="type">bool</span> QHash::<span class="name">empty</span> () const</h3>
<p>This function is provided for STL compatibility. It is equivalent to <a href="qhash.html#isEmpty">isEmpty</a>(), returning true if the hash is empty; otherwise returns false.</p>
<!-- @@@empty -->
<!-- $$$end[overload1]$$$end -->
<h3 class="fn"><a name="end"></a><span class="type"><a href="qhash-iterator.html">iterator</a></span> QHash::<span class="name">end</span> ()</h3>
<p>Returns an <a href="containers.html#stl-style-iterators">STL-style iterator</a> pointing to the imaginary item after the last item in the hash.</p>
<p><b>See also </b><a href="qhash.html#begin">begin</a>() and <a href="qhash.html#constEnd">constEnd</a>().</p>
<!-- @@@end -->
<!-- $$$end$$$end -->
<h3 class="fn"><a name="end-2"></a><span class="type"><a href="qhash-const-iterator.html">const_iterator</a></span> QHash::<span class="name">end</span> () const</h3>
<p>This is an overloaded function.</p>
<!-- @@@end -->
<!-- $$$erase[overload1]$$$eraseiterator -->
<h3 class="fn"><a name="erase"></a><span class="type"><a href="qhash-iterator.html">iterator</a></span> QHash::<span class="name">erase</span> ( <span class="type"><a href="qhash-iterator.html">iterator</a></span> <i>pos</i> )</h3>
<p>Removes the (key, value) pair associated with the iterator <i>pos</i> from the hash, and returns an iterator to the next item in the hash.</p>
<p>Unlike <a href="qhash.html#remove">remove</a>() and <a href="qhash.html#take">take</a>(), this function never causes <a href="qhash.html">QHash</a> to rehash its internal data structure. This means that it can safely be called while iterating, and won't affect the order of items in the hash. For example:</p>
<pre class="cpp"> <span class="type"><a href="qhash.html">QHash</a></span><span class="operator">&lt;</span><span class="type"><a href="qobject.html">QObject</a></span> <span class="operator">*</span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span> objectHash;
 <span class="operator">.</span><span class="operator">.</span><span class="operator">.</span>
 <span class="type"><a href="qhash.html">QHash</a></span><span class="operator">&lt;</span><span class="type"><a href="qobject.html">QObject</a></span> <span class="operator">*</span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span><span class="operator">::</span>iterator i <span class="operator">=</span> objectHash<span class="operator">.</span><a href="qhash.html#find">find</a>(obj);
 <span class="keyword">while</span> (i <span class="operator">!</span><span class="operator">=</span> objectHash<span class="operator">.</span>end() <span class="operator">&amp;</span><span class="operator">&amp;</span> i<span class="operator">.</span>key() <span class="operator">=</span><span class="operator">=</span> obj) {
     <span class="keyword">if</span> (i<span class="operator">.</span>value() <span class="operator">=</span><span class="operator">=</span> <span class="number">0</span>) {
         i <span class="operator">=</span> objectHash<span class="operator">.</span>erase(i);
     } <span class="keyword">else</span> {
         <span class="operator">+</span><span class="operator">+</span>i;
     }
 }</pre>
<p><b>See also </b><a href="qhash.html#remove">remove</a>(), <a href="qhash.html#take">take</a>(), and <a href="qhash.html#find">find</a>().</p>
<!-- @@@erase -->
<!-- $$$find[overload1]$$$findconstKey& -->
<h3 class="fn"><a name="find"></a><span class="type"><a href="qhash-iterator.html">iterator</a></span> QHash::<span class="name">find</span> ( const <span class="type">Key</span> &amp; <i>key</i> )</h3>
<p>Returns an iterator pointing to the item with the <i>key</i> in the hash.</p>
<p>If the hash contains no item with the <i>key</i>, the function returns <a href="qhash.html#end">end</a>().</p>
<p>If the hash contains multiple items with the <i>key</i>, this function returns an iterator that points to the most recently inserted value. The other values are accessible by incrementing the iterator. For example, here's some code that iterates over all the items with the same key:</p>
<pre class="cpp"> <span class="type"><a href="qhash.html">QHash</a></span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span> hash;
 <span class="operator">.</span><span class="operator">.</span><span class="operator">.</span>
 <span class="type"><a href="qhash.html">QHash</a></span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span><span class="operator">::</span>const_iterator i <span class="operator">=</span> hash<span class="operator">.</span>find(<span class="string">&quot;HDR&quot;</span>);
 <span class="keyword">while</span> (i <span class="operator">!</span><span class="operator">=</span> hash<span class="operator">.</span>end() <span class="operator">&amp;</span><span class="operator">&amp;</span> i<span class="operator">.</span>key() <span class="operator">=</span><span class="operator">=</span> <span class="string">&quot;HDR&quot;</span>) {
     cout <span class="operator">&lt;</span><span class="operator">&lt;</span> i<span class="operator">.</span>value() <span class="operator">&lt;</span><span class="operator">&lt;</span> endl;
     <span class="operator">+</span><span class="operator">+</span>i;
 }</pre>
<p><b>See also </b><a href="qhash.html#value">value</a>(), <a href="qhash.html#values">values</a>(), and <a href="qmultihash.html#find">QMultiHash::find</a>().</p>
<!-- @@@find -->
<!-- $$$find$$$findconstKey& -->
<h3 class="fn"><a name="find-2"></a><span class="type"><a href="qhash-const-iterator.html">const_iterator</a></span> QHash::<span class="name">find</span> ( const <span class="type">Key</span> &amp; <i>key</i> ) const</h3>
<p>This is an overloaded function.</p>
<!-- @@@find -->
<!-- $$$insert[overload1]$$$insertconstKey&constT& -->
<h3 class="fn"><a name="insert"></a><span class="type"><a href="qhash-iterator.html">iterator</a></span> QHash::<span class="name">insert</span> ( const <span class="type">Key</span> &amp; <i>key</i>, const <span class="type">T</span> &amp; <i>value</i> )</h3>
<p>Inserts a new item with the <i>key</i> and a value of <i>value</i>.</p>
<p>If there is already an item with the <i>key</i>, that item's value is replaced with <i>value</i>.</p>
<p>If there are multiple items with the <i>key</i>, the most recently inserted item's value is replaced with <i>value</i>.</p>
<p><b>See also </b><a href="qhash.html#insertMulti">insertMulti</a>().</p>
<!-- @@@insert -->
<!-- $$$insertMulti[overload1]$$$insertMulticonstKey&constT& -->
<h3 class="fn"><a name="insertMulti"></a><span class="type"><a href="qhash-iterator.html">iterator</a></span> QHash::<span class="name">insertMulti</span> ( const <span class="type">Key</span> &amp; <i>key</i>, const <span class="type">T</span> &amp; <i>value</i> )</h3>
<p>Inserts a new item with the <i>key</i> and a value of <i>value</i>.</p>
<p>If there is already an item with the same key in the hash, this function will simply create a new one. (This behavior is different from <a href="qhash.html#insert">insert</a>(), which overwrites the value of an existing item.)</p>
<p><b>See also </b><a href="qhash.html#insert">insert</a>() and <a href="qhash.html#values">values</a>().</p>
<!-- @@@insertMulti -->
<!-- $$$isEmpty[overload1]$$$isEmpty -->
<h3 class="fn"><a name="isEmpty"></a><span class="type">bool</span> QHash::<span class="name">isEmpty</span> () const</h3>
<p>Returns true if the hash contains no items; otherwise returns false.</p>
<p><b>See also </b><a href="qhash.html#size">size</a>().</p>
<!-- @@@isEmpty -->
<!-- $$$key[overload1]$$$keyconstT& -->
<h3 class="fn"><a name="key"></a>const <span class="type">Key</span> QHash::<span class="name">key</span> ( const <span class="type">T</span> &amp; <i>value</i> ) const</h3>
<p>Returns the first key mapped to <i>value</i>.</p>
<p>If the hash contains no item with the <i>value</i>, the function returns a <a href="containers.html#default-constructed-values">default-constructed key</a>.</p>
<p>This function can be slow (<a href="containers.html#linear-time">linear time</a>), because <a href="qhash.html">QHash</a>'s internal data structure is optimized for fast lookup by key, not by value.</p>
<p><b>See also </b><a href="qhash.html#value">value</a>() and <a href="qhash.html#keys">keys</a>().</p>
<!-- @@@key -->
<!-- $$$key$$$keyconstT&constKey& -->
<h3 class="fn"><a name="key-2"></a>const <span class="type">Key</span> QHash::<span class="name">key</span> ( const <span class="type">T</span> &amp; <i>value</i>, const <span class="type">Key</span> &amp; <i>defaultKey</i> ) const</h3>
<p>This is an overloaded function.</p>
<p>Returns the first key mapped to <i>value</i>, or <i>defaultKey</i> if the hash contains no item mapped to <i>value</i>.</p>
<p>This function can be slow (<a href="containers.html#linear-time">linear time</a>), because <a href="qhash.html">QHash</a>'s internal data structure is optimized for fast lookup by key, not by value.</p>
<p>This function was introduced in Qt 4.3.</p>
<!-- @@@key -->
<!-- $$$keys[overload1]$$$keys -->
<h3 class="fn"><a name="keys"></a><span class="type"><a href="qlist.html">QList</a></span>&lt;<span class="type">Key</span>&gt; QHash::<span class="name">keys</span> () const</h3>
<p>Returns a list containing all the keys in the hash, in an arbitrary order. Keys that occur multiple times in the hash (because items were inserted with <a href="qhash.html#insertMulti">insertMulti</a>(), or <a href="qhash.html#unite">unite</a>() was used) also occur multiple times in the list.</p>
<p>To obtain a list of unique keys, where each key from the map only occurs once, use <a href="qhash.html#uniqueKeys">uniqueKeys</a>().</p>
<p>The order is guaranteed to be the same as that used by <a href="qhash.html#values">values</a>().</p>
<p><b>See also </b><a href="qhash.html#uniqueKeys">uniqueKeys</a>(), <a href="qhash.html#values">values</a>(), and <a href="qhash.html#key">key</a>().</p>
<!-- @@@keys -->
<!-- $$$keys$$$keysconstT& -->
<h3 class="fn"><a name="keys-2"></a><span class="type"><a href="qlist.html">QList</a></span>&lt;<span class="type">Key</span>&gt; QHash::<span class="name">keys</span> ( const <span class="type">T</span> &amp; <i>value</i> ) const</h3>
<p>This is an overloaded function.</p>
<p>Returns a list containing all the keys associated with value <i>value</i>, in an arbitrary order.</p>
<p>This function can be slow (<a href="containers.html#linear-time">linear time</a>), because <a href="qhash.html">QHash</a>'s internal data structure is optimized for fast lookup by key, not by value.</p>
<!-- @@@keys -->
<!-- $$$remove[overload1]$$$removeconstKey& -->
<h3 class="fn"><a name="remove"></a><span class="type">int</span> QHash::<span class="name">remove</span> ( const <span class="type">Key</span> &amp; <i>key</i> )</h3>
<p>Removes all the items that have the <i>key</i> from the hash. Returns the number of items removed which is usually 1 but will be 0 if the key isn't in the hash, or greater than 1 if <a href="qhash.html#insertMulti">insertMulti</a>() has been used with the <i>key</i>.</p>
<p><b>See also </b><a href="qhash.html#clear">clear</a>(), <a href="qhash.html#take">take</a>(), and <a href="qmultihash.html#remove">QMultiHash::remove</a>().</p>
<!-- @@@remove -->
<!-- $$$reserve[overload1]$$$reserveint -->
<h3 class="fn"><a name="reserve"></a><span class="type">void</span> QHash::<span class="name">reserve</span> ( <span class="type">int</span> <i>size</i> )</h3>
<p>Ensures that the <a href="qhash.html">QHash</a>'s internal hash table consists of at least <i>size</i> buckets.</p>
<p>This function is useful for code that needs to build a huge hash and wants to avoid repeated reallocation. For example:</p>
<pre class="cpp"> <span class="type"><a href="qhash.html">QHash</a></span><span class="operator">&lt;</span><span class="type"><a href="qstring.html">QString</a></span><span class="operator">,</span> <span class="type">int</span><span class="operator">&gt;</span> hash;
 hash<span class="operator">.</span>reserve(<span class="number">20000</span>);
 <span class="keyword">for</span> (<span class="type">int</span> i <span class="operator">=</span> <span class="number">0</span>; i <span class="operator">&lt;</span> <span class="number">20000</span>; <span class="operator">+</span><span class="operator">+</span>i)
     hash<span class="operator">.</span><a href="qhash.html#insert">insert</a>(keys<span class="operator">[</span>i<span class="operator">]</span><span class="operator">,</span> values<span class="operator">[</span>i<span class="operator">]</span>);</pre>
<p>Ideally, <i>size</i> should be slightly more than the maximum number of items expected in the hash. <i>size</i> doesn't have to be prime, because <a href="qhash.html">QHash</a> will use a prime number internally anyway. If <i>size</i> is an underestimate, the worst that will happen is that the <a href="qhash.html">QHash</a> will be a bit slower.</p>
<p>In general, you will rarely ever need to call this function. <a href="qhash.html">QHash</a>'s internal hash table automatically shrinks or grows to provide good performance without wasting too much memory.</p>
<p><b>See also </b><a href="qhash.html#squeeze">squeeze</a>() and <a href="qhash.html#capacity">capacity</a>().</p>
<!-- @@@reserve -->
<!-- $$$size[overload1]$$$size -->
<h3 class="fn"><a name="size"></a><span class="type">int</span> QHash::<span class="name">size</span> () const</h3>
<p>Returns the number of items in the hash.</p>
<p><b>See also </b><a href="qhash.html#isEmpty">isEmpty</a>() and <a href="qhash.html#count">count</a>().</p>
<!-- @@@size -->
<!-- $$$squeeze[overload1]$$$squeeze -->
<h3 class="fn"><a name="squeeze"></a><span class="type">void</span> QHash::<span class="name">squeeze</span> ()</h3>
<p>Reduces the size of the <a href="qhash.html">QHash</a>'s internal hash table to save memory.</p>
<p>The sole purpose of this function is to provide a means of fine tuning <a href="qhash.html">QHash</a>'s memory usage. In general, you will rarely ever need to call this function.</p>
<p><b>See also </b><a href="qhash.html#reserve">reserve</a>() and <a href="qhash.html#capacity">capacity</a>().</p>
<!-- @@@squeeze -->
<!-- $$$swap[overload1]$$$swapQHash<Key,T>& -->
<h3 class="fn"><a name="swap"></a><span class="type">void</span> QHash::<span class="name">swap</span> ( <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>other</i> )</h3>
<p>Swaps hash <i>other</i> with this hash. This operation is very fast and never fails.</p>
<p>This function was introduced in Qt 4.8.</p>
<!-- @@@swap -->
<!-- $$$take[overload1]$$$takeconstKey& -->
<h3 class="fn"><a name="take"></a><span class="type">T</span> QHash::<span class="name">take</span> ( const <span class="type">Key</span> &amp; <i>key</i> )</h3>
<p>Removes the item with the <i>key</i> from the hash and returns the value associated with it.</p>
<p>If the item does not exist in the hash, the function simply returns a <a href="containers.html#default-constructed-values">default-constructed value</a>. If there are multiple items for <i>key</i> in the hash, only the most recently inserted one is removed.</p>
<p>If you don't use the return value, <a href="qhash.html#remove">remove</a>() is more efficient.</p>
<p><b>See also </b><a href="qhash.html#remove">remove</a>().</p>
<!-- @@@take -->
<!-- $$$uniqueKeys[overload1]$$$uniqueKeys -->
<h3 class="fn"><a name="uniqueKeys"></a><span class="type"><a href="qlist.html">QList</a></span>&lt;<span class="type">Key</span>&gt; QHash::<span class="name">uniqueKeys</span> () const</h3>
<p>Returns a list containing all the keys in the map. Keys that occur multiple times in the map (because items were inserted with <a href="qhash.html#insertMulti">insertMulti</a>(), or <a href="qhash.html#unite">unite</a>() was used) occur only once in the returned list.</p>
<p>This function was introduced in Qt 4.2.</p>
<p><b>See also </b><a href="qhash.html#keys">keys</a>() and <a href="qhash.html#values">values</a>().</p>
<!-- @@@uniqueKeys -->
<!-- $$$unite[overload1]$$$uniteconstQHash<Key,T>& -->
<h3 class="fn"><a name="unite"></a><span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; QHash::<span class="name">unite</span> ( const <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>other</i> )</h3>
<p>Inserts all the items in the <i>other</i> hash into this hash. If a key is common to both hashes, the resulting hash will contain the key multiple times.</p>
<p><b>See also </b><a href="qhash.html#insertMulti">insertMulti</a>().</p>
<!-- @@@unite -->
<!-- $$$value[overload1]$$$valueconstKey& -->
<h3 class="fn"><a name="value"></a>const <span class="type">T</span> QHash::<span class="name">value</span> ( const <span class="type">Key</span> &amp; <i>key</i> ) const</h3>
<p>Returns the value associated with the <i>key</i>.</p>
<p>If the hash contains no item with the <i>key</i>, the function returns a <a href="containers.html#default-constructed-values">default-constructed value</a>. If there are multiple items for the <i>key</i> in the hash, the value of the most recently inserted one is returned.</p>
<p><b>See also </b><a href="qhash.html#key">key</a>(), <a href="qhash.html#values">values</a>(), <a href="qhash.html#contains">contains</a>(), and <a href="qhash.html#operator-5b-5d">operator[]</a>().</p>
<!-- @@@value -->
<!-- $$$value$$$valueconstKey&constT& -->
<h3 class="fn"><a name="value-2"></a>const <span class="type">T</span> QHash::<span class="name">value</span> ( const <span class="type">Key</span> &amp; <i>key</i>, const <span class="type">T</span> &amp; <i>defaultValue</i> ) const</h3>
<p>This is an overloaded function.</p>
<p>If the hash contains no item with the given <i>key</i>, the function returns <i>defaultValue</i>.</p>
<!-- @@@value -->
<!-- $$$values[overload1]$$$values -->
<h3 class="fn"><a name="values"></a><span class="type"><a href="qlist.html">QList</a></span>&lt;<span class="type">T</span>&gt; QHash::<span class="name">values</span> () const</h3>
<p>Returns a list containing all the values in the hash, in an arbitrary order. If a key is associated multiple values, all of its values will be in the list, and not just the most recently inserted one.</p>
<p>The order is guaranteed to be the same as that used by <a href="qhash.html#keys">keys</a>().</p>
<p><b>See also </b><a href="qhash.html#keys">keys</a>() and <a href="qhash.html#value">value</a>().</p>
<!-- @@@values -->
<!-- $$$values$$$valuesconstKey& -->
<h3 class="fn"><a name="values-2"></a><span class="type"><a href="qlist.html">QList</a></span>&lt;<span class="type">T</span>&gt; QHash::<span class="name">values</span> ( const <span class="type">Key</span> &amp; <i>key</i> ) const</h3>
<p>This is an overloaded function.</p>
<p>Returns a list of all the values associated with the <i>key</i>, from the most recently inserted to the least recently inserted.</p>
<p><b>See also </b><a href="qhash.html#count">count</a>() and <a href="qhash.html#insertMulti">insertMulti</a>().</p>
<!-- @@@values -->
<!-- $$$operator!=[overload1]$$$operator!=constQHash<Key,T>& -->
<h3 class="fn"><a name="operator-not-eq"></a><span class="type">bool</span> QHash::<span class="name">operator!=</span> ( const <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>other</i> ) const</h3>
<p>Returns true if <i>other</i> is not equal to this hash; otherwise returns false.</p>
<p>Two hashes are considered equal if they contain the same (key, value) pairs.</p>
<p>This function requires the value type to implement <tt>operator==()</tt>.</p>
<p><b>See also </b><a href="qhash.html#operator-eq-eq">operator==</a>().</p>
<!-- @@@operator!= -->
<!-- $$$operator=[overload1]$$$operator=constQHash<Key,T>& -->
<h3 class="fn"><a name="operator-eq"></a><span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; QHash::<span class="name">operator=</span> ( const <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>other</i> )</h3>
<p>Assigns <i>other</i> to this hash and returns a reference to this hash.</p>
<!-- @@@operator= -->
<!-- $$$operator==[overload1]$$$operator==constQHash<Key,T>& -->
<h3 class="fn"><a name="operator-eq-eq"></a><span class="type">bool</span> QHash::<span class="name">operator==</span> ( const <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>other</i> ) const</h3>
<p>Returns true if <i>other</i> is equal to this hash; otherwise returns false.</p>
<p>Two hashes are considered equal if they contain the same (key, value) pairs.</p>
<p>This function requires the value type to implement <tt>operator==()</tt>.</p>
<p><b>See also </b><a href="qhash.html#operator-not-eq">operator!=</a>().</p>
<!-- @@@operator== -->
<!-- $$$operator[][overload1]$$$operator[]constKey& -->
<h3 class="fn"><a name="operator-5b-5d"></a><span class="type">T</span> &amp; QHash::<span class="name">operator[]</span> ( const <span class="type">Key</span> &amp; <i>key</i> )</h3>
<p>Returns the value associated with the <i>key</i> as a modifiable reference.</p>
<p>If the hash contains no item with the <i>key</i>, the function inserts a <a href="containers.html#default-constructed-values">default-constructed value</a> into the hash with the <i>key</i>, and returns a reference to it. If the hash contains multiple items with the <i>key</i>, this function returns a reference to the most recently inserted value.</p>
<p><b>See also </b><a href="qhash.html#insert">insert</a>() and <a href="qhash.html#value">value</a>().</p>
<!-- @@@operator[] -->
<!-- $$$operator[]$$$operator[]constKey& -->
<h3 class="fn"><a name="operator-5b-5d-2"></a>const <span class="type">T</span> QHash::<span class="name">operator[]</span> ( const <span class="type">Key</span> &amp; <i>key</i> ) const</h3>
<p>This is an overloaded function.</p>
<p>Same as <a href="qhash.html#value">value</a>().</p>
<!-- @@@operator[] -->
</div>
<div class="relnonmem">
<h2>Related Non-Members</h2>
<!-- $$$qHash[overload1]$$$qHashconstQXmlNodeModelIndex& -->
<h3 class="fn"><a name="qHash"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( const <span class="type"><a href="qxmlnodemodelindex.html">QXmlNodeModelIndex</a></span> &amp; <i>index</i> )</h3>
<p>Computes a hash key from the <a href="qxmlnodemodelindex.html">QXmlNodeModelIndex</a> <i>index</i>, and returns it. This function would be used by <a href="qhash.html">QHash</a> if you wanted to build a hash table for instances of <a href="qxmlnodemodelindex.html">QXmlNodeModelIndex</a>.</p>
<p>The hash is computed on <a href="qxmlnodemodelindex.html#data">QXmlNodeModelIndex::data</a>(), <a href="qxmlnodemodelindex.html#additionalData">QXmlNodeModelIndex::additionalData</a>(), and <a href="qxmlnodemodelindex.html#model">QXmlNodeModelIndex::model</a>(). This means the hash key can be used for node indexes from different node models.</p>
<p>This function was introduced in Qt 4.4.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashqint64 -->
<h3 class="fn"><a name="qHash-36"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type"><a href="qtglobal.html#qint64-typedef">qint64</a></span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashQChar -->
<h3 class="fn"><a name="qHash-37"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type"><a href="qchar.html">QChar</a></span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashconstQByteArray& -->
<h3 class="fn"><a name="qHash-38"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( const <span class="type"><a href="qbytearray.html">QByteArray</a></span> &amp; <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashconstQBitArray& -->
<h3 class="fn"><a name="qHash-41"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( const <span class="type"><a href="qbitarray.html">QBitArray</a></span> &amp; <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashconstT* -->
<h3 class="fn"><a name="qHash-42"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( const <span class="type">T</span> * <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashconstQPair<T1,T2>& -->
<h3 class="fn"><a name="qHash-43"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( const <span class="type"><a href="qpair.html">QPair</a></span>&lt;<span class="type">T1</span>, <span class="type">T2</span>&gt; &amp; <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<p>Types <tt>T1</tt> and <tt>T2</tt> must be supported by <a href="qhash.html#qHash">qHash</a>().</p>
<p>This function was introduced in Qt 4.3.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashconstQString& -->
<h3 class="fn"><a name="qHash-11"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( const <span class="type"><a href="qstring.html">QString</a></span> &amp; <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashchar -->
<h3 class="fn"><a name="qHash-26"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type">char</span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashuchar -->
<h3 class="fn"><a name="qHash-27"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type"><a href="qtglobal.html#uchar-typedef">uchar</a></span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashsignedchar -->
<h3 class="fn"><a name="qHash-28"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type">signed</span> <span class="type">char</span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashushort -->
<h3 class="fn"><a name="qHash-29"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type"><a href="qtglobal.html#ushort-typedef">ushort</a></span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashshort -->
<h3 class="fn"><a name="qHash-30"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type">short</span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashuint -->
<h3 class="fn"><a name="qHash-31"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashint -->
<h3 class="fn"><a name="qHash-32"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type">int</span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashulong -->
<h3 class="fn"><a name="qHash-33"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type"><a href="qtglobal.html#ulong-typedef">ulong</a></span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashlong -->
<h3 class="fn"><a name="qHash-34"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type">long</span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$qHash$$$qHashquint64 -->
<h3 class="fn"><a name="qHash-35"></a><span class="type"><a href="qtglobal.html#uint-typedef">uint</a></span> <span class="name">qHash</span> ( <span class="type"><a href="qtglobal.html#quint64-typedef">quint64</a></span> <i>key</i> )</h3>
<p>Returns the hash value for the <i>key</i>.</p>
<!-- @@@qHash -->
<!-- $$$operator<<$$$operator<<QDataStream&constQHash<Key,T>& -->
<h3 class="fn"><a name="operator-lt-lt-15"></a><span class="type"><a href="qdatastream.html">QDataStream</a></span> &amp; <span class="name">operator&lt;&lt;</span> ( <span class="type"><a href="qdatastream.html">QDataStream</a></span> &amp; <i>out</i>, const <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>hash</i> )</h3>
<p>Writes the hash <i>hash</i> to stream <i>out</i>.</p>
<p>This function requires the key and value types to implement <tt>operator&lt;&lt;()</tt>.</p>
<p><b>See also </b><a href="datastreamformat.html">Serializing Qt Data Types</a>.</p>
<!-- @@@operator<< -->
<!-- $$$operator>>$$$operator>>QDataStream&QHash<Key,T>& -->
<h3 class="fn"><a name="operator-gt-gt-12"></a><span class="type"><a href="qdatastream.html">QDataStream</a></span> &amp; <span class="name">operator&gt;&gt;</span> ( <span class="type"><a href="qdatastream.html">QDataStream</a></span> &amp; <i>in</i>, <span class="type">QHash</span>&lt;<span class="type">Key</span>, <span class="type">T</span>&gt; &amp; <i>hash</i> )</h3>
<p>Reads a hash from stream <i>in</i> into <i>hash</i>.</p>
<p>This function requires the key and value types to implement <tt>operator&gt;&gt;()</tt>.</p>
<p><b>See also </b><a href="datastreamformat.html">Serializing Qt Data Types</a>.</p>
<!-- @@@operator>> -->
</div>
      </div>
    </div>
    </div> 
    <div class="ft">
      <span></span>
    </div>
  </div> 
  <div class="footer">
    <p>
      <acronym title="Copyright">&copy;</acronym> 2013 Digia Plc 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>
      Digia, Qt and their respective logos are trademarks of Digia Plc 
      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>

  <script src="scripts/functions.js" type="text/javascript"></script>
</body>
</html>