Opened 14 years ago
Closed 14 years ago
#2689 closed Bugs (fixed)
Unordered containers: cache_begin not compatible with auto_unlink
Reported by: | Andrey Semashev | Owned by: | Ion Gaztañaga |
---|---|---|---|
Milestone: | Boost 1.39.0 | Component: | intrusive |
Version: | Boost 1.37.0 | Severity: | Problem |
Keywords: | unordered cache_begin auto_unlink | Cc: |
Description
It looks like using cache_begin< true > option with unordered containers with link_mode< auto_unlink > can lead to subtle crashes in run time. Supposedly, the problem appears when the leading node of the container (the one that is pointed to by begin()) is deleted without explicitly erasing the element from the container. In that case begin() returns an iterator to a non-existing element.
This issue is not highlighted in the docs or checked in the code. It would be great if the container checked this options combination and did not compile in the first place.
Change History (1)
comment:1 by , 14 years ago
Milestone: | Boost 1.38.0 → Boost 1.39.0 |
---|---|
Resolution: | → fixed |
Status: | new → closed |
Note:
See TracTickets
for help on using tickets.
Static assertion added to check it at compile time and also a note in the documentation. Revision 51971 in trunk.