Некий
Jonathan Wakely определенно меня не любит.
А началось всё с
моего письма в рассылке GCC (см.
здесь предысторию возникновения этого письма), в котором я поинтересовался, а отчего же такая асимметрия:
- swap для пользовательских типов можно определять и в std, и в том же пространстве имён, откуда они;
- distance с advance - только в std, если вы
( Read more... )
Comments 7
Reply
Ведь я прочитал об этом в книжке-справочнике по шаблонам функций и классов, но описанный подход ни коем образом не связан с ними.
P.S.: А ещё из-за этой книги я долго тупил в последние дни над осознанием того, чего я не понимал: указатели на члены класса, которых нет и никогда не будет в самом классе.
Reply
(The comment has been removed)
Судя по всему, для этого анонимуса подходит твоё "просто некошерно".
Я решил проверить это утверждение на зуб, нашел много интересного по ходу ( что-то изложено в моём посте), и пришел к выводу, что когда припрёт, пАлюбому, расширять std надо, от этого никуда не денешься ( ... )
Reply
(The comment has been removed)
Т.е., мне не к спеху, как соберёшься, даже можно уже почитанную, я не скуплюсь полностью оплатить полную её цену.
Как думаешь, а? :-)
Reply
> потому, что STL может предоставить оптимальные реализации для всех возможных категорий
> итераторов" - вызвало у меня недоумение.
Он всё правильно говорит. distance определена для трех категорий итераторов: Forward, Bidirectional, Random Access. Для первых двух она реализована как последовательный инкремент, для последнего -- как разность двух итераторов. По идеи ты должен просто указать категорию итератора, а реализация STL сама выберет для неё distance.
Если бы я писал свой итератор, скажем, по дереву и для него можно было бы быстро реализовать distance, (быстрее чем Forward итератор и медленее чем RNA) я бы добавил его distance в std:: и не парился бы.
Reply
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 ( ... )
Reply
Leave a comment