c++时间类型
时间类型可以说是非常常用的类型,在使用的过程中经常感觉掌握的不够全面,这里梳理一下,作为记录。
C风格时间
tm结构体
在C++11之前,标准库中并没有提供专门的时间和日期类型。为了处理时间和日期,开发者通常会C语言提供的时间和类型。现在C++项目基本上都使用了C++11及更高的版本,但是一些古早的代码或者库接口还是能看到C风格的时间。
为了使用C语言踢狗的日期和时间相关的函数和结构,需要在 C++ 程序中引用 <ctime>
头文件。
有四个与时间相关的类型:clock_t
、time_t
、size_t
和 tm
。类型 clock_t
、size_t
和 time_t
能够把系统时间和日期表示为某种整数。
结构类型 tm
把日期和时间以 C 结构的形式保存,tm 结构的定义如下:
1 | struct tm { |
相关函数
一些跟C风格时间有关的函数如下:
序号 | 函数 & 描述 |
---|---|
time_t time(time_t *time); | 该函数返回系统的当前日历时间,自 1970 年 1 月 1 日以来经过的秒数。如果系统没有时间,则返回 -1。 |
char *ctime(const time_t *time); | 该返回一个表示当地时间的字符串指针,字符串形式 day month year hours:minutes:seconds year\n\0。 |
struct tm *localtime(const time_t *time); | 该函数返回一个指向表示本地时间的 tm 结构的指针。 |
clock_t clock(void); | 该函数返回程序执行起(一般为程序的开头),处理器时钟所使用的时间。如果时间不可用,则返回 -1。 |
char * asctime ( const struct tm * time ); | 该函数返回一个指向字符串的指针,字符串包含了 time 所指向结构中存储的信息,返回形式为:day month date hours:minutes:seconds year\n\0。 |
struct tm *gmtime(const time_t *time); | 该函数返回一个指向 time 的指针,time 为 tm 结构,用协调世界时(UTC)也被称为格林尼治标准时间(GMT)表示。 |
time_t mktime(struct tm *time); | 该函数返回日历时间,相当于 time 所指向结构中存储的时间。 |
double difftime ( time_t time2, time_t time1 ); | 该函数返回 time1 和 time2 之间相差的秒数。 |
size_t strftime(); | 该函数可用于格式化日期和时间为指定的格式。 |
格式化成字符串:
1 | time_t now = time(NULL); |
C++11之后提供了string格式化函数put_time
用法如下
1 |
|
字符串格式化成时间:
1 | const char *time_string = "2023-10-07 14:30:00"; |
用例
用时间类函数给代码片段计时:
1 |
|
这种方法虽然简单易用,但是实际上这种计时方法只能精确到秒级,如果想要精确到毫秒级需要使用POSIX
提供的gettimeofday
函数和timeval
结构体
timeval结构体
timeval结构体非常简单,只由两个成员变量组成
1 | struct timeval { |
相关函数
gettimeofday()
函数是POSIX标准的一部分,用于获取当前时间,精度可以达到微秒级别。以下是 gettimeofday()
函数的详细文档:
1 |
|
tv
:指向struct timeval
类型的指针,用于存储当前时间。tz
:指向struct timezone
类型的指针,用于存储时区信息。不过,这个参数在现代系统中通常被忽略,应该设置为NULL
。- 成功时返回0,失败时返回-1,并设置
errno
以指示错误类型。
用例
使用下面这段代码可以统计高精度的计时
1 |
|
C++风格时间
C++11标准引入了<chrono>
库是。它提供了C++版的时间和日期处理函数和数据类型,并且它是跨平台的,在开始时不用考虑平台上的差异,他包含以下内容:
时钟(Clocks):
system_clock
:表示系统的实时时钟,通常与当前日期和时间相关联。steady_clock
:一个稳定的时钟,不会因为系统时间的调整而改变,适用于测量时间间隔。high_resolution_clock
:系统中具有最高分辨率的时钟,通常是system_clock
或steady_clock
的别名。
一般来说
steady_clock
有比system_clock
更高的时间精度,具有纳秒级别的时间精度。时间点(Time Points):
time_point
:表示一个特定的时间点,通常与某个时钟相关联,可以选择上面介绍的三种时钟之一。例如:1
std::chrono::time_point<std::chrono::system_clock> now = std::chrono::system_clock::now();
时间间隔(Durations):
std::chrono::duration
是 C++ 标准库中的一个类模板,用于表示时间间隔。1
2
3
4namespace std::chrono {
template <class Rep, class Period = std::ratio<1>>
class duration;
}Rep
:表示存储时间值的类型(如int
、long long
、double
等)。Period
:表示时间单位,相对于秒的比例(如std::ratio<1>
表示秒,std::milli
表示毫秒)。
时间转换和格式化:
duration_cast
:用于在不同的时间单位之间进行转换。例如:1
auto milliseconds = std::chrono::duration_cast<std::chrono::milliseconds>(elapsed_seconds);
time_point_cast
:用于在不同的时间点类型之间进行转换。例如:1
auto tp_ms = std::chrono::time_point_cast<std::chrono::milliseconds>(now);
to_time_t
:可以将system_clock
的时间点转换为time_t
类型,以便与C风格的日期时间函数交互。例如:1
std::time_t now_c = std::chrono::system_clock::to_time_t(now);
用例
一段使用chrono
统计代码耗时的代码如下
1 |
|