Я играю с новым explicit
для операторов-литов. Если вы напишете что-то вроде
struct Data {
explicit operator string();
};
Невозможно случайно преобразовать Data
в string
. Исключением является тип данных darget bool
: в некоторых случаях допускается неявное преобразование, даже если оно помечено explicit
- контекстное преобразование. Таким образом, вы можете использовать эти типы данных в if(...)
, например:
struct Ok {
explicit operator bool(); // allowed in if(...) anyway
};
Параграф "25.4. (2)" Сортировка и связанные операции ", по-видимому, позволяет это для Compare
функтора стандартных контейнеров, например set
. Но мои попытки с gcc-4.7.0 терпят неудачу, и я уверен, что если это мое неправильное понимание или ошибка в gcc?
#include <set>
struct YesNo { // Return value type of Comperator
int val_;
explicit YesNo(int y) : val_{y} {}
/* explicit */ operator bool() { return val_!=0; }
};
static const YesNo yes{1};
static const YesNo no{0};
struct LessYesNo { // Comperator with special return values
YesNo operator()(int a, int b) const {
return a<b ? yes : no;
}
};
int main() {
std::set<int,LessYesNo> data {2,3,4,1,2};
}
Без explicit
до operator bool()
пример компилируется. И мое понимание "25.4. (2)" заключается в том, что это также должно компилировать с явным.
Я правильно понял Std, что для set
также explicit
bool
преобразования должны работать? И может быть, это ошибка в gcc, или я понял что-то не так?