Пользовательские литералы C++ для любого типа

На данный момент пользовательские литералы принимают ограниченный набор типов в качестве входного параметра (см. Здесь). Планируется ли принимать какой-либо тип в качестве входного параметра, и если нет, то почему?

Например, я мог бы захотеть получить std:: chrono:: duration в другом формате (секунды, миллисекунды и т. Д.) И сделать что-то вроде

constexpr double operator"" _s(std::chrono::nanosecond time)
{
   return std::chrono::duration_cast<std::chrono::duration<double, std::chrono::seconds::period>>(time).count();
}

constexpr long operator"" _us(std::chrono::nanoseconds time)
{
    return std::chrono::duration_cast<std::chrono::microseconds>(time).count();
}

// And so on ...

int main()
{
    auto t0 = std::chrono::high_resolution_clock::now();
    // do some stuff
    auto t1 = std::chrono::high_resolution_clock::now();

    std::cout << "Time in seconds : " << (t1 - t0)_s << "s\n";
    std::cout << "Time in microseconds : " << (t1 - t0)_us << "µs\n";

    return 0;
}

1 ответ

Возможно, вы могли бы вместо этого использовать вспомогательные структуры:

#include <chrono>
#include <iostream>

using namespace std::literals::chrono_literals;

template <class Duration>
struct dc {
    using rep = typename Duration::rep;
    const std::chrono::nanoseconds time;
    constexpr dc(std::chrono::nanoseconds time):time(time) { }
    constexpr operator rep() {
       return std::chrono::duration_cast<Duration>(time).count();
    }
};

using s_ = dc<std::chrono::seconds>;
using us_ = dc<std::chrono::microseconds>;

// And so on ...

template <us_::rep N>
struct S {
};

int main()
{
    auto t0 = std::chrono::high_resolution_clock::now();
    // do some stuff
    auto t1 = std::chrono::high_resolution_clock::now();
    std::cout << "Time in seconds : " << s_(t1 - t0) << "s\n";
    std::cout << "Time in microseconds : " << us_(t1 - t0) << "µs\n";
    S<us_(10us)> us;
    (void)us;
    return 0;
}

[живое демо]

Другие вопросы по тегам