• python进程和线程(05)


    python进程和线程(05)

    1 python进程和线程

    1.1 进程和线程概念

    参考视频:黑马保姆级视频

    进程:就是一个程序,运行在系统之上,那么便称之这个程序为一个
    运行进程,并分配进程ID方便系统管理。
    线程:线程是归属于进程的,一个进程可以开启多个线程,执行不同
    的工作,是进程的实际工作最小单位。
    
    进程就好比一家公司,是操作系统对程序进行运行管理的单位
    线程就好比公司的员工,进程可以有多个线程(员工),是进程实际的工作者
    操作系统中可以运行多个进程,即多任务运行
    一个进程内可以运行多个线程,即多线程运行
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    注意点:

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

    在这里插入图片描述

    1.2 并行执行

    并行执行的意思指的是同一时间做不同的工作。
    进程之间就是并行执行的,操作系统可以同时运行好多程序,这些程序都是在并行执行。
    除了进程外,线程其实也是可以并行执行的。
    也就是比如一个Python程序,其实是完全可以做到:
    。一个线程在输出:你好
    。一个线程在输出:Hello
    像这样一个程序在同一时间做两件乃至多件不同的事情,我们就称之为:多线程并行执行

    1.3 核心使用语法_threading模块

    绝大多数编程语言,都允许多线程编程,Pyhton也不例外。
    Python的多线程可以通过threading模块来实现。
    
    import threading
    
    thread_obj=threading.Thread([group [, target [, name [, args [, kwargs]]]]])
    
        group: 暂时无用,未来功能的预留参数
        target: 执行的目标任务名
        args: 以元组的方式给执行任务传参
        kwargs: 以字典方式给执行任务传参
        name: 线程名,一般不用设置
    
    #启动线程,让线程开始工作
    thread_obj.start()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    1.4 多线程编程

    在这里插入图片描述

    1.4.1 案例单线程不能满足情况如下:
    import time
    
    def sing():
        while True:
            print("我在唱歌,啦啦啦...")
            time.sleep(1)
    
    def dance():
        while True:
            print("我在跳舞,呱呱呱....")
            time.sleep(1)
    
    if __name__ == '__main__':
        sing()
        dance()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    打印:

    在这里插入图片描述

    1.4.2 多线程
    1.4.2.1 多线程创建语句
    import  threading
    
    sing_thread = threading.Thread( target=sing )  
    dance_thread= threading.Thread( target=dance )  
    
    sing_thread.start()  #启动线程1
    dance_thread.start() #启动线程2
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    1.4.2.2 案例
    import time
    import  threading
    
    def sing():
        while True:
            print("我在唱歌,啦啦啦...")
            time.sleep(1)
    
    def dance():
        while True:
            print("我在跳舞,呱呱呱....")
            time.sleep(1)
    
    if __name__ == '__main__':
    	# 创建线程1,需要指定目标target,注意方法名不带括号
        sing_thread = threading.Thread( target=sing )  
         # 创建线程2,需要指定目标target,注意方法名不带括号
        dance_thread= threading.Thread( target=dance )  
    
        sing_thread.start()  #启动线程1
        dance_thread.start() #启动线程2
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    1.4.2 多线程传参使用
    1.4.2.1 多线程传参使用 args 和 kwargs
    thread_obj=threading.Thread([group [, target [, name [, args [, kwargs]]]]])
    
    args: 以元组的方式给执行任务传参,注意参数是元组,如:args=("元素1",) ;元组点号,结束
    kwargs: 以字典方式给执行任务传参,注意参数是字典类型,如: kwargs={"msg":"我在跳舞"} 
    
    • 1
    • 2
    • 3
    • 4
    1.4.2.2 使用案例
    import time
    import  threading
    
    def sing(msg):
        while True:
            print(msg)
            time.sleep(1)
    
    def dance(msg):
        while True:
            print(msg)
            time.sleep(1)
    
    if __name__ == '__main__':
    
        # 创建线程1,传参,注意:(args是元组类型,结尾有,)
        sing_thread = threading.Thread( target=sing, args=("我在唱歌",) )
        # 创建线程2,传参,注意:(kwargs是字典类型)
        dance_thread= threading.Thread( target=dance, kwargs={"msg":"我在跳舞"} )
    
        sing_thread.start()  #启动线程1 
        dance_thread.start() #启动线程2
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
  • 相关阅读:
    什么是【固件】?
    Layui快速入门之第十一节 弹出层
    30天精通Nodejs--第二天:模块系统与npm
    八一书《乡村振兴战略下传统村落文化旅游设计》许少辉瑞博士生辉少许——2023学生开学季许多少年辉光三农
    Haproxy搭建Web群集
    Word控件Spire.Doc 【文本】教程(9) ;如何在C#中获取word文档中文本的高度和宽度
    Redis 过期删除策略和内存淘汰策略
    基于django的网络隐私检测系统
    Java —— 程序逻辑控制
    python 压缩与解压文件
  • 原文地址:https://blog.csdn.net/weixin_42786460/article/details/133092003