进程、线程及python的多线程编程

  • 阿里云国际版折扣https://www.yundadi.com

  • 阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

    目录

    一.进程、线程和并行执行

    1.什么是进程、线程

    注意

     2.什么是并行执行

    二.python的多线程编程

    threading模块

    语法

     多线程编程的传参

    演示

    三.总结


     

    一.进程、线程和并行执行

    1.什么是进程、线程

    现代操作系统比如Mac OS X,UNIX, Linux, Windows等都是支持“多任务”的操作系统。
    进程:就是一个程序运行在系统之上那么便称之这个程序为一个运行进程并分配进程ID方便系统管理。线程:线程是归属于进程的,一个进程可以开启多个线程,执行不同的工作是进程的实际工作最小单位。

    进程就好比一家公司,是操作系统对程序进行运行管理的单位
    线程就好比公司的员工进程可以有多个线程员工)是进程实际的工作者
    操作系统中可以运行多个进程,即多任务运行
    一个进程内可以运行多个线程即多线程运行

    注意

    进程之间是内存隔离的即不同的进程拥有各自的内存空间。这就类似于不同的公司拥有不同的办公场所。
    线程之间是内存共享的,线程是属于进程的,一个进程内的多个线程之间是共享这个进程所拥有的内存空间的。这就好比,公司员工之间是共享公司的办公场所。

     2.什么是并行执行

    并行执行的意思指的是同一时间做不同的工作。
    进程之间就是并行执行的,操作系统可以同时运行好多程序这些程序都是在并行执行。

    除了进程外线程其实也是可以并行执行的。
    也就是比如一个Python程序,其实是完全可以做到:

    • 一个线程在输出:你好
    • 一个线程在输出:Hello

    像这样一个程序在同一时间做两件乃至多件不同的事情我们就称之为:多线程并行执行

    二.python的多线程编程

    threading模块

    绝大多数编程语言,都允许多线程编程Pyhton也不例外。Python的多线程可以通过threading模块来实现。

    语法

    演示

    import time
    
    def dence():
        while True:
            print("我在跳舞")
            time.sleep(1)
    
    def sing():
        while True:
            print("我在唱歌啦啦啦")
            time.sleep(1)
    
    dence()
    sing()

    如上图当直接调用时sing函数一直没有执行因为此时程序是单线程

    import time
    import threading
    def dence():
        while True:
            print("我在跳舞")
            time.sleep(1) 
    
    def sing():
        while True:
            print("我在唱歌啦啦啦")
            time.sleep(1)
    #创建跳舞和唱歌两个线程
    dance_thread=threading.Thread(target=dence)
    sing_thread=threading.Thread(target=sing)
    #让线程干活
    dance_thread.start()
    sing_thread.start()

     结果是

     多线程编程的传参

    需要传参的话可以通过:

    1. args参数通过元组按参数顺序)的方式传参元组内只有一个时最后要有逗号
    2. 或使用kwargs参数用字典的形式传参

    演示

    import time
    import threading
    def dence(msg):
        while True:
            print(msg)
            time.sleep(1)
    
    def sing(a):
        while True:
            print(a)
            time.sleep(1)
    #创建跳舞和唱歌两个线程
    dance_thread=threading.Thread(target=dence,args=("我要跳舞",))
    sing_thread=threading.Thread(target=sing,kwargs={"a":"我要唱歌"})
    #让线程干活
    dance_thread.start()
    sing_thread.start()

    结果是

    三.总结

    1.什么是进程
    程序在操作系统内运行即成为一个运行进程
    2.什么是线程
    进程内部可以有多个线程,程序的运行本质上就是由进程内部的线程在实际工作的。
    3.什么是并行执行

    • 多个进程同时在运行,即不同的程序同时运行,称之为:多任务并行执行
    • 一个进程内的多个线程同时在运行,称之为:多线程并行执行

    4.threading模块的使用
    thread_obj = threading.Thread(target=func)创建线程对象
    thread_obj.start()启动线程执行
    5.如何传参

     注意传参需要

    1. args参数通过元组按参数顺序)的方式传参元组内只有一个时最后要有逗号
    2. 或使用kwargs参数用字典的形式传参

     

     

  • 阿里云国际版折扣https://www.yundadi.com

  • 阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
    标签: python