reference in new- and old-style iterators
data:image/s3,"s3://crabby-images/853f9/853f928ac4ef01db7fa9d4cd7aa49e64c0f581aa" alt=""
Hello, I'm wondering what the reference member in the iterator_traits of an iterator is required to be. I couldn't find any requirement at all in the C++98 standard, and more surprisingly, I can't see any requirement in the new iterator proposal either. In particular, operator* does not seem to be required to return the iterator_traits< Iterator >::reference for lvalue iterators. At one point, however, the proposal suggests that this was the intention: "...would have a return type of reference; the same as operator*." where reference has a font style indicating that it's the iterator_traits's notion of reference. I'm looking at the proposal version currently published along in the documentation of the boost iterator library. So my questions: - Am I right in my suspicion that in the STL, the reference iterator_trait is entirely useless if taken strictly? - Should the proposal not better require the reference to match with operator*'s return type for lvalue iterators? If not, what's its use? - Is this off-topic here? :) Regards, Jens
data:image/s3,"s3://crabby-images/b4e66/b4e6618abd88571690777d58d3e735c7f53bb18c" alt=""
Jens Theisen
Hello,
I'm wondering what the reference member in the iterator_traits of an iterator is required to be. I couldn't find any requirement at all in the C++98 standard,
Bingo.
and more surprisingly, I can't see any requirement in the new iterator proposal either.
In particular, operator* does not seem to be required to return the iterator_traits< Iterator >::reference for lvalue iterators.
Interesting point. IIRC we were trying to stay compatible with the existing standard iterators; one of the iterators (istream_iterator?) has a very strange reference type. OTOH, for lvalue iterators, the reference member is redundant: the result of operator* is reqiured to be value_type&
At one point, however, the proposal suggests that this was the intention:
"...would have a return type of reference; the same as operator*."
where reference has a font style indicating that it's the iterator_traits's notion of reference.
I'm looking at the proposal version currently published along in the documentation of the boost iterator library.
So my questions:
- Am I right in my suspicion that in the STL, the reference iterator_trait is entirely useless if taken strictly?
Yes.
- Should the proposal not better require the reference to match with operator*'s return type for lvalue iterators? If not, what's its use?
Maybe, but that particular proposal is sorta dead. Some people have been working on a new one to address these issues, but I don't know where it's going.
- Is this off-topic here? :)
It's marginally on-topic, I s'pose. -- Dave Abrahams Boost Consulting www.boost-consulting.com
participants (2)
-
David Abrahams
-
Jens Theisen