• Python连载30-多线程之进程&线程&线程使用举例


    一、多线程

    1.我们的环境

    (1)xubuntu 16.04(2)anaconda(3)pycharm(4)python 3.6

    2.程序:一堆代码以文本的形式存入一个文档

    3.进程:程序运行的一个状态。

    特点:(1)其中包含地址控件、内存、数据栈等;(2)每个进程由自己完全独立的运行环境,多进程共享数据是一个问题。

    4.线程:一个进程的独立运行片段

    特点:(1)一个进程可以有多个线程;(2)轻量化的进程;(3)一个进程的多个线程间共享数据和上下文运行环境;(4)共享互斥问题

    5.全局解释器锁(GIL)

    (1)Python代码的执行是由python虚拟机进行控制

    (2)在主循环中只能有一个控制线程在执行

    6.python包

    (1)thread:有问题,不好用,python3改为_thread

    (2)threading:通行的包

    7.例子:

    import threading,time
    
    import _thread as thread
    
    #利用time生成两个函数
    
    def loop1():
    
        print("Start loop 1 at:",time.ctime())
    
        time.sleep(4)
    
        print("End loop 1 at :",time.ctime())
    
    def loop2():
    
        print("Start loop 2 at :",time.ctime())
    
        time.sleep(2)
    
        print("End loop 2 at :",time.ctime())
    
    def main():
    
        print("Start at :",time.ctime())
    
        thread.start_new_thread(loop1,())#这里里面的第二个位置是用来传递参数的,因为咱们的函数刚好没有参数,因此咱们传递了一个空参数
    
        thread.start_new_thread(loop2,())
    
        print("End at :",time.ctime())
    
    if __name__ == "__main__":
    
        main()

    解释:如上图的运行结果:按照顺序输出开始时间,然后应该是线程1,线程2,最后是结束时间,从运行结果来看,现在只有开始时间以及结束时间,中间那两个线程都没了,这是因为,我们让这两个线程开始执行的时候我们的主线程已经之行结束了,导致中间两个线程都没有执行完,主线程终止了,所有中间的两个线程也结束了。优秀!!

    二、源码

    d24_1_multithread.py

    地址:https://github.com/ruigege66/Python_learning/blob/master/d24_1_multithread.py

    2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

    3.博客园:https://www.cnblogs.com/ruigege0000/

    4.欢迎关注微信公众号:傅里叶变换

     

  • 相关阅读:
    centos下两种方法安装git
    Field.setAccessible()方法
    Tomcat日志格式自定义
    Java监控工具
    JDK目录结构和文件作用介绍
    Java中堆和栈的区别
    Magicodes.WeiChat——使用AntiXssAttribute阻止XSS(跨站脚本攻击)攻击
    Magicodes.WeiChat——缓存管理
    Magicodes.WeiChat——WeChatOAuthTest(网页授权获取用户基本信息)
    Magicodes.WeiChat——后台JS框架封装
  • 原文地址:https://www.cnblogs.com/ruigege0000/p/11343453.html
Copyright © 2020-2023  润新知