首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
定时器tick函数存在协程api时,下个定时器不会等待前一个执行完成吗?
### 问题描述 下面的代码,每秒钟还是会输出aaa 根据文档说明: 但如果定时器回调函数的执行时间过长,甚至覆盖了下一次定时器执行的时间。底层会进行时间校正,丢弃已过期的行为,在下一时间回调。 ### Swoole版本,PHP版本,以及操作系统版本信息 swoole 4.4.x php7.2.x ### 相关代码 ```php <?php use Swoole\Runtime; Runtime::enableCoroutine(SWOOLE_HOOK_ALL); Swoole\Timer::tick(1000, function(){ echo "aaa\n"; sleep(3); }); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么?
发布于3年前 · 9 次浏览 · 来自
提问
yiyi
### 问题描述 下面的代码,每秒钟还是会输出aaa 根据文档说明: 但如果定时器回调函数的执行时间过长,甚至覆盖了下一次定时器执行的时间。底层会进行时间校正,丢弃已过期的行为,在下一时间回调。 ### Swoole版本,PHP版本,以及操作系统版本信息 swoole 4.4.x php7.2.x ### 相关代码 ```php <?php use Swoole\Runtime; Runtime::enableCoroutine(SWOOLE_HOOK_ALL); Swoole\Timer::tick(1000, function(){ echo "aaa\n"; sleep(3); }); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么?
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2021-06-03
sff
sleep放echo前面
赞
0
回复
2021-06-03
MARiA
你好,这是我的个人见解。 我想应该是你的sleep时间大于定时器的间隔才会出现每秒钟还是会输出aaa。 而且你开启了Runtime::enableCoroutine(SWOOLE_HOOK_ALL),sleep就变为了一个非阻塞函数,其作用是在3秒后切换协程栈,并执行原本的函数。
赞
0
回复
微信公众号
热门内容
作者其它话题
- 协程TCP客户端connect域名解析问题
- TCP异步客户端和TCP协程客户端的疑问
- heartbeat_idle_time、heartbeat_check_interval但不触发onclose的必现代码
- 设置了heartbeat_idle_time、heartbeat_check_interval但不触发onclose
- 关于TCP协程客户端的疑问
暂无回复的问答
- CodeGalaxy K3s 轻量集群节点之间如何实现负载均衡
- 关于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]
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。