一,问题发现:
使用多线程处理文档时,发现将数据打印在控制台时,任务是并行的,同时执行的
但是将相同的文字写到txt文本时,文本的内容是单线程执行的
1. 下面是代码
#codint=utf-8
from multiprocessing import Process
import time
def run(Str,Num):
m = 1
with open("test.txt","a",encoding="utf-8") as FileObj:
while True:
FileObj.write("run(%s)方法正在运行,第 %d 次运行,n的值是 %d\n"%(Str,m,Num))
print("run(%s)方法正在运行,第 %d 次运行,n的值是 %d\n"%(Str,m,Num))
m += 1
time.sleep(1)
if m >= 10:
break
if __name__ == '__main__':
with open("test.txt", "a",encoding="utf-8") as FileObj:
FileObj.write("主进程启动。。。\n")
print("主进程启动。。。\n")
# 创建子进程
# target说明进程执行的任务
n = 1
PObj = Process(target=run,args=("nice",n))
# 启动进程
PObj.start()
while True:
FileObj.write("main()方法正在运行,第 %d 次运行\n"%n)
print("main()方法正在运行,第 %d 次运行\n"%n)
n += 1
time.sleep(1)
if n >= 10:
break
2. 控制台打印截图
3. txt文本截图
二,问题原因
- 出现此问题是因为,打印语句执行完毕后,打印的数据直接输出
- 写文件的语句执行完毕后,数据保存在计算机的内存中,等到任务执行完毕,再将内存中的数据统一保存到文件中,将文件关闭,数据才会保存成功。
- 因此会出现文本中保存的数据不是并行的
三,解决方法
- 每个方法中的写文件的语句执行完后,立即执行一次保存操作,这样调用哪个方法,都会将数据即时保存
四,解决效果
- 按照以上方法解决之后,文件中的数据也是并行的了