This is the mail archive of the
libstdc++@gcc.gnu.org
mailing list for the libstdc++ project.
Re: map<const T, const U> is assignable even though pair<const T, const U> is not
- From: Daniel Krügler <daniel dot kruegler at gmail dot com>
- To: Jonathan Wakely <jwakely at redhat dot com>
- Cc: "libstdc++" <libstdc++ at gcc dot gnu dot org>
- Date: Thu, 23 Apr 2015 15:07:43 +0200
- Subject: Re: map<const T, const U> is assignable even though pair<const T, const U> is not
- Authentication-results: sourceware.org; auth=none
- References: <20150423104850 dot GA3618 at redhat dot com> <20150423123904 dot GC3618 at redhat dot com>
2015-04-23 14:39 GMT+02:00 Jonathan Wakely <jwakely@redhat.com>:
> On 23/04/15 11:48 +0100, Jonathan Wakely wrote:
>>
>> Marshall Clow sent me this problem:
>>
>> On 22 April 2015 at 21:49, Marshall Clow wrote:
>>>
>>> The following code fails to compile w/libc++, but succeeds with
>>> libstdc++.
>>>
>>> #include <map>
>>>
>>> int main () {
>>> std::map<const int, const int> foo1, foo2;
>>> foo2 = foo1;
>>> }
>>>
>>> assigning a allocator-aware container requires that the value type
>>> be
>>> CopyAssignable, which pair<const int, const int> is definitely not.
>>>
>>
>> I think this is a consequence of our optimization to recycle nodes on
>> assignment, which runs a destructor and then constructs a new element
>> with placement new, so it doesn't actually do any assignments.
>>
>> The example violates the preconditions on the assignment, so it's
>> undefined behaviour, but it's a bit surprising that it Just Works.
>>
>> Do we want to make this type non-CopyAssignable?
>
> Answering myself ... I don't think we should change anything, given
> that pair<const T, U> is already not assignable, and we have to make
> map<T, U> assignable despite that.
To me these comparisons don't hold: I don't find it surprising that
map<T, U>
works for non-const T *albeit* semantically the values are pair<const
T, U> values, because for these container the key is actually never
needed to be *replaced*. Either in a unique-key container there is
only one of it or in a non-unique-key container each duplicate is
added (but does not replace the older one). But from the user
perspective the *mapped values* should be sensitive to
const-correctness.
Therefore I would appreciate making
std::map<T, const U>
non-CopyAssignable.
- Daniel