forked from boostorg/unordered
https://svn.boost.org/svn/boost/branches/unordered/dev ........ r41822 | danieljames | 2007-12-07 12:51:54 +0000 (Fri, 07 Dec 2007) | 5 lines Change the macros to meet boost guidelines. I should really have done this before the review. At least it'll give them something to say. ........ r41928 | danieljames | 2007-12-09 19:23:27 +0000 (Sun, 09 Dec 2007) | 1 line Add some parameters to standalone documentation build. ........ r41929 | danieljames | 2007-12-09 19:24:07 +0000 (Sun, 09 Dec 2007) | 1 line An extra rehash test for inserting a range. ........ r41930 | danieljames | 2007-12-09 19:24:52 +0000 (Sun, 09 Dec 2007) | 1 line get_for_erase can be static because all the required information is in the iterator. ........ r41931 | danieljames | 2007-12-09 19:31:00 +0000 (Sun, 09 Dec 2007) | 1 line ADL doesn't seem to be working properly on Visual C++ 7.1 when calling swap, so workaround this in the compile tests. ........ r41932 | danieljames | 2007-12-09 19:44:46 +0000 (Sun, 09 Dec 2007) | 1 line Try to make the erase exception requirements a little clearer. ........ r41933 | danieljames | 2007-12-09 19:52:50 +0000 (Sun, 09 Dec 2007) | 1 line Hopefully clearer comparison of accessors for comparison/hash function objects. ........ r41943 | danieljames | 2007-12-10 00:03:53 +0000 (Mon, 10 Dec 2007) | 1 line Fix a typo. ........ r41951 | danieljames | 2007-12-10 11:08:02 +0000 (Mon, 10 Dec 2007) | 1 line Use the locale in the case insensitive comparison, I really should add a test for this. ........ r41994 | danieljames | 2007-12-13 00:26:05 +0000 (Thu, 13 Dec 2007) | 3 lines Hervé Brönnimann's improved explanation of the formula for avoiding invalidating iterators. ........ r41995 | danieljames | 2007-12-13 00:30:46 +0000 (Thu, 13 Dec 2007) | 4 lines Explicity use the classic locale in the case insensitive example. I could make the locale a member, but that would make the example longer. Also, this would be a good place to put a note about the need for constant function objects. ........ r41996 | danieljames | 2007-12-13 00:31:55 +0000 (Thu, 13 Dec 2007) | 1 line Pull the point examples out into test files - fixing a few bugs in the process. ........ r41997 | danieljames | 2007-12-13 00:41:30 +0000 (Thu, 13 Dec 2007) | 3 lines A few reference links for boost::hash, it might be better to link to the first page of the Boost.Hash documentation though. ........ r42092 | danieljames | 2007-12-16 10:07:27 +0000 (Sun, 16 Dec 2007) | 2 lines Fix some typos, and use American spelling. ........ r42093 | danieljames | 2007-12-16 10:11:00 +0000 (Sun, 16 Dec 2007) | 1 line Small documentation tweak. ........ r42096 | danieljames | 2007-12-16 10:17:03 +0000 (Sun, 16 Dec 2007) | 1 line Fix some reference documentation errors. ........ r42097 | danieljames | 2007-12-16 10:28:08 +0000 (Sun, 16 Dec 2007) | 1 line Document the explicit constructors. ........ r42098 | danieljames | 2007-12-16 10:47:13 +0000 (Sun, 16 Dec 2007) | 1 line Try to make the active issues and proposals a little clearer - including more obvious links to the relevant papers. ........ r42099 | danieljames | 2007-12-16 10:52:30 +0000 (Sun, 16 Dec 2007) | 1 line Fix some complexity errors in the comparison table. ........ r42100 | danieljames | 2007-12-16 10:59:45 +0000 (Sun, 16 Dec 2007) | 1 line Use Mapped instead of T in the documentation. ........ r42101 | danieljames | 2007-12-16 11:06:16 +0000 (Sun, 16 Dec 2007) | 1 line Remove hard-coded length of prime numbers. ........ [SVN r42187]
159 lines
5.4 KiB
Plaintext
159 lines
5.4 KiB
Plaintext
[/ Copyright 2006-2007 Daniel James.
|
|
/ Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
/ file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) ]
|
|
|
|
[section:comparison Comparison with Associative Containers]
|
|
|
|
[table Interface differences.
|
|
[[Associative Containers] [Unordered Associative Containers]]
|
|
|
|
[
|
|
[Parameterized by an ordering relation `Compare`]
|
|
[Parameterized by a function object `Hash` and an equivalence relation
|
|
`Pred`]
|
|
]
|
|
[
|
|
[Keys can be compared using `key_compare` which is accessed by member function `key_comp()`,
|
|
values can be compared using `value_compare` which is accessed by member function `value_comp()`.]
|
|
[Keys can be hashed using `hasher` which is accessed by member function `hash_function()`,
|
|
and checked for equality using `key_equal` which is accessed by member function `key_eq()`.
|
|
There is no function object for compared or hashing values.]
|
|
]
|
|
[
|
|
[Constructors have optional extra parameters for the comparison object.]
|
|
[Constructors have optional extra parameters for the initial minimum
|
|
number of buckets, a hash function and an equality object.]
|
|
]
|
|
|
|
[
|
|
[Keys `k1`, `k2` are considered equivalent if
|
|
`!Compare(k1, k2) && !Compare(k2, k1)`]
|
|
[Keys `k1`, `k2` are considered equivalent if `Pred(k1, k2)`]
|
|
]
|
|
[
|
|
[Member function `lower_bound(k)` and `upper_bound(k)`]
|
|
[No equivalent. Since the elements aren't ordered `lower_bound` and
|
|
`upper_bound` would be meaningless.]
|
|
]
|
|
[
|
|
[`equal_range(k)` returns an empty range at the position that k
|
|
would be inserted if k isn't present in the container.]
|
|
[`equal_range(k)` returns a range at the end of the container if
|
|
k isn't present in the container. It can't return a positioned
|
|
range as k could be inserted into multiple place. To find out the
|
|
bucket that k would be inserted into use `bucket(k)`. But remember
|
|
that an insert can cause the container to rehash - meaning that the
|
|
element can be inserted into a different bucket.]
|
|
]
|
|
[
|
|
[`iterator`, `const_iterator` are of the bidirectional category.]
|
|
[`iterator`, `const_iterator` are of at least the forward category.]
|
|
]
|
|
[
|
|
[Inserts do not invalidate iterators or references to the container.]
|
|
[Inserts can invalidate iterators but not references to the container.]
|
|
]
|
|
[
|
|
[Iterators iterate through the container in the order defined by
|
|
the comparison object.]
|
|
[Iterators iterate through the container in an arbitrary order, that
|
|
can change as elements are inserted. Although, equivalent elements
|
|
are always adjacent.]
|
|
]
|
|
[
|
|
[No equivalent]
|
|
[Local iterators can be used to iterate through individual buckets.
|
|
(I don't think that the order of local iterators and iterators are
|
|
required to have any correspondence.)]
|
|
]
|
|
[
|
|
[Can be compared using the `==`, `!=`, `<`, `<=`, `>`, `>=` operators]
|
|
[No comparison operators are defined]
|
|
]
|
|
[
|
|
[]
|
|
[When inserting with a hint, implementations are permitted to ignore
|
|
the hint.]
|
|
]
|
|
[
|
|
[`erase` never throws an exception]
|
|
[The containers hash or predicate function can throw exceptions
|
|
from `erase`]
|
|
]
|
|
]
|
|
|
|
[table Complexity Guarantees
|
|
[[Operation] [Associative Containers] [Unordered Associative Containers]]
|
|
[
|
|
[Construction of empty container]
|
|
[constant]
|
|
[O(/n/) where /n/ is the minimum number of buckets.]
|
|
]
|
|
[
|
|
[Construction of container from a range of /N/ elements]
|
|
[O(/N/ log /N/), O(/N/) if the range is sorted with `value_comp()`]
|
|
[Average case O(/N/), worst case
|
|
O(/N/'''<superscript>2</superscript>''')]
|
|
]
|
|
[
|
|
[Insert a single element]
|
|
[logarithmic]
|
|
[Average case constant, worst case linear]
|
|
]
|
|
[
|
|
[Insert a single element with a hint]
|
|
[Amortized constant if t elements inserted right after hint,
|
|
logarithmic otherwise]
|
|
[Average case constant, worst case linear (ie. the same as
|
|
a normal insert).]
|
|
]
|
|
[
|
|
[Inserting a range of /N/ elements]
|
|
[ /N/ log(`size()`+/N/) ]
|
|
[Average case O(/N/), worst case O(/N/ * `size()`)]
|
|
]
|
|
[
|
|
[Erase by key, `k`]
|
|
[O(log(`size()`) + `count(k)`)]
|
|
[Average case: O(`count(k)`), Worst case: O(`size()`)]
|
|
]
|
|
[
|
|
[Erase a single element by iterator]
|
|
[Amortized constant]
|
|
[Average case: O(1), Worst case: O(`size()`)]
|
|
]
|
|
[
|
|
[Erase a range of /N/ elements]
|
|
[O(log(`size()`) + /N/)]
|
|
[Average case: O(/N/), Worst case: O(`size()`)]
|
|
]
|
|
[
|
|
[Clearing the container]
|
|
[O(`size()`)]
|
|
[O(`size()`)]
|
|
]
|
|
[
|
|
[Find]
|
|
[logarithmic]
|
|
[Average case: O(1), Worst case: O(`size()`)]
|
|
]
|
|
[/ TODO: Average case is probably wrong. ]
|
|
[
|
|
[Count]
|
|
[O(log(`size()`) + `count(k)`)]
|
|
[Average case: O(1), Worst case: O(`size()`)]
|
|
]
|
|
[
|
|
[`equal_range(k)`]
|
|
[logarithmic]
|
|
[Average case: O(`count(k)`), Worst case: O(`size()`)]
|
|
]
|
|
[
|
|
[`lower_bound`,`upper_bound`]
|
|
[logarithmic]
|
|
[n/a]
|
|
]
|
|
]
|
|
|
|
[endsect]
|