- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
示例:从字符串解析日期/时间,然后我想分解日期/时间的组成部分。似乎我得到了所有内容,但我被困在小数秒上。代码如下
std::wistringstream in{ L"2016-12-11 15:43:22.0999919" };
date::sys_time<std::chrono::microseconds> tp;
in >> date::parse(L"%F %T", tp);
assert(!in.fail());
assert(!in.bad());
date::sys_days dp = date::floor<date::days>(tp);
date::year_month_day the_date = date::year_month_day{ dp };
date::time_of_day<std::chrono::microseconds> the_time = date::make_time(tp - dp);
std::cout << the_date << ' ' << the_time << std::endl;
std::cout << "Year: " << the_date.year() << std::endl;
std::cout << "Month: " << (unsigned)the_date.month() << std::endl;
std::cout << "Date: " << the_date.day() << std::endl;
std::cout << "Hour: " << the_time.hours().count() << std::endl;
std::cout << "Minutes: " << the_time.minutes().count() << std::endl;
std::cout << "Seconds: " << the_time.seconds().count() << std::endl;
//以下是错误的
std::cout << "Micro Seconds: " << the_time.microseconds().count() << std::endl;
错误 C2039:“微秒”:不是“date::time_of_day”的成员
最佳答案
啊,刚刚得到编辑。
正确,microseconds
不是 date::time_of_day
的成员. documentation对于 time_of_day<Duration>
在 Duration
时给出此概要具有亚秒精度:
time_of_day<std::chrono::duration<Rep, Period>>
{
public:
using precision = The decimal-based duration used to format
constexpr time_of_day() noexcept;
constexpr explicit time_of_day(std::chrono::duration<Rep, Period> since_midnight) noexcept;
constexpr std::chrono::hours hours() const noexcept;
constexpr std::chrono::minutes minutes() const noexcept;
constexpr std::chrono::seconds seconds() const noexcept;
constexpr precision subseconds() const noexcept;
constexpr unsigned mode() const noexcept;
constexpr explicit operator precision() const noexcept;
constexpr precision to_duration() const noexcept;
void make24() noexcept;
void make12() noexcept;
};
如果我改变:
the_time.microseconds().count()
到:
the_time.subseconds().count()
然后我得到的输出是:
2016-12-11 15:43:22.099992
Year: 2016
Month: 12
Date: 11
Hour: 15
Minutes: 43
Seconds: 22
Micro Seconds: 99992
这是你得到的吗?如果是,您将得到正确的答案。如果您不明白,请告诉我们您看到了什么。错误时有发生,我感谢错误报告并尝试尽快修复它们。
如果这是您所看到的,并且您不相信它是正确的,您可能会对四舍五入感到困惑。您正在阅读 7 位十进制小数,然后要求将其四舍五入为 6 位小数。如果您希望字符串中时间戳的完全精度,您将需要使用至少 100ns 的单位,例如:
date::sys_time<std::chrono::nanoseconds> tp;
// ...
auto the_time = date::make_time(tp - dp);
// ...
std::cout << "Nanoseconds: " << the_time.subseconds().count() << std::endl;
现在输出结束于:
Nanoseconds: 99991900
更新
名称的基本原理 subseconds
而不是更明显的名称 microseconds
是precision
该成员的(以及返回类型)变化太大,我无法给出更精确的名称来返回小数秒。可能是 nanoseconds
如上所示。或者它甚至可能是像 microfortnights
这样疯狂的东西.
当我注意到这个问题发现了一个错误时,在下面的评论中。事实证明,当我试图解析 microfortnights
我遇到了一个编译时错误,我刚刚修复了它。
关于c++ - 你如何从 Howard Hinnant 日期中得到小数秒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45652554/
我想将 Hinnant 的堆栈分配器(documentation、implementation)与 STL 容器结合使用,但我想对其进行修改,以便永远不会进行动态内存分配。 要实现这一点,必须做的一件
我一直在使用 Howard Hinnant 的 stack allocator它就像一个魅力,但实现的一些细节对我来说有点不清楚。 为什么是全局运营商new和 delete用过的? allocate(
我正在使用 Howard Hinnant 的免费、开源、跨平台、C++11/14 时区库: #include "date/tz.h" #include int main() { std::c
我有一个像这样的日期字符串 YYYYMMDD HHMMSSFFF。我正在尝试使用 Howard Hinnats 日期库。代码片段是这样的, std::chrono::system_clock::tim
我正在尝试使用 Hinnant 的 short_alloc 在堆栈上分配 vector ,我正在尝试完全删除堆分配。现在出现了开发人员使用超出 vector 大小的 push_back 的问题。我正在
示例:从字符串解析日期/时间,然后我想分解日期/时间的组成部分。似乎我得到了所有内容,但我被困在小数秒上。代码如下 std::wistringstream in{ L"2016-12-11 15:43
我最近遇到了 Howard Hinnant 的 short_alloc这是我见过的自定义分配器的最佳示例。 但是当我花更多时间研究代码以将其集成到我的个人项目中时,我突然想到提供基于堆栈的分配的 ar
我正在研究 C++ 中的特定实现。假设我有一个来自 Howard Hinnant's date library 的 date::year_month_day 变量称为 X 我想将其转换为 std::c
我想试试新的 Hinnant's short_alloc allocator据我所知,它取代了旧的 stack_alloc分配器。但是,我无法编译 vector 示例。 g++ 说: ~# g++ -
我目前正在尝试使用 Howard Hinnant's unique_ptr implementation ,并且遇到编译错误。这是一些示例代码: struct Base {}; struct Deri
我有以下代码,使用日期库: #include "date.h" #include #include using namespace date; using namespace std::chron
我正在尝试使用 Howard Hinnant 的 stack_alloc使用 boost rtrees,如以下示例所示: #include "stack_alloc.h" #include usin
我正在尝试使用这个 C++ 日期 library计算特定日期自年初以来的天数。 我可以创建日期对象: date::year_month_day queryDate((date::year(2019))
我正在使用 Howard Hinnant 的漂亮的基于竞技场的小分配器,short_alloc . 令我震惊的是,从 vector 进行的 move 分配可以使用通常的快速 move 分配(即获取目标
我有以下玩具代码: #include "date/date.h" #include using namespace std; using namespace chrono; int main() {
我正在使用 Howard Hinnant 的日期 C++ 库 ( https://howardhinnant.github.io/date/date.html ),但我在使用它时遇到了一些困惑。下面是
我希望能够将自定义分配器与 std::vector 一起使用,以便将小数据缓冲区(例如,小于 1024 字节)存储在堆栈上,并且只有较长的 vector 存储在堆上。作为一个有 Fortran 背景的
问题是我尝试使用 day_point 时出现的错误,day_point 是与 Howard Hinnant 的 date.h 头文件一起使用的命令之一。头文件保存在正确的位置,并且到目前为止与所有其他
我是一名优秀的程序员,十分优秀!