如何将std :: chrono :: system_clock :: duration转换为struct timeval

chm*_*ike 5 timeval c++-chrono

标题说明了一切.

我必须实现一个接收std :: chrono :: system_clock :: duration值的函数,并且需要将其转换为timeval sruct,以便将其传递给某个系统函数.

Nev*_*ore 8

更一般的实施.

template<typename Duration>
void to_timeval(Duration&& d, struct timeval & tv) {
    std::chrono::seconds const sec = std::chrono::duration_cast<std::chrono::seconds>(d);

    tv.tv_sec  = sec.count();
    tv.tv_usec = std::chrono::duration_cast<std::chrono::microseconds>(d - sec).count();
}
Run Code Online (Sandbox Code Playgroud)

更新:

像单独的方法to_timeval()不太方便.超载力量在哪里?我们刚刚将硬编码类型timeval转换为函数名称to_timeval().这不是C++的方式.struct timeval例如,我想传入std::chrono::duration_cast()并得到我的chrono结果,反之亦然.

因此,我们可以延长std::chrono::duration_cast(当然,风险自负).请享用.

namespace std {
namespace chrono {
namespace detail {

template<typename From, typename To>
struct posix_duration_cast;

// chrono -> timeval caster
template<typename Rep, typename Period>
struct posix_duration_cast< std::chrono::duration<Rep, Period>, struct timeval > {

    static struct timeval cast(std::chrono::duration<Rep, Period> const& d) {
        struct timeval tv;

        std::chrono::seconds const sec = std::chrono::duration_cast<std::chrono::seconds>(d);

        tv.tv_sec  = sec.count();
        tv.tv_usec = std::chrono::duration_cast<std::chrono::microseconds>(d - sec).count();

        return std::move(tv);
    }

};

// timeval -> chrono caster
template<typename Rep, typename Period>
struct posix_duration_cast< struct timeval, std::chrono::duration<Rep, Period> > {

    static std::chrono::duration<Rep, Period> cast(struct timeval const & tv) {
        return std::chrono::duration_cast< std::chrono::duration<Rep, Period> >(
                    std::chrono::seconds(tv.tv_sec) + std::chrono::microseconds(tv.tv_usec)
                    );
    }

};

}

// chrono -> timeval    
template<typename T, typename Rep, typename Period>
auto duration_cast(std::chrono::duration<Rep, Period> const& d)
-> std::enable_if_t< std::is_same<T, struct timeval>::value, struct timeval >
{
    return detail::posix_duration_cast< std::chrono::duration<Rep, Period>, timeval >::cast(d);
}

// timeval -> chrono
template<typename Duration>
Duration duration_cast(struct timeval const& tv) {
    return detail::posix_duration_cast< struct timeval, Duration >::cast(tv);
}

} // chrono
} // std
Run Code Online (Sandbox Code Playgroud)

这只是一个例子.作为替代方案,我们可以实现自己的,duration_cast()并在某些情况下转发它std::chrono::duration_cast().

我们记得struct timespec.


chm*_*ike 6

ð是输入持续时间值和电视输出的timeval结构由实心转换功能.注意:如果持续时间为负,则函数将timeval设置为0.

void convert( const std::chrono::system_clock::duration &d, timeval &tv )
{
  chrono::microseconds usec = chrono::duration_cast<chrono::microseconds>(d);
  if( usec <= chrono::microseconds(0) )
    tv.tv_sec = tv.tv_usec = 0;
  else
  {
    tv.tv_sec = usec.count()/1000000;
    tv.tv_usec = usec.count()%1000000;
  }
}
Run Code Online (Sandbox Code Playgroud)