Я играю с новым 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, или я понял что-то не так?