多线程
- 多线程使用的是thread库,多进程使用的是multiprocessing库,建议不要使用多线程进行爬虫。
- 在Python多线程下,每个线程的执行方式:
- 获取GIL(Global Interpreter Lock(全局解释器锁))
- 执行代码直到sleep或者是Python虚拟机将其挂起
- 释放GIL
注释:
1.GIL的全称是Global Interpreter Lock(全局解释器锁),来源是python设计之初的考虑,为了数据安全所做的决定。
2.每个CPU在同一时间只能执行一个线程(在单核CPU下的多线程其实都只是并发,不是并行,并发和并行从宏观上来讲都是同时处理多路请求的概念。但并发和并行又有区别,并行是指两个或者多个事件在同一时刻发生;而并发是指两个或多个事件在同一时间间隔内发生。)
多线程的使用方法
使用Theading模块创建线程
文档地址:https://docs.python.org/3/library/threading.html
1.直接实例化threading.Thread线程对象,实现多线程
实例
import threading
import time
def print_age(who, age):
"""
需要用多线程调用的函数
:param who:
:param age:
:return:
"""
print("Hello,every one!")
time.sleep(1)
print("%s is %s years old !" % (who, age))
if __name__ == "__main__":
t1 = threading.Thread(target=print_age, args=("jet", 18, )) # 创建线程1
t2 = threading.Thread(target=print_age, args=("jack", 25, )) # 创建线程2
t3 = threading.Thread(target=print_age, args=("jack", 25,)) # 创建线程3
t1.start() # 运行线程1
t2.start() # 运行线程2
t3.start() # 运行线程3
print("over...")
2.通过继承threading.Thread,并重写run()方法,来实现多线程
import threading
import time
class MyThread(threading.Thread):
"""
使用继承的方式实现多线程
"""
def __init__(self, who):
super().__init__() # 必须调用父类的构造方法
self.name = who
def run(self):
print("%s is run..." % self.name)
time.sleep(3)
if __name__ == "__main__":
t1 = MyThread("Jet") # 创建线程1
t2 = MyThread("Jack") # 创建线程2
t1.start() # 运行线程1
t2.start() # 运行线程2
print("over...")