在做一个实验,树莓派里用python3.5写的程序,主线程开启1个线程,写一个while死循环,执行代码轮询读取各个传感器的状态,并且还判断一些条件如果满足 就执行一些操作,比如到晚上6点 就打开一个小灯这种,循环执行完一次代码 就 time.sleep(1),睡一秒再循环,个人感觉 这样相当于一秒执行一次循环代码,但是我发现有些传感器走通讯这样的多线程好像会占用通道,不知道为什么,然后我单独测试(就是不加读取传感器或者通讯方面的代码,只是测试多线程死循环这种) python 的这种多线程循环有个问题,就是并不是一秒一执行的,比如我放一行代码打印当前系统的时间秒,发现是4秒左右打印一次。这是为什么呢?
或者有什么更好的办法,以前在C#里这种一般用timer控件做。
部分代码:
函数:
def GetTcpData():
while 1:
# 读灯带
读取传感器状态根据条件控制设备动作
time.sleep(1)
主程序:
tGetData = threading.Thread(target=GetTcpData) #建立线程设置函数入口点
tGetData.setDaemon(True) # 设置为后台线程
tGetData.start() #线程开始
或者有什么更好的办法,以前在C#里这种一般用timer控件做。
部分代码:
函数:
def GetTcpData():
while 1:
# 读灯带
读取传感器状态根据条件控制设备动作
time.sleep(1)
主程序:
tGetData = threading.Thread(target=GetTcpData) #建立线程设置函数入口点
tGetData.setDaemon(True) # 设置为后台线程
tGetData.start() #线程开始