sys.waitUntil与sys.waitUntilExt的区别

基础用法都是相似的,用于协程的阻塞等待:

sys.taskInit(function()
    while true do
        sys.waitUntil("MSG")
    end
end)

不同点在于函数返回值不同:
sys.waitUntil 返回 true(收到消息)/false(超时)和Data(如果有);
sys.waitUntilExt返回 MSG(消息的str)/ false(超时)和Data(如果有);

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
--发布消息
sys.taskInit(function()
while true do
sys.wait(2000)
sys.publish("MSG_TEST", "test_payload")
log.info("msg_test", "send")
end
end)

--订阅消息
--sys.subscribe("MSG", function(callback) log.info("msg",callback ) end)

--测试waitUntil
sys.taskInit(function()
while true do
local result, data = sys.waitUntil("MSG_TEST")
log.info("msg.waitUntil", result, data)
end
end)
--测试waitUntil timeout
sys.taskInit(function()
while true do
local result, data = sys.waitUntil("MSG_TEST", 1500)
log.info("msg.waitUntil.timeout", result, data)
end
end)


--测试waitUntilExt
sys.taskInit(function()
while true do
local msg, data = sys.waitUntilExt("MSG_TEST")
log.info("msg.waitUntilExt", msg, data)
end
end)
--测试waitUntilExt timeout
sys.taskInit(function()
while true do
local msg, data = sys.waitUntilExt("MSG_TEST", 1500)
log.info("msg.waitUntilExt.timeout", msg, data)
end
end)

输出结果如下:

1
2
3
4
5
[2020-03-13 09:38:54.648]: [I]-[msg_test] send
[2020-03-13 09:38:55.155]: [I]-[msg.waitUntil.timeout] false nil
[2020-03-13 09:38:55.157]: [I]-[msg.waitUntilExt.timeout] false nil
[2020-03-13 09:38:56.656]: [I]-[msg.waitUntilExt] MSG_TEST test_payload
[2020-03-13 09:38:56.658]: [I]-[msg.waitUntil] true test_payload

上次更新 2021-01-28