python 实现多线程的三种方法总结

作者:淋巴不想动 时间:2022-10-17 07:09:11 

1._thread.start_new_thread(了解)


import threading
import time
import _thread
def job():
   print("这是一个需要执行的任务。。。。。")
   print("当前线程的个数:", threading.active_count() )
   print("当前线程的信息:", threading.current_thread())
   time.sleep(100)
if __name__ == '__main__':
   # 创建多线程时, 需要制定该线程执行的任务
   _thread.start_new_thread(job, ())
   _thread.start_new_thread(job, ())
   job()

2.threading.Thread


import threading
import time
def job():
   print("这是一个需要执行的任务。。。。。")
   print("当前线程的个数:", threading.active_count() )
   time.sleep(1)
   print("当前线程的信息:", threading.current_thread())
if __name__ == '__main__':
   # 创建多线程时, 需要制定该线程执行的任务.name线程名字 target目标函数名
   t1 = threading.Thread(target=job,name='job1')
   t2 = threading.Thread(target=job,name='job2')
   t1.start()
   t2.start()
   print(threading.active_count())
print("程序执行结束.....")

输出:

这是一个需要执行的任务。。。。。

当前线程的个数: 3

这是一个需要执行的任务。。。。。

3

程序执行结束.....

当前线程的个数: 3

当前线程的信息: <Thread(job1, started 140416648140544)>

当前线程的信息: <Thread(job2, started 140416639747840)>

出现的问题: 主线程执行结束, 但是子线程还在运行。

join()方法可以等待所有的子线程执行结束之后, 再执行主线程。


import threading
import time
def job():
   print("这是一个需要执行的任务。。。。。")
   print("当前线程的个数:", threading.active_count() )
   print("当前线程的信息:", threading.current_thread())
time.sleep(1)
if __name__ == '__main__':
   # 创建多线程时, 需要制定该线程执行的任务.name线程名字 target目标函数名
   t1 = threading.Thread(target=job,name='job1')
   t2 = threading.Thread(target=job,name='job2')
   t1.start()
   t2.start()
   print(threading.active_count())
   # 出现的问题: 主线程执行结束, 但是子线程还在运行。
   # 等待所有的子线程执行结束之后, 再执行主线程
   t1.join()
   t2.join()
   print("程序执行结束.....")

python 实现多线程的三种方法总结

之前写过一个简单爬虫的实验,现在希望获取十个ip的城市和国家

-不使用多线程


import time
from urllib.request import urlopen
# 记录时间的装饰器
def timeit(f):
   def wrapper(*args, **kwargs):
       start_time = time.time()
       res = f(*args, **kwargs)
       end_time = time.time()
       print("%s函数运行时间:%.2f" % (f.__name__, end_time - start_time))
       return res
   return wrapper
def get_addr(ip):
   url = "http://ip-api.com/json/%s" % (ip)
   urlObj = urlopen(url)
   # 服务端返回的页面信息, 此处为字符串类型
   pageContent = urlObj.read().decode('utf-8')
   # 2. 处理Json数据
   import json
   # 解码: 将json数据格式解码为python可以识别的对象;
   dict_data = json.loads(pageContent)
   print("""
                       %s
   所在城市: %s
   所在国家: %s

""" % (ip, dict_data['city'], dict_data['country']))
@timeit
def main():
   ips = ['12.13.14.%s' % (i + 1) for i in range(10)]
   for ip in ips:
       get_addr(ip)
if __name__ == '__main__':
   main()

python 实现多线程的三种方法总结

时间需要138.91秒。

-使用多线程


import threading
import time
from urllib.request import urlopen
def timeit(f):
   def wrapper(*args, **kwargs):
       start_time = time.time()
       res = f(*args, **kwargs)
       end_time = time.time()
       print("%s函数运行时间:%.2f" % (f.__name__, end_time - start_time))
       return res
   return wrapper
def get_addr(ip):
   url = "http://ip-api.com/json/%s" % (ip)
   urlObj = urlopen(url)
   # 服务端返回的页面信息, 此处为字符串类型
   pageContent = urlObj.read().decode('utf-8')
   # 2. 处理Json数据
   import json
   # 解码: 将json数据格式解码为python可以识别的对象;
   dict_data = json.loads(pageContent)
   print("""
                       %s
   所在城市: %s
   所在国家: %s

""" % (ip, dict_data['city'], dict_data['country']))
@timeit
def main():
   ips = ['12.13.14.%s' % (i + 1) for i in range(10)]
   threads = []
   for ip in ips:
       # 实例化10个对象,target=目标函数名,args=目标函数参数(元组格式)
       t = threading.Thread(target=get_addr, args=(ip, ))
       threads.append(t)
       t.start()

