mirror of
				https://github.com/boostorg/unordered.git
				synced 2025-10-30 23:31:41 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			50 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Boost.Unordered
 | ||
| 
 | ||
| Part of collection of the [Boost C++ Libraries](http://github.com/boostorg).
 | ||
| 
 | ||
| For accessing data based on key lookup, the C++ standard library offers `std::set`, `std::map`, `std::multiset` and `std::multimap`.
 | ||
| These are generally implemented using balanced binary trees so that lookup time has logarithmic complexity.
 | ||
| That is generally okay, but in many cases a hash table can perform better, as accessing data has constant complexity, on average.
 | ||
| The worst case complexity is linear, but that occurs rarely and with some care, can be avoided.
 | ||
| 
 | ||
| Also, the existing containers require a 'less than' comparison object to order their elements.
 | ||
| For some data types this is impossible to implement or isn’t practical.
 | ||
| In contrast, a hash table only needs an equality function and a hash function for the key.
 | ||
| 
 | ||
| With this in mind, unordered associative containers were added to the C++ standard.
 | ||
| This is an implementation of the containers described in C++11, with some deviations from the standard in order to work with non-C++11 compilers and libraries.
 | ||
| 
 | ||
| 
 | ||
| ### License
 | ||
| 
 | ||
| Distributed under the [Boost Software License, Version 1.0](http://www.boost.org/LICENSE_1_0.txt).
 | ||
| 
 | ||
| ### Properties
 | ||
| 
 | ||
| * C++03
 | ||
| * Header-Only
 | ||
| 
 | ||
| ### Build Status
 | ||
| 
 | ||
| Branch          | GH Actions | Appveyor | codecov.io | Deps | Docs | Tests |
 | ||
| :-------------: | ---------- | -------- | ---------- | ---- | ---- | ----- |
 | ||
| [`master`](https://github.com/boostorg/unordered/tree/master)   | [](https://github.com/boostorg/unordered/actions/workflows/ci.yml)  | [](https://ci.appveyor.com/project/danieljames/unordered-qtwe6/branch/master)   | [](https://codecov.io/gh/boostorg/unordered/branch/master)   | [](https://pdimov.github.io/boostdep-report/master/unordered.html)   | [](https://www.boost.org/doc/libs/master/libs/unordered/doc/html/unordered.html)   | [](http://www.boost.org/development/tests/master/developer/unordered.html)
 | ||
| [`develop`](https://github.com/boostorg/unordered/tree/develop) | [](https://github.com/boostorg/unordered/actions/workflows/ci.yml) | [](https://ci.appveyor.com/project/danieljames/unordered-qtwe6/branch/develop) | [](https://codecov.io/gh/boostorg/unordered/branch/develop) | [](https://pdimov.github.io/boostdep-report/develop/unordered.html) | [](https://www.boost.org/doc/libs/develop/libs/unordered/doc/html/unordered.html) | [](http://www.boost.org/development/tests/develop/developer/unordered.html)
 | ||
| 
 | ||
| ### Directories
 | ||
| 
 | ||
| | Name        | Purpose                        |
 | ||
| | ----------- | ------------------------------ |
 | ||
| | `doc`       | documentation                  |
 | ||
| | `example`   | examples                       |
 | ||
| | `include`   | headers                        |
 | ||
| | `test`      | unit tests                     |
 | ||
| 
 | ||
| ### More information
 | ||
| 
 | ||
| * [Ask questions](http://stackoverflow.com/questions/ask?tags=c%2B%2B,boost,boost-unordered)
 | ||
| * [Report bugs](https://github.com/boostorg/unordered/issues): Be sure to mention Boost version, platform and compiler you're using. A small compilable code sample to reproduce the problem is always good as well.
 | ||
| * Submit your patches as pull requests against **develop** branch. Note that by submitting patches you agree to license your modifications under the [Boost Software License, Version 1.0](http://www.boost.org/LICENSE_1_0.txt).
 | ||
| * Discussions about the library are held on the [Boost developers mailing list](http://www.boost.org/community/groups.html#main). Be sure to read the [discussion policy](http://www.boost.org/community/policy.html) before posting and add the `[unordered]` tag at the beginning of the subject line.
 | ||
| 
 |