Наследники:Если (i)<lhs>типа<Lhs>можно использовать в выражении<lhs++>, и (ii)<Ret=dont_care>или результат выражения<lhs++>конвертируем в<Ret>, то наследуется отtrue_type, в противном случае наследуется отfalse_type.
По умолчанию поведение<Ret=dont_care>не проверяется на возвратное значение постфикса<operator++>. Если<Ret>отличается от стандартного<dont_care>типа, значение возврата проверяется на конвертируемость в<Ret>. Конвертируемое к<Ret>означает, что возвращаемое значение оператора может быть использовано в качестве аргумента для функции, ожидающей<Ret>:
voidf(Ret);Lhslhs;f(lhs++);// is valid if has_post_increment<Lhs, Ret>::value==true
Если<Ret=void>, то тип возврата проверяется точно<void>.
Совместимость компилятора:Требуется работа SFINAE (т.е. BOOST_NO_SFINAE не установлен). Этого не поддерживает лишь меньшинство довольно старых компиляторов.
Эта черта не может определить, является ли исправление<operator++>общедоступным или нет: если<operator++>определено как частный член<Lhs>, то инстанцирование<has_post_increment<Lhs>>приведет к ошибке компилятора. По этой причине<has_post_increment>не может использоваться для определения того, имеет ли тип публичный<operator++>или нет.<
structA{private:voidoperator++(int);};boost::has_post_increment<A>::value;// error: A::operator++(int) is private
>
Существует проблема, если оператор существует только для типа<A>и<B>является конвертируемым в<A>. В этом случае компилятор сообщит о двусмысленной перегрузке.<
structA{};voidoperator++(constA&,int);structB{operatorA();};boost::has_post_increment<A>::value;// this is fineboost::has_post_increment<B>::value;// error: ambiguous overload
>
Существует проблема при применении этой черты к классам шаблонов. Если<operator++>определен, но не связывается для данного типа шаблона, он все еще обнаруживается чертой, которая возвращается<true>вместо<false>. Пример:<
#include<boost/type_traits/has_post_increment.hpp>#include<iostream>template<classT>structcontains{Tdata;};template<classT>booloperator++(constcontains<T>&lhs,int){returnf(lhs.data);}classbad{};classgood{};boolf(constgood&,constgood&){}intmain(){std::cout<<std::boolalpha;// works fine for contains<good>std::cout<<boost::has_post_increment<contains<good>>::value<<'\n';// truecontains<good>g;g++;// ok// does not work for contains<bad>std::cout<<boost::has_post_increment<contains<bad>>::value<<'\n';// true, should be falsecontains<bad>b;b++;// compile time errorreturn0;}
>
<volatile>квалификатор не обрабатывается должным образом и приведет к неопределенному поведению
Статья has_post_increment раздела Chapter 1. Boost.TypeTraits Alphabetical Reference может быть полезна для разработчиков на c++ и boost.
Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.