Home
Document
Q&A
Video
Donate
Source Code
Code-Galaxy 云原生平台
Business
Swoole Tracker
Swoole Compiler
Login
Register
全部
提问
分享
讨论
建议
公告
开发框架
发表新帖
Swoole 底层获取时间的方法
最新的代码中使用了 `C++11` 的 `chrono` 标准库处理时间。`C` 标准库中获取当前时间戳的函数是 `time(NULL)`,缺点是只能精确到秒。在 `Swoole` 中做了一个封装,可以使用 `swoole::time()` 函数来获取时间。 ```c++ long ms1 = swoole::time<std::chrono::milliseconds>(); ``` 时间单位 ---- 此函数需要设置模板参数,表示返回的单位,可以选择: - 纳秒:`std::chrono::nanoseconds` - 微秒:`std::chrono::microseconds` - 毫秒:`std::chrono::milliseconds` - 秒:`std::chrono::seconds` - 分:`std::chrono::minutes` - 时:`std::chrono::hours` 如使用`std::chrono::minutes`就会返回从`Unix起始时间1970年`距今的分钟数。 单调时间 ----- `swoole::timer()`还支持了`steady`单调递增时间,可防止修改系统时间引起的时间回退问题。设置参数为 `true` 即可。例如: ```c++ swoole::time<std::chrono::milliseconds>(true); ``` 是不是很简单?如果你对于`Swoole`内核开发很感兴趣可以考虑加入我们。
发布于2年前 · 59 次浏览 · 来自
分享
Rango
最新的代码中使用了 `C++11` 的 `chrono` 标准库处理时间。`C` 标准库中获取当前时间戳的函数是 `time(NULL)`,缺点是只能精确到秒。在 `Swoole` 中做了一个封装,可以使用 `swoole::time()` 函数来获取时间。 ```c++ long ms1 = swoole::time<std::chrono::milliseconds>(); ``` 时间单位 ---- 此函数需要设置模板参数,表示返回的单位,可以选择: - 纳秒:`std::chrono::nanoseconds` - 微秒:`std::chrono::microseconds` - 毫秒:`std::chrono::milliseconds` - 秒:`std::chrono::seconds` - 分:`std::chrono::minutes` - 时:`std::chrono::hours` 如使用`std::chrono::minutes`就会返回从`Unix起始时间1970年`距今的分钟数。 单调时间 ----- `swoole::timer()`还支持了`steady`单调递增时间,可防止修改系统时间引起的时间回退问题。设置参数为 `true` 即可。例如: ```c++ swoole::time<std::chrono::milliseconds>(true); ``` 是不是很简单?如果你对于`Swoole`内核开发很感兴趣可以考虑加入我们。
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
评论
2021-12-23
Rango
1024
赞
0
回复
微信公众号
热门内容
- swoole针对400的请求--TRACE Port_onRead_http() (ERRNO 7102): Bad Request: unknown protocol from session#193 on 0.0.0.0:9505
- 基于Swoole+PHP的超高性能短信网关(CMPP、SMPP)模拟器
- http服务中,使用write分段输出文件。设置header总文件长度无用
- Call to undefined function Swoole\Coroutine\run() 是怎么回事啊?
- Swoole Loader扩展 如何下载,https://business.swoole.com/trial/download/ 404
- 请教当使用request主动推送的时候,产生新的连接,及会马上关闭连接问题
- 为什么连接池只创建一个连接
- timer定时器,启动一下,突然执行了1万多次,这是怎么回事呢?
- 在swoole 中, 使用地址引用自身,造成内存增加
- windows 配置wss链接,链接不成功
作者其它话题
- 有没有办法判断当前是否运行在swoole守护进程里面?
暂无回复的问答
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 请问那个一键协程化的代码是放外面还是set里面
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。