这个方案其实在提出问题的第二天就解决了,由于忘记了,所以就没有做记录。
需求:使用python实现一边输出程序运行时间计时,一边向指定文件中写入数据
解决方案:由于涉及到i/o密集型问题,所以采用多线程实现。源代码如下:
import time
import threading
def count_time():
start_time = int(time.time())
while True:
end_time = int(time.time())
print(end_time - start_time)
time.sleep(1)
def run_data():
file = open('./a.txt','a+',encoding='utf-8')
for i in range(1,1000000000):
if i % 100 == 0:
file.write('n')
else:
file.write(str(i))
def main_function():
t1 = threading.Thread(target=count_time)
t2 = threading.Thread(target=run_data)
t1.start()
t2.start()
t1.join()
t2.join()
if __name__ == '__main__':
main_function()
不足:类似于这样做测试的一些小的解决方案,其实也是需要一个完备的错误捕获机制和安全预处理机制的。在这里没有去写,整体的代码构缺乏这些必要的处理。代码中其实还缺乏一些别的处理,如控制程序暂停。上次向同事取了一下经,经同事介绍,直接控制线程暂停,其实不是一个好的解决方案,一般类似于这样的解决方案,都会添加任务管理的,也就是像我们的主控制程序一样。让任务暂停,然后再启动会更合理一些。
当前见过有同事的暂停/恢复功能,也是使用这样的方式来实现,恢复之后从日志记录中去找已经执行过的操作,然后再接着从那里开始就可以实现继续了。
注意:在使用多线程和多进程的时候需要注意的一个点是,target=里边对应的函数,一定不要忘记去掉括号,加上括号是有问题的。



