我只是花了一个小时在我重写了一堆代码之后,仔细搜索代码,找出它为什么会死机。我没想到while循环这么慢。我想我从来没有在时间非常紧迫的地方使用过它们。在
最后,我将问题缩小到这个方法,经过测试,我发现while循环中的两行运行得非常快。大约30/100000到1/10000秒,但是当我把datetime调用直接放在while循环之外时,它会减慢到1秒左右。在def query(self, command):
result = ''
result_list = []
self.obd.write(command + "\r\n")
while result != '>':
result = self.obd.readline()
result_list.append(result)
self.result = result_list[-2].strip()
为什么while循环的速度如此之慢,我该如何加快速度呢?在
为了解释我在做什么,我从一个设备上得到串行输入,这个设备在输出多少行方面似乎有自己的想法。有时我需要的信息在第二行,有时在第三行,有时在第一行。我只知道“>;”符号前的最后一行,以及我尝试过的其他方法,都会给我留下未读的缓冲数据,这会使我以后陷入混乱,所以我不得不等待“>;”。在
编辑:显然我没有很好地解释我所做的。在
我从上面的代码开始,编辑它以检查它的运行速度。在
^{pr2}$
每次运行此方法时,平均运行时间不到1/10000秒。在def query(self, command):
result = ''
result_list = []
self.obd.write(command + "\r\n")
a = datetime.datetime.now()
while result != '>':
result = self.obd.readline()
result_list.append(result)
b = datetime.datetime.now()
print b - a
self.result = result_list[-2].strip()
这意味着每次运行这个方法1秒以上。在
while循环中发生的是从中读取串行端口。如果我围绕它做一个for循环,它会工作一段时间,然后在缓冲区稍微落后时停止,但我可以查询端口,最高可达60赫兹。在
如果不是while循环,为什么会得到我看到的结果?在