美文网首页
线程 threading

线程 threading

作者: 程猿先生 | 来源:发表于2017-06-12 20:51 被阅读0次

    1. 多线程-threading

    python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用

    1.2使用threading模块

    Paste_Image.png

    说明
    1. 可以明显看出使用了多线程并发的操作,花费时间要短很多
    2. 创建好的线程,需要调用start()方法来启动

    1.3 主线程会等待所有的子线程结束后才结束

    Paste_Image.png
    说明
    • python的threading.Thread类有一个run方法,用于定义线程的功能函数,可以在自己的线程类中覆盖该方法。而创建自己的线程实例后,通过Thread类的start方法,可以启动该线程,交给python虚拟机进行调度,当该线程获得执行的机会时,就会调用run方法执行线程。

    1.4 线程的执行顺序

    Paste_Image.png
    说明

    从代码和执行结果我们可以看出,多线程程序的执行顺序是不确定的。当执行到sleep语句时,线程将被阻塞(Blocked),到sleep结束后,线程进入就绪(Runnable)状态,等待调度。而线程调度将自行选择一个线程执行。上面的代码中只能保证每个线程都运行完整个run函数,但是线程的启动顺序、run函数中每次循环的执行顺序都不能确定。

    总结

    1. 每个线程一定会有一个名字,尽管上面的例子中没有指定线程对象的name,但是python会自动为线程指定一个名字。
    2. 当线程的run()方法结束时该线程完。
    3. 无法控制线程调度程序,但可以通过别的方式来影响线程调度的方式。
    4. 线程的几种状态

    Paste_Image.png

    1.5 多线程-共享全局变量

    Paste_Image.png Paste_Image.png Paste_Image.png
    列表当做实参传递到线程中
    Paste_Image.png Paste_Image.png
    总结:

    • 在一个进程内的所有线程共享全局变量,能够在不适用其他方式的前提下完成多线程之间的数据共享(这点要比多进程要好)
    • 缺点就是,线程是对全局变量随意遂改可能造成多线程之间对全局变量的混乱(即线程非安全)

    相关文章

      网友评论

          本文标题:线程 threading

          本文链接:https://www.haomeiwen.com/subject/ynfrqxtx.html