我正在使用ESP8266 wifi模块使用NodeMCU在LUA中对其进行编程。我能够从iPhone应用程序连接到由wifi模块创建的TCP服务器,以发送3个浮动。我将大字符串解析为3个字符串并使用uart和Arduino发送它们。它工作得很好,但在大约10个输入后它崩溃/冻结。我需要不断的数据流来保持一致但我始终无法可靠地做到这一点。 我在每一行之后打印出来,以便跟踪实际发生的情况,甚至在此之后我还不确定发生了什么。
代码 `
print("11\n")
wifi.setmode(wifi.STATION)
print("22\n")
wifi.sta.config("WDTS03","Walker14!")
print("33\n")
elWiFi =(wifi.sta.getip())
if elWiFi ~= nil then
print(wifi.sta.getip())
end
print("44\n")
if srv~=nil then
print("444\n")
srv:close()
print("555 \n")
end
print("Create server \n")
srv=net.createServer(net.TCP)
print("1\n")
if srv ~= nil then
print("srv !=nil \n")
srv:listen(6969,function(conn)
print("listening \n")
if conn ~= nil then
print("incoming\n")
conn:on("receive",function(conn,numbers)
print("2\n")
print(#numbers)
print("chekcing for nil \n")
if numbers ~= nil then
print("3\n")
p = string.find(numbers, "x=")
print("4\n")
q = string.find(numbers, "&y")
print("5\n")
if p ~= nill then
print("6\n")
if q ~= nil then
print("7\n")
x = (string.sub(numbers,p+2, q-1))
print("x=" .. x)
end
end --p ~= nill
print("8\n")
p = string.find(numbers, "y=")
print("9\n")
q = string.find(numbers, "&z")
print("10\n")
if p ~= nill then
print("11\n")
if q ~= nil then
print("12\n")
y = (string.sub(numbers,p+2, q-1))
print("y=" .. y)
end
end --p ~= nill
print("13\n")
p = string.find(numbers, "z=")
print("14\n")
q = string.find(numbers, " H")
print("15\n")
if p ~= nill then
print("16\n")
if q ~= nil then
print("17\n")
z = (string.sub(numbers,p+2, q-1))
print("z=" .. z)
end
end-- p ~= nill
print("18\n")
end --numbers ~= nil
print("54\n")
--conn:send("test\n")
end)
print("55 \n")
end
print("66 \n")
end)
print("77\n")
end
print("666\n")`
我得到以下输出
11
22
33
44
Create server
1
srv !=nil
77
666
> listening
incoming
55
66
listening
incoming
55
66
listening
incoming
55
66
listening
incoming
55
66
2
338
chekcing for nil
3
4
5
6
7
x=0.1722259521484375
8
9
10
11
12
y=-0.7733306884765625
13
14
15
16
17
z=-0.5716094970703125
18
54
2
337
chekcing for nil
3
4
5
6
7
.
.--repeats a few times
.
y=-0.005340576171875
13
14
15
16
17
z=-0.9838409423828125
18
54
PANIC: unprotected error in call to Lua API (attempt to call a nil value)
�l� �=+���T2n���
NodeMCU 0.9.6 build 20150704 powered by Lua 5.1.4
11
22`
它失败了" conn:on" " srv:listen"几次之后
感谢您的帮助,对不起,如果格式混乱了。第一次
答案 0 :(得分:1)
评论太长了,抱歉。
PANIC:调用Lua API时出现无保护错误(尝试调用nil值)
很难分辨哪个值为零/ null。创建FHS以减少需要分析的代码量。
以下代码段最终会因关闭的上升值而导致内存不足。每个回调函数都应使用自己传递的套接字实例的副本,而不是引用包装回调函数。第三行不应重用conn
变量,而应使用新名称定义一个变量。
有关详细信息,请参阅Minimal, Complete, and Verifiable Example (MCVE)。
srv:listen(6969,function(conn)
if conn ~= nil then
conn:on("receive",function(conn,numbers)
NodeMCU 0.9.6 build 20150704
不要使用那些旧的0.9.x二进制文件,它们已经过时并且包含许多错误。 https://stackoverflow.com/a/37379426/131929可帮助您开始使用新固件。