python进程和线程(05)
文章目录
- python进程和线程(05)
- 1 python进程和线程
- 1.1 进程和线程概念
- 1.2 并行执行
- 1.3 核心使用语法_threading模块
- 1.4 多线程编程
- 1.4.1 案例单线程不能满足情况如下:
- 1.4.2 多线程
- 1.4.2.1 多线程创建语句
- 1.4.2.2 案例
- 1.4.2 多线程传参使用
- 1.4.2.1 多线程传参使用 args 和 kwargs
- 1.4.2.2 使用案例
1 python进程和线程
1.1 进程和线程概念
参考视频:黑马保姆级视频
进程:就是一个程序,运行在系统之上,那么便称之这个程序为一个
运行进程,并分配进程ID方便系统管理。
线程:线程是归属于进程的,一个进程可以开启多个线程,执行不同
的工作,是进程的实际工作最小单位。进程就好比一家公司,是操作系统对程序进行运行管理的单位
线程就好比公司的员工,进程可以有多个线程(员工),是进程实际的工作者
操作系统中可以运行多个进程,即多任务运行
一个进程内可以运行多个线程,即多线程运行
注意点:
进程之间是内存隔离的,即不同的进程拥有各自的内存空间。这就类似于不同的公司拥有不同的办公场所。
线程之间是内存共享的,线程是属于进程的,一个进程内的多个线程之间是共享这个进程所拥有的内存空间的。
这就好比,公司员工之间是共享公司的办公场所。
1.2 并行执行
并行执行的意思指的是同一时间做不同的工作。
进程之间就是并行执行的,操作系统可以同时运行好多程序,这些程序都是在并行执行。
除了进程外,线程其实也是可以并行执行的。
也就是比如一个Python程序,其实是完全可以做到:
。一个线程在输出:你好
。一个线程在输出:Hello
像这样一个程序在同一时间做两件乃至多件不同的事情,我们就称之为:多线程并行执行
1.3 核心使用语法_threading模块
绝大多数编程语言,都允许多线程编程,Pyhton也不例外。
Python的多线程可以通过threading模块来实现。import threadingthread_obj=threading.Thread([group [, target [, name [, args [, kwargs]]]]])group: 暂时无用,未来功能的预留参数target: 执行的目标任务名args: 以元组的方式给执行任务传参kwargs: 以字典方式给执行任务传参name: 线程名,一般不用设置#启动线程,让线程开始工作
thread_obj.start()
1.4 多线程编程
1.4.1 案例单线程不能满足情况如下:
import timedef sing():while True:print("我在唱歌,啦啦啦...")time.sleep(1)def dance():while True:print("我在跳舞,呱呱呱....")time.sleep(1)if __name__ == '__main__':sing()dance()
打印:
1.4.2 多线程
1.4.2.1 多线程创建语句
import threadingsing_thread = threading.Thread( target=sing )
dance_thread= threading.Thread( target=dance ) sing_thread.start() #启动线程1
dance_thread.start() #启动线程2
1.4.2.2 案例
import time
import threadingdef 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() #启动线程1dance_thread.start() #启动线程2
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.4.2.2 使用案例
import time
import threadingdef 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