在C++中获取当前年份的更优雅的方法

enxuqcxy  于 2022-12-15  发布在  其他
关注(0)|答案(4)|浏览(305)

我对C++还是个新手。我需要得到当前年份并将其存储在一个int型变量中。
我得出了这个解决方案:

  1. std::time_t result = std::time(nullptr);
  2. std::istringstream iss(ctime(&result));
  3. iss.ignore(20);
  4. int year;
  5. iss >> year;

我发现这个解决方案有点难看,即使它工作,因为它似乎不是很健壮,它需要很多步骤来做不太多。
有没有更好的办法?

643ylb08

643ylb081#

C++20中,您可以使用std::chrono来实现此目的。
P0355R7 Extending to Calendars and Time Zones

  1. #include <iostream>
  2. #include <format>
  3. #include <chrono>
  4. int main()
  5. {
  6. const auto now = std::chrono::system_clock::now();
  7. std::cout << std::format("{:%Y}", now); // => 2021
  8. }
o0lyfsai

o0lyfsai2#

在我看来,将time_t转换为字符串并随后进行字符串解析是不必要的复杂和容易出错的。正如@Ted的评论中所抱怨的那样,这可能会引入文本输出的本地化,从而使解析变得不健壮。
std::time()一起,还有

将自纪元以来的给定时间作为std::time_t值转换为日历时间,以本地时间表示。

将自纪元std::time_t值起的给定时间转换为日历时间,以协调世界时(UTC)表示。
两者都返回指向struct tm的指针,struct tm包含公共成员
自1900年以来int tm_year
小样本:

  1. #include <ctime>
  2. #include <iostream>
  3. int main()
  4. {
  5. std::time_t t = std::time(nullptr);
  6. std::tm *const pTInfo = std::localtime(&t);
  7. std::cout << "Current year: " << 1900 + pTInfo->tm_year << '\n';
  8. }

输出:

  1. Current year: 2019

Live Demo on coliru

展开查看全部
56lgkhnf

56lgkhnf3#

  1. #include <ctime>
  2. #include <iostream>
  3. using namespace std;
  4. int main()
  5. {
  6. time_t current_time;
  7. current_time = time(NULL);
  8. int a;
  9. a = 1970 + current_time / 31537970;
  10. cout << a << " is the current year.";
  11. return 0;
  12. }
wd2eg0qa

wd2eg0qa4#

简而言之,下面的get_this_year()函数应该可以用C++20的方式工作。
它将返回当前年份的int

  1. // year.cpp
  2. #include <chrono>
  3. #include <iostream>
  4. int get_current_year() {
  5. using namespace std::chrono;
  6. return static_cast<int>(
  7. year_month_day{time_point_cast<days>(system_clock::now())}.year());
  8. }
  9. int main() {
  10. int year = get_current_year();
  11. std::cout << year << std::endl; // 2022
  12. }

这应该使用g++ -std=c++20 year.cpp等进行编译。
但我也想以一种冗长的方式展开它,解释每一步发生了什么。

  1. // year.cpp
  2. #include <chrono>
  3. #include <iostream>
  4. int get_current_year() {
  5. using namespace std::chrono;
  6. auto now = system_clock::now(); // 1. get time_point for now
  7. auto today = time_point_cast<days>(now); // 2. cast to time_point for today
  8. auto ymd = year_month_day(today); // 3. convert to year_month_day
  9. auto year = ymd.year(); // 4. get year from year_month_day
  10. return static_cast<int>(year); // 5. an explicit cast is required
  11. }
  12. int main() {
  13. int year = get_current_year();
  14. std::cout << year << std::endl; // 2022
  15. }

现在,更详细地,明确地说出所有的类型-

  1. // year.cpp
  2. #include <chrono>
  3. #include <iostream>
  4. int get_current_year() {
  5. std::chrono::time_point<std::chrono::system_clock,
  6. std::chrono::system_clock::duration>
  7. now = std::chrono::system_clock::now();
  8. std::chrono::time_point<std::chrono::system_clock, std::chrono::days> today =
  9. std::chrono::time_point_cast<std::chrono::days>(now);
  10. std::chrono::year_month_day ymd = std::chrono::year_month_day(today);
  11. std::chrono::year year = ymd.year();
  12. return static_cast<int>(year);
  13. }
  14. int main() {
  15. int year = get_current_year();
  16. std::cout << year << std::endl; // 2022
  17. }

基本上有两种类型的格式来表示时间点:
1.基于序列-例如,该时间点自一个时期(例如,1970年1月1日)以来为x
1.基于字段-例如,该时间点为year/month/day
从系统时钟中我们得到一个基于序列的时间点,我们需要将它转换成一个基于字段的时间点,然后从这个基于字段的时间点中提取年份。

展开查看全部

相关问题