[optional] boost improvement over std::map, the default initialization requirement
data:image/s3,"s3://crabby-images/f50de/f50debce04ae4d88adac3c8cc86a72503c8a1272" alt=""
Hi,
The STL has an implementation of std::map
data:image/s3,"s3://crabby-images/72199/72199608b8d1582d6f69bcdc3b12b385d811e135" alt=""
On Sunday, July 18, 2010, alfC
Hi, The STL has an implementation of std::map
. It has some designs drawbacks in my opinion. For example, the fact that T2 has to have a default copy constructor. Even if for T2, by design, doesn't make sense to have a copy constructor. The problem boils down to the fact that, in the STL design, if an key element of the map is referenced with the operator[] and it doesn't exist then an 'empty' (default) object T2 is created. In my opinion this feature is independent of the other features of a map. For example if the element doesn't exists and the context is not assignment then it could give an exception.
Easy solution: use find and insert instead of operator[]. HTH -- -- Dave Abrahams BoostPro Computing http://www.boostpro.com
data:image/s3,"s3://crabby-images/60deb/60deb4d6c10efe00852105496c6edad7a74d2fec" alt=""
On Sun, Jul 18, 2010 at 4:48 AM, Dave Abrahams
On Sunday, July 18, 2010, alfC
wrote: Hi, The STL has an implementation of std::map
. It has some designs drawbacks in my opinion. For example, the fact that T2 has to have a default copy constructor. Even if for T2, by design, doesn't make sense to have a copy constructor. The problem boils down to the fact that, in the STL design, if an key element of the map is referenced with the operator[] and it doesn't exist then an 'empty' (default) object T2 is created. In my opinion this feature is independent of the other features of a map. For example if the element doesn't exists and the context is not assignment then it could give an exception.
Easy solution: use find and insert instead of operator[]. HTH
I haven't done any timings but isn't lower_bound+insert potentially better because you can then pass the iterator from lower_bound to insert as a hint? Emil Dotchevski Reverge Studios, Inc. http://www.revergestudios.com/reblog/index.php?n=ReCode
data:image/s3,"s3://crabby-images/3cdde/3cdde99a33dd10faf821fade4b762c93ab4a4310" alt=""
Le 18/07/2010 19:47, Emil Dotchevski wrote:
I haven't done any timings but isn't lower_bound+insert potentially better because you can then pass the iterator from lower_bound to insert as a hint?
If you don't give a hint, insert calls lower_bound on its own. The hint is only useful if you already know where it could be put.
participants (4)
-
alfC
-
Dave Abrahams
-
Emil Dotchevski
-
Mathias Gaunard