boost::posix_time::milliseconds与boost::chrono::milliseconds的
Difference between boost::posix_time::milliseconds and boost::chrono::milliseconds
我正在尝试使用condition_variable_any::timed_wait()
当我向函数传递boost::chrono::millisecond
时,它无法编译:
error: no match for ‘operator+’ in ‘boost::get_system_time() + wait_duration’
然而,如果我传递boost::posix_time::milliseconds
到函数,它确实编译。
boost::posix_time::milliseconds p(1000)
代表了历元后1秒的时间。我不认为这是一个持续时间。
我错过了什么?有人能解释一下它们的区别吗?
我将尝试一下,尽管我不是标准委员会的开发人员或成员。
Boost是一个想法的游乐场,这些想法可能有一天会集成到标准库中。因此,它经常有一些你在其他地方看不到的怪癖。
boost::posix_time是posix_time数据结构的包装器。POSIX(可移植操作系统接口)是IEEE给出的一组标准,试图让所有操作系统和程序使用类似的语言(剧透,它们不是)。POSIX为时间和时间差定义了一个定点数字系统,尽管该结构的分辨率各不相同。在BOOST中,分辨率在编译时是可配置的。该库的目标是更容易地操作POSIX辅助时间结构。在1.31之前介绍过。
boost::chrono(作为std::chrono集成到c++ 11中)是一个通用的时间尺度库。我们的目标是拥有一组可以很好地处理时间的函数和结构,并允许用户配置底层数据类型。没有努力去符合任何标准。在1.51版引入。
虽然这(100%)是两个库做同样的事情,但它们的方式略有不同。在boost这样的系统中,这可以说是不可避免的:对于新的语言特性和编程需求,您可能想要完全折射一些东西,但需要保持(某种程度上)向后兼容性。但它导致了一个奇怪的问题:不同的实现,只是为了迷惑你。因为POSIX时间太老了,所以大多数接口(如condition_variable_any::timed_wai)只有posix_time接口。
- 理解boost::asio-async_read在无需读取内容时的行为
- boost::进程间消息队列引发错误
- 如何运行位于boost/libs/python/example/tutorial目录中的hello.cpp和Jamfil
- cmake如何在fedora工作站中找到boost静态库包
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- Boost Graph Library,修复节点大小
- 什么是"#include <boost/functional/hash.hpp> "?
- 基于boost的程序的静态链接——zlib问题
- C++:如何在CLion IDE中安装Boost
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 如何在boost beast http请求中设置http头
- Boost Spirit,获取迭代器内部语义动作
- boost::asio::steady_timer()与sleep()我应该使用哪一个
- boost::asio如何生成多个协同程序,然后加入它们
- 当我尝试使用 sstream 和分面将 Boost Time_duration转换为字符串时,我没有得到所需的格式
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- 如何使用boost::具有嵌套结构和最小代码更改的序列化
- 使用Boost Interprocess创建托管共享内存需要很长时间
- 如何将“ std :: chrono :: milliseconds”铸造为`boost :: posix_time :
- boost::posix_time::milliseconds与boost::chrono::milliseconds的