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 |
|