]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/hashmap.tex
Restored Objective-C typesafety while retaining proper C++ name mangling
[wxWidgets.git] / docs / latex / wx / hashmap.tex
CommitLineData
e676441f
MB
1\section{\class{wxHashMap}}\label{wxhashmap}
2
e492150d 3This is a simple, type-safe, and reasonably efficient hash map class,
e676441f
MB
4whose interface is a subset of the interface of STL containers.
5
6\wxheading{Example}
7
8\begin{verbatim}
9 class MyClass { /* ... */ };
10
4f3b37fd 11 // declare a hash map with string keys and int values
e676441f
MB
12 WX_DECLARE_STRING_HASH_MAP( int, MyHash5 );
13 // same, with int keys and MyClass* values
14 WX_DECLARE_HASH_MAP( int, MyClass*, wxIntegerHash, wxIntegerEqual, MyHash1 );
15 // same, with wxString keys and int values
16 WX_DECLARE_STRING_HASH_MAP( int, MyHash3 );
17 // same, with wxString keys and values
18 WX_DECLARE_STRING_HASH_MAP( wxString, MyHash2 );
19
20 MyHash1 h1;
21 MyHash2 h2;
22
23 // store and retrieve values
24 h1[1] = new MyClass( 1 );
25 h1[10000000] = NULL;
26 h1[50000] = new MyClass( 2 );
27 h2["Bill"] = "ABC";
28 wxString tmp = h2["Bill"];
29 // since element with key "Joe" is not present, this will return
2edb0bde 30 // the default value, that is an empty string in the case of wxString
e676441f
MB
31 MyClass tmp2 = h2["Joe"];
32
33 // iterate over all the elements in the class
34 MyHash2::iterator it;
35 for( it = h2.begin(); it != h2.end(); ++it )
36 {
37 wxString key = it->first, value = it->second;
38 // do something useful with key and value
39 }
40\end{verbatim}
41
42\wxheading{Declaring new hash table types}
43
44\begin{verbatim}
45 WX_DECLARE_STRING_HASH_MAP( VALUE_T, // type of the values
46 CLASSNAME ); // name of the class
47\end{verbatim}
48
49Declares an hash map class named CLASSNAME, with {\tt wxString} keys
50and VALUE\_T values.
51
52\begin{verbatim}
53 WX_DECLARE_VOIDPTR_HASH_MAP( VALUE_T, // type of the values
54 CLASSNAME ); // name of the class
55\end{verbatim}
56
57Declares an hash map class named CLASSNAME, with {\tt void*} keys
58and VALUE\_T values.
59
60\begin{verbatim}
61 WX_DECLARE_HASH_MAP( KEY_T, // type of the keys
62 VALUE_T, // type of the values
63 HASH_T, // hasher
64 KEY_EQ_T, // key equality predicate
65 CLASSNAME); // name of the class
66\end{verbatim}
67
68The HASH\_T and KEY\_EQ\_T are the types
69used for the hashing function and key comparison. wxWindows provides
70three predefined hashing functions: {\tt wxIntegerHash}
71for integer types ( {\tt int}, {\tt long}, {\tt short},
72and their unsigned counterparts ), {\tt wxStringHash} for strings
73( {\tt wxString}, {\tt wxChar*}, {\tt char*} ), and
74{\tt wxPointerHash} for any kind of pointer.
75Similarly three equality predicates:
76{\tt wxIntegerEqual}, {\tt wxStringEqual}, {\tt wxPointerEqual} are provided.
77
78Using this you could declare an hash map mapping {\tt int} values
79to {\tt wxString} like this:
80
81\begin{verbatim}
82 WX_DECLARE_HASH_MAP( int,
83 wxString,
84 wxIntegerHash,
85 wxIntegerEqual,
86 MyHash );
87\end{verbatim}
88
89\latexignore{\rtfignore{\wxheading{Types}}}
90
91In the documentation below you should replace wxHashMap with the name
92you used in the class declaration.
93
94\begin{twocollist}
95\twocolitem{wxHashMap::key\_type}{Type of the hash keys}
96\twocolitem{wxHashMap::mapped\_type}{Type of the values stored in the hash map}
97\twocolitem{wxHashMap::value\_type}{Equivalent to
98{\tt struct \{ key\_type first; mapped\_type second \};} }
99\twocolitem{wxHashMap::iterator}{Used to enumerate all the elements in an hash
100map; it is similar to a {\tt value\_type*}}
101\twocolitem{wxHashMap::const\_iterator}{Used to enumerate all the elements
102in a constant hash map; it is similar to a {\tt const value\_type*}}
103\twocolitem{wxHashMap::size\_type}{Used for sizes}
104\end{twocollist}
105
106\wxheading{Iterators}
107
108An iterator is similar to a pointer, and so you can use the usual pointer
109operations: {\tt ++it} ( and {\tt it++} ) to move to the next element,
110{\tt *it} to access the element pointed to, {\tt it->first}
111( {\tt it->second} ) to access the key ( value )
112of the element pointed to. Hash maps provide forward only iterators, this
113means that you can't use {\tt --it}, {\tt it + 3}, {\tt it1 - it2}.
114
115\wxheading{Include files}
116
117<wx/hashmap.h>
118
119\latexignore{\rtfignore{\wxheading{Members}}}
120
121\membersection{wxHashMap::wxHashMap}
122
123\func{}{wxHashMap}{\param{size\_type}{ size = 10}}
124
125The size parameter is just an hint, the table will resize automatically
126to preserve performance.
127
7af3ca16 128\func{}{wxHashMap}{\param{const wxHashMap\&}{ map}}
e676441f
MB
129
130Copy constructor.
131
132\membersection{wxHashMap::begin}
133
134\constfunc{const\_iterator}{begin}{}
135
136\func{iterator}{begin}{}
137
e492150d
JS
138Returns an iterator pointing at the first element of the hash map.
139Please remember that hash maps do not guarantee ordering.
e676441f
MB
140
141\membersection{wxHashMap::clear}
142
143\func{void}{clear}{}
144
145Removes all elements from the hash map.
146
147\membersection{wxHashMap::count}
148
7af3ca16 149\constfunc{size\_type}{count}{\param{const key\_type\&}{ key}}
e676441f
MB
150
151Counts the number of elements with the given key present in the map.
152This function can actually return 0 or 1.
153
154\membersection{wxHashMap::empty}
155
156\constfunc{bool}{empty}{}
157
cc81d32f 158Returns true if the hash map does not contain any element, false otherwise.
e676441f
MB
159
160\membersection{wxHashMap::end}
161
162\constfunc{const\_iterator}{end}{}
163
164\func{iterator}{end}{}
165
e492150d
JS
166Returns an iterator pointing at the one-after-the-last element of the hash map.
167Please remember that hash maps do not guarantee ordering.
e676441f
MB
168
169\membersection{wxHashMap::erase}
170
7af3ca16 171\func{size\_type}{erase}{\param{const key\_type\&}{ key}}
e676441f
MB
172
173Erases the element with the given key, and returns the number of element
e492150d 174erased (either 0 or 1).
e676441f
MB
175
176\func{void}{erase}{\param{iterator}{ it}}
177
178\func{void}{erase}{\param{const\_iterator}{ it}}
179
180Erases the element pointed to by the iterator. After the deletion
181the iterator is no longer valid and must not be used.
182
183\membersection{wxHashMap::find}
184
7af3ca16 185\func{iterator}{find}{\param{const key\_type\&}{ key}}
e676441f 186
7af3ca16 187\constfunc{const\_iterator}{find}{\param{const key\_type\&}{ key}}
e676441f
MB
188
189If an element with the given key is present, the functions returns
190an iterator pointing at that element, otherwise an invalid iterator
e492150d 191is returned (i.e. hashmap.find( non\_existent\_key ) == hashmap.end()).
e676441f
MB
192
193\membersection{wxHashMap::insert}
194
7af3ca16 195\func{void}{insert}{\param{const value\_type\&}{ v}}
e676441f
MB
196
197Inserts the given value in the hash map.
198
199\membersection{wxHashMap::operator[]}
200
7af3ca16 201\func{mapped\_type\&}{operator[]}{\param{const key\_type\&}{ key}}
e676441f
MB
202
203Use it as an array subscript. The only difference is that if the
204given key is not present in the hash map, an element with the
205default {\tt value\_type()} is inserted in the table.
206
207\membersection{wxHashMap::size}
208
209\constfunc{size\_type}{size}{}
210
211Returns the numbers of elements in the map.
6b3d51cc 212