Некий
Jonathan Wakely определенно меня не любит.
А началось всё с
моего письма в рассылке GCC (см.
здесь предысторию возникновения этого письма), в котором я поинтересовался, а отчего же такая асимметрия:
- swap для пользовательских типов можно определять и в std, и в том же пространстве имён, откуда они;
- distance с advance - только в std, если вы
( Read more... )
namespace A {
template
class TChSetIterator : public std::iterator<
std::bidirectional_iterator_tag,
typename std::iterator_traits::value_type::node_type,
std::ptrdiff_t,
const typename std::iterator_traits::value_type::node_type *,
const typename std::iterator_traits::value_type::node_type &>
{
.......
typedef std::iterator<
std::bidirectional_iterator_tag,
node_type,
std::ptrdiff_t,
const node_type *,
const node_type &> parent_type;
typedef TChSetIterator Self;
.......
public:
typename parent_type::difference_type distance(const Self & other) const;
void advance(typename parent_type::difference_type n);
Self & operator++()
{
advance(1);
return *this;
}
.......
};
} // namespace A
namespace std {
template
inline typename A::TChSetIterator::difference_type
distance(const A::TChSetIterator & first,
const A::TChSetIterator & last)
{
return first.distance(last);
}
template
inline void advance(A::TChSetIterator& i,
typename A::TChSetIterator::difference_type n)
{
return i.advance(n);
}
} // namespace std
По поводу его правоты - я уже высказался.
По поводу правильности расширения std я высказался тут (с учётом того, что для некоторых пользовательских типов всё же возможно и нужно определить то, что вами названо "быстрее чем Forward итератор и медленее чем RNA"): http://mpd.livejournal.com/33738.html?thread=147402#t147402
Reply
Leave a comment