localtime
是C++标准库中的一个函数,它用于将一个UTC时间(通常是std::time_t
类型)转换为一个本地时间(通常是std::tm
类型)。下面是一个简单的示例,展示了如何使用localtime
函数:
#include#include int main() { // 获取当前UTC时间 std::time_t utc_time = std::time(nullptr); // 将UTC时间转换为本地时间 std::tm local_time = *std::localtime(&utc_time); // 输出本地时间 std::cout << "Local time: " << std::put_time(&local_time, "%Y-%m-%d %H:%M:%S") << std::endl; return 0; }
在这个示例中,我们首先使用std::time(nullptr)
获取当前的UTC时间。然后,我们使用std::localtime
函数将UTC时间转换为一个本地时间。最后,我们使用std::cout
和std::put_time
输出本地时间。
注意,localtime
返回的是一个指向静态缓冲区的指针,因此多次调用localtime
可能会导致意外的结果。为了避免这种情况,你可以使用std::localtime_r
函数,它接受一个额外的参数,用于存储转换后的本地时间:
#include#include int main() { // 获取当前UTC时间 std::time_t utc_time = std::time(nullptr); // 将UTC时间转换为本地时间 std::tm local_time; if (std::localtime_r(&utc_time, &local_time) == nullptr) { std::cerr << "Error converting time" << std::endl; return 1; } // 输出本地时间 std::cout << "Local time: " << std::put_time(&local_time, "%Y-%m-%d %H:%M:%S") << std::endl; return 0; }
这个示例与之前的示例功能相同,但使用了std::localtime_r
来确保每次调用都能安全地转换时间。