# 等待所有子线程结束再运行主线程
   [thread.join() for thread in threads]
if __name__ == '__main__':
   main()

python 实现多线程的三种方法总结 python 实现多线程的三种方法总结

3.重写run方法

重写run方法, 实现多线程, 因为start方法执行时, 调用的是run方法;run方法里面编写的内容就是你要执行的任务;


import threading
import time
# 重写一个类,继承于threading.Thread
class MyThread(threading.Thread):
   def __init__(self, jobName):
       super(MyThread, self).__init__()
       self.jobName = jobName
   # 重写run方法, 实现多线程, 因为start方法执行时, 调用的是run方法;
   # run方法里面编写的内容就是你要执行的任务;
   def run(self):
       print("这是一个需要执行的任务%s。。。。。" %(self.jobName))
       print("当前线程的个数:", threading.active_count() )
       time.sleep(1)
       print("当前线程的信息:", threading.current_thread())
if __name__ == '__main__':
   t1 = MyThread("name1")
   t2 = MyThread("name2")
   t1.start()
   t2.start()
   t1.join()
   t2.join()
   print("程序执行结束.....")

重写run方法实现刚才爬虫多线程案例


import threading
import time
from urllib.request import urlopen
def timeit(f):
   def wrapper(*args, **kwargs):
       start_time = time.time()
       res = f(*args, **kwargs)
       end_time = time.time()
       print("%s函数运行时间:%.2f" % (f.__name__, end_time - start_time))
       return res
   return wrapper
class MyThread(threading.Thread):
   def __init__(self, ip):
       super(MyThread, self).__init__()
       self.ip = ip
   def run(self):
       url = "http://ip-api.com/json/%s" % (self.ip)
       urlObj = urlopen(url)
       # 服务端返回的页面信息, 此处为字符串类型
       pageContent = urlObj.read().decode('utf-8')
       # 2. 处理Json数据
       import json
       # 解码: 将json数据格式解码为python可以识别的对象;
       dict_data = json.loads(pageContent)
       print("""
                           %s
       所在城市: %s
       所在国家: %s

""" % (self.ip, dict_data['city'], dict_data['country']))
@timeit
def main():
   ips = ['12.13.14.%s' % (i + 1) for i in range(10)]
   threads = []
   for ip in ips:
       # 实例化自己重写的类
       t = MyThread(ip)
       threads.append(t)
       t.start()
   [thread.join() for thread in threads]
if __name__ == '__main__':
   main()

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

来源:https://blog.csdn.net/weixin_43067754/article/details/86763905

标签:python,多线程
0
投稿

猜你喜欢

  • 浅析Django 接收所有文件,前端展示文件(包括视频,文件,图片)ajax请求

    2023-03-30 14:35:25
  • MySQL组合索引与最左匹配原则详解

    2024-01-24 18:28:16
  • Python 聊聊socket中的listen()参数(数字)到底代表什么

    2022-10-17 00:49:25
  • Python操作MySQL简单实现方法

    2024-01-19 04:45:44
  • python基于pygame实现飞机大作战小游戏

    2021-04-27 07:59:17
  • kali2021.4a使用virtualenv安装angr的详细过程

    2022-10-15 12:39:00
  • Python eval函数原理及用法解析

    2021-04-29 05:17:18
  • SQL+HTML+PHP 一个简单论坛网站的综合开发案例(注册、登录、注销、修改信息、留言等)

    2023-06-14 15:54:17
  • SQL语句的执行原理分析

    2024-01-15 03:17:59
  • Vue+Express实现登录状态权限验证的示例代码

    2024-05-13 09:11:49
  • Python分析微信好友性别比例和省份城市分布比例的方法示例【基于itchat模块】

    2022-01-04 08:14:09
  • python 基于pygame实现俄罗斯方块

    2021-07-22 15:47:23
  • Python数据相关系数矩阵和热力图轻松实现教程

    2022-06-08 05:12:06
  • 教你用一行Python代码实现GUI图形界面

    2021-10-15 01:38:30
  • MySQL函数大全及用法示例分享

    2024-01-28 16:36:07
  • HTML在线编辑器任意设置字号大小

    2007-08-29 19:55:00
  • OpenCV计算平均值cv::mean实例代码

    2023-06-19 10:26:02
  • 用asp编写文档搜索页面

    2008-01-13 07:04:00
  • php安全攻防利用文件上传漏洞与绕过技巧详解

    2023-07-23 12:08:06
  • 使用ASP脚本命令重新启动服务器

    2008-10-10 11:53:00
  • asp之家 网络编程 m.aspxhome.com