go获取两个时间点的时间差、当前时间秒/毫秒/纳秒数以及几天前/后、几小时前/后、几分钟前/后、几秒前/后的时间

 筚路蓝缕,以启山林。抚有蛮夷,以属华夏。不鸣则已,一鸣惊人。
                                                                                                          ——左传`宣公十二年


 

目录

获取当前时间及其秒、毫秒、纳秒数

获取指定时间前的时间

获取指定时间后的时间

获取两个时间点的时间差


获取当前时间及其秒、毫秒、纳秒数

now := time.Now() //获取当前时间
==>2019-08-21 11:30:51.2470317 +0800 CST m=+0.004501101
fmt.Printf("时间戳(秒):%v;\n", time.Now().Unix())        //10位
fmt.Printf("时间戳(纳秒):%v;\n",time.Now().UnixNano())    //19位
fmt.Printf("时间戳(毫秒):%v;\n",time.Now().UnixNano() / 1e6)        //或者秒*1000也可
fmt.Printf("时间戳(纳秒-->秒):%v;\n",time.Now().UnixNano() / 1e9)

获取指定时间前的时间

// 获取50秒前的时间,方式1
st,_ := time.ParseDuration("-50s")
fmt.Println("50秒前的时间:",time.Now().Add(st))

// 获取1分钟前的时间,n秒前则是time.Second * -n,方式2
t := time.Now().Add(time.Minute * -1) 
fmt.Println("一分钟前的时间:",t)

//获取1小时前的时间
sth,_ := time.ParseDuration("-1h")
fmt.Println("1小时前的时间:",time.Now().Add(sth))

// 获取2天前的时间
oldTime := time.Now().AddDate(0, 0, -2)

//获取两个月前的时间
oldTime := time.Now().AddDate(0, -2, 0)

获取指定时间后的时间

// 获取50秒后的时间,方式1
st,_ := time.ParseDuration("50s")
fmt.Println("50秒之后的时间:",time.Now().Add(st))

// 获取1分钟后的时间,n秒前则是time.Second * n,方式2
t := time.Now().Add(time.Minute * 1) 
fmt.Println("一分钟后的时间:",t)

//获取1小时后的时间
sth,_ := time.ParseDuration("1h")
fmt.Println("1小时之后的时间:",time.Now().Add(sth))

// 获取当前时间2天后的时间
newTime := time.Now().AddDate(0, 0, 2)
//newTime 的结果为时间time类型

//获取当前时间2月后的时间
newTime := time.Now().AddDate(0, 2, 0)

获取两个时间点的时间差

t1 := time.Now()
//设置期间经历了50秒时间
t2 := time.Now().Add(time.Second * 50)
fmt.Println("t2与t1相差:",t2.Sub(t1))		//t2与t1相差: 50s

### 实现毫秒、微纳秒级别系统时间差计算 在C/C++中,可以利用标准库中的`<chrono>`头文件以及POSIX定义的结构体来实现毫秒、微甚至纳秒级别的系统时间差计算。以下是几种常见的方法及其具体实现。 #### 使用 `<chrono>` 头文件 现代C++提供了强大的时间处理工具——`std::chrono`,它支持多种分辨率的时间测量。通过该库,能够轻松获取并比较不同粒度的时间戳。 ```cpp #include <iostream> #include <chrono> int main() { auto start = std::chrono::high_resolution_clock::now(); // 开始计时 // 模拟耗时操作 volatile int i = 0; while (i++ < 1e8); auto end = std::chrono::high_resolution_clock::now(); // 结束计时 // 计算时间差 std::chrono::duration<double, std::milli> duration_ms = end - start; // 毫秒 std::chrono::duration<double, std::micro> duration_us = end - start; // 微 std::chrono::duration<double, std::nano> duration_ns = end - start; // 纳秒 std::cout << "Duration in milliseconds: " << duration_ms.count() << " ms\n"; std::cout << "Duration in microseconds: " << duration_us.count() << " us\n"; std::cout << "Duration in nanoseconds: " << duration_ns.count() << " ns\n"; return 0; } ``` 这种方法基于高精度时钟[^1],适用于跨平台开发场景,并能提供较高的时间分辨率。 --- #### 使用 `gettimeofday()` 函(Linux/Unix) 在POSIX兼容的操作系统上,可以通过调用`gettimeofday()`函获取当前时间和日期信息。此函返回的是自UNIX纪元以来经过的和微。 ```cpp #include <sys/time.h> #include <stdio.h> void getTimeDifference(struct timeval& startTime, struct timeval& endTime) { double elapsedTimeUs = (endTime.tv_sec - startTime.tv_sec) * 1e6 + (endTime.tv_usec - startTime.tv_usec); printf("Elapsed Time: %.6f μs\n", elapsedTimeUs); // 输出微时间差 } int main() { struct timeval tStart, tEnd; gettimeofday(&tStart, NULL); // 获取起始时间 // 模拟耗时操作 volatile int i = 0; while (i++ < 1e7); gettimeofday(&tEnd, NULL); // 获取结束时间 getTimeDifference(tStart, tEnd); // 打印时间差 return 0; } ``` 这里需要注意,在某些情况下,`tv_usec`字段可能会溢出,因此需要特别小心处理边界条件[^2]。 --- #### Windows 平台下的 `QueryPerformanceCounter` Windows API 提供了一个高性能计器接口——`QueryPerformanceCounter`,它可以用来精确地记录短时间段内的流逝时间。 ```cpp #include <windows.h> #include <iostream> double getFrequency() { LARGE_INTEGER freq; QueryPerformanceFrequency(&freq); return static_cast<double>(freq.QuadPart); } double calculateElapsedTime(LARGE_INTEGER start, LARGE_INTEGER end, double frequency) { return ((end.QuadPart - start.QuadPart) / frequency) * 1e9; // 转换为纳秒 } int main() { LARGE_INTEGER startCount, endCount; double frequency = getFrequency(); QueryPerformanceCounter(&startCount); // 开始计时 // 模拟耗时操作 volatile int i = 0; while (i++ < 1e7); QueryPerformanceCounter(&endCount); // 停止计时 double elapsedNs = calculateElapsedTime(startCount, endCount, frequency); std::cout << "Elapsed Time: " << elapsedNs << " ns\n"; // 显示纳秒时间差 return 0; } ``` 这段代码展示了如何使用硬件性能计器来达到更高的精度[^4]。 --- #### 利用 CPU TSC 寄存器读取周期 如果目标机器支持RDTSC指令,则可以直接访问处理器内部的TSC寄存器以获得非常高的频率计值。不过这种方式依赖于特定架构且不具备可移植性。 ```cpp unsigned __int64 GetCpuCycle(void) { unsigned __int64 cycles; asm volatile ("rdtsc" : "=A"(cycles)); return cycles; } // 测试程序省略... ``` 尽管如此,由于多核环境可能导致不一致的结果,建议仅将其作为实验用途而非生产环境中推荐的做法[^3]。 --- ### 总结 以上介绍了四种不同的技术手段分别针对不同类型的需求进行了阐述。每种方案都有其适用范围与局限之处,请根据实际应用场景选择合适的解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ProblemTerminator

您的鼓励将是作者最大的动力哦!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值