首页 > 编程语言 > 详细

Python3 多线程的使用

时间:2019-03-14 13:31:37      阅读:150      评论:0      收藏:0      [点我收藏+]

多线程

  • 多线程使用的是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...")

Python3 多线程的使用

原文:https://www.cnblogs.com/spmt/p/10529032.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!