这个方案其实在提出问题的第二天就解决了,由于忘记了,所以就没有做记录。
需求:使用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=里边对应的函数,一定不要忘记去掉括号,加上括号是有问题的。