1

我有以下代码,我正在努力获得做我想做的声明的方式。

我希望将当前时间输出到毫秒精度(四舍五入也可以,例如 129999 我们可以四舍五入到 129 毫秒,但在这种情况下我更喜欢 130)。

注意:我正在使用 fmt ,因为从我看到<format>的标题中仍然没有实现。

#include<string>
#include<chrono>
#include<iostream>
#include<thread>
#include<fmt/format.h>
#include<fmt/chrono.h>

using namespace std::chrono;
int main(){
    for (int i =0; i<5;++i){
    // I wish this was local_time, not sys time, and that sys_time<milliseconds> worked
    const std::chrono::sys_time<nanoseconds> now =
        (std::chrono::system_clock::now());
    auto round_now = std::chrono::round<milliseconds>(now);
    int64_t ms = (round_now.time_since_epoch()%seconds(1)).count();
    // %S does not print milliseconds
    std::cout << fmt::format("{:%F %H:%M:%S}.{:03}", now, ms) << std::endl;     
    std::cout << std::endl;   
    std::this_thread::sleep_for(milliseconds(100));
    }
    std::cout << "Bye";
}
4

2 回答 2

2

%S默认打印毫秒。例如:

#include <fmt/chrono.h>

int main() {
  fmt::print("{:%S}", std::chrono::system_clock::now().time_since_epoch());
}

打印(实际输出当然取决于当前时间):

34.459

神箭:https ://godbolt.org/z/Y1jzv5

于 2020-09-10T19:04:19.763 回答
1
#include <fmt/chrono.h>

auto a = system_clock::now();
print("{:%FT%T%Oz}\n", a);
print("{0:%FT%H:%M:}{1:%S}{0:%Oz}\n", a,a.time_since_epoch());

印刷

2021-04-13T21:38:04+0800
2021-04-13T21:38:04.076+0800
于 2021-04-13T13:38:56.327 回答