Я пытаюсь использовать str_const
класс вдохновленный от https://stackoverflow.com/a/15863826/2859099Лексикографически сравнить две строки во время компиляции в C++ 11
#include <cstddef>
#include <stdexcept>
class str_const
{
public:
template<std::size_t N>
constexpr str_const(const char(&arr)[N]) noexcept : str{arr}, len{N - 1}
{
}
constexpr char operator[](std::size_t i) const
{
return i < len ? str[i] : throw std::out_of_range{""};
}
constexpr std::size_t size() const noexcept { return len; }
constexpr operator const char*() const noexcept { return str; }
constexpr const char* c_str() const noexcept { return str; }
private:
const char* const str;
const std::size_t len;
};
Учитывая ограничения на функции constexpr в C++ 11, как реализовать следующее лексикографическое сравнение:
constexpr bool operator<(str_const lhs, str_const rhs)
{
}
Оцените свой ответ, но я не вижу никаких проблем с этим оператором throw, потому что он просто не скомпилируется, если вызван в контексте constexpr. –
Вы абсолютно правы. http://stackoverflow.com/questions/34280729/throw-in-constexpr-function – CygnusX1