Re: Is there a proposal to fix the operator[] (rvalue/lvalue issues)??
"Gene Bushuyev" wrote:
<jose.diego@gmail.com> wrote in message
news:1155678420.260516.259860@74g2000cwt.googlegroups.com...
I made the following function to access a map elements to simulate the
operator[] in a const map
template<typename MapType>
const MapType::value_type::second_type get(const MapType map, const
MapType::value_type::first_type value) {
MapType::const_iterator it = map.find(value);
if( it == map.end() ) return MapType::value_type::second_type();
return *it;
}
If the std::map<>::operator[] could be used as an rvalue, it could have
the above implementation
What do you think?
Your solution is already problematic because it breaks the standardized
behavior.
The "standardized" behavior - if std::string or std::vector is any kind
of example - is to implement both a non-const and const operator[]. By
implementing only a non-const operator[], std::map would appear to be
the exception.
It's highly unlikely that the committee will choose to make changes
that break a lot of code.
Adding a const version of a std::map's operator[] could not break any
existing code - since no existing code could be invoking operator[] on
a const std::map.
On the other hand, no clear logic dictates whether a
new element should or should not be added to the map or the exception should be
thrown when operator [] is invoked for non-existing element.
You seem to be unaware that std::map already implements a non-const
operator[]. Its behavior is to insert a value when invoked with a key
not already present in the map. The question here is the best analagous
behavior were a non-const operator[] added to std::map.
I personally would
prefer exception, but in the final analysis it's not important. Using iterators
is more logical with associative containers and doesn't have any of these
problems, and that's what people are accustomed to doing - using find(),
lower/upper_bound(), etc.
For programs that currently retrieve values by indexing a non-const
std::map - being able to access a const std::map in the same way does
seem useful. After all, most programmers expect the non-const and const
versions of an object to behave consistently.
Greg
---
[ comp.std.c++ is moderated. To submit articles, try just posting with ]
[ your news-reader. If that fails, use mailto:std-c++@ncar.ucar.edu ]
[ --- Please see the FAQ before posting. --- ]
[ FAQ: http://www.comeaucomputing.com/csc/faq.html ]