python多线程返回值的实现与处理

题目:

# 编写一个python程序,创建两个子线程,分别到下面的网址获取文本内容
# http://mirrors.163.com/centos/6/isos/x86_64/README.txt
# http://mirrors.163.com/centos/7/isos/x86_64/0_README.txt
# 主线程等待这个两个子线程获取到信息后,将其内容依次合并后存入名为 readme89.TXT 的文件中

答案1:通过返回值实现

1、创建线程类,重构线程基类初始化函数

from threading import Thread

# 创建一个线程类
class MyThread(Thread):
# 重定义初始化
def __init__(self,func,args=()):
super(MyThread, self).__init__()
self.func = func
self.args = args

# 运行函数(线程)
def run(self):
self.rusult = self.func(*self.args)

# 获得返回值
def get_result(self):
Thread.join(self) # 等待线程执行完毕
try:
return self.rusult
except Exception:
return None

2、创建子线程实现调用返回值的操作

import requests,traceback
from pythondevelop.case_1109ReturnValue import MyThread

# 创建两个子线程用于获取网页内容
def thread1():
r = requests.get('http://mirrors.163.com/centos/6/isos/x86_64/README.txt')

return r

def thread2():
r = requests.get('http://mirrors.163.com/centos/6/isos/x86_64/0_README.txt')

return r

# 主程序等待子线程获取后合并内容到readme89.TXT
try:
th1= MyThread(thread1)
th2= MyThread(thread2)
th1.start()
th2.start()
th1result = th1.get_result()
th2result = th2.get_result()
if th1result != None and th2result != None and th1result.status_code == 200 and th2result.status_code == 200:
with open('readme89.txt','w+') as f:
f.write(th1result.text)
f.write('---------------------------------------this is line!!-------------------------------------')
f.write(th2result.text)
f.close()
except:
print(traceback.format_exc())

答案2:通过将返回值放在预先定义的列表中,及对线程锁的应用
# coding=utf8
import requests,threading

urls = [
'http://mirrors.163.com/centos/6/isos/x86_64/README.txt',
'http://mirrors.163.com/centos/6/isos/x86_64/0_README.txt']

# 对应urls 依次存储网页文件内容, 先创建同样个数的元素占位
fileContentList = [None for one in urls]

# 锁对象,用来控制访问 fileContentList
lock = threading.Lock()

def thread_entry(idx,url):
print('thread #%s start' % idx)
r = requests.get(url)

# 注意上面的代码不应该放在获取锁的代码中
lock.acquire()
# 注意 r.text的类型是unicode,可以在文档中查到
fileContentList[idx] = r.text
lock.release()

print('thread #%s end' % idx)

if __name__ == '__main__':
print('main thread start.')

threadpool = []

for idx,url in enumerate(urls): # enumerate()用于遍历数据对象(如列表)组合为一个索引序列,同时列出下标和数据
t = threading.Thread(target=thread_entry,args=(idx,url))
t.start()

threadpool.append(t)

# 等所有 线程结束
for t in threadpool:
t.join()

# 所有线程结束后,所有内容都获取到了,合并内容

mergeTxt = '\n\n----------------------\n\n'.join(fileContentList)
print(mergeTxt)

with open('readme89.txt','w',encoding='utf8') as f:
f.write(mergeTxt)

print('main thread end.')

转载于:https://www.cnblogs.com/blogofzxf/p/10512951.html

Python 中,多线程并不能直接返回值。因为线程是并行执行的,所以它们之间无法直接共享变量或返回值。如果你需要获取线程执行的结果,可以使用以下方法之一: 1. 使用共享变量:你可以在主线程中创建一个共享变量,在子线程中对其进行修改,并在主线程中等待子线程完成后获取该变量的值。这可以通过 `threading` 模块的 `Thread` 类和共享变量(如 `Queue`)实现。 下面是一个示例代码: ```python import threading def worker(result): # 在子线程中修改共享变量 result.append("Hello from worker") # 创建共享变量 result = [] # 创建线程对象 thread = threading.Thread(target=worker, args=(result,)) # 启动线程 thread.start() # 等待线程结束 thread.join() # 输出共享变量的值 print(result) ``` 2. 使用回调函数:你可以定义一个回调函数,将其作为参数传递给子线程,并在子线程中调用该回调函数来传递结果。这需要通过自定义的方式来实现。 下面是一个示例代码: ```python import threading def worker(callback): result = "Hello from worker" callback(result) def on_result(result): print(result) # 创建线程对象,传递回调函数 thread = threading.Thread(target=worker, args=(on_result,)) # 启动线程 thread.start() # 等待线程结束 thread.join() ``` 请注意,在多线程编程中,对共享变量的访问需要进行适当的同步,以防止竞争条件和数据不一致的情况发生。可以使用锁(`Lock`)或其他同步机制来确保线程安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值