前言丨
1.python环境2.7
2.threading模块系统自带
讲多线程前,先要了解什么是进程,什么是线程,已经知道的请略过。
进程与线程
进程是资源分配的最小单位,一个程序至少有一个进程。
线程是程序执行的最小单位,一个进程至少有一个线程。
进程都有自己独立的地址空间,内存,数据栈等,所以进程占用资源多。由于进程的资源独立,所以通讯不方便,只能使用进程间通讯(IPC)。
线程共享进程中的数据,他们使用相同的地址空间,使用线程创建快捷,创建开销比进程小。同一进程下的线程共享全局变量、静态变量等数据,所以线程通讯非常方便,但会存在数据同步与互斥的问题,如何处理好同步与互斥是编写多线程程序的难点。
一个进程中可以存在多个线程,在单核CPU中每个进程中同时刻只能运行一个线程,只有在多核CPU中才能存在线程并发的情况。
当线程需要运行但没有运行空间时,会对线程的优先级进行判断,高优先级先运行,低优先级进程让行。
单线程
平常写的代码都是按顺序挨个执行的,就好比吃泡面和唱小曲这两个行为事件,定义成两个函数,执行的时候,是先吃泡面再唱小曲,这种就是单线程的行为。
![7794112b2ecd5d99b67f764fc84fc5de.png](https://img-blog.csdnimg.cn/img_convert/7794112b2ecd5d99b67f764fc84fc5de.png)
mon nov 30 16:32:37 2020 吃泡面开始:
mon nov 30 16:32:38 2020 吃泡面结束--
mon nov 30 16:32:38 2020 唱着小曲开始:
mon nov 30 16:32:39 2020 唱着小曲结束--
生活中我们是可以一边吃泡面一边唱小曲的,那么代码里面如何实现这种同时进行的不同事件呢?
这就是接下来要讲的python多线程
多线程threading
1.Python通过两个标准库thread和threading提供对线程的支持。thread提供了低级别的、原始的线程以及一个简单的锁;Threading模块封装了一些常用的方法,初学者直接学这个模块就行了。
2.Python中使用线程有两种方式:函数或者用类来包装线程对象
3.threading.Thread里面几个参数介绍:
![adc7519f6dd535d1ff669981e31afaa3.png](https://img-blog.csdnimg.cn/img_convert/adc7519f6dd535d1ff669981e31afaa3.png)
函数式
1.先看个简单案例,这种是执行函数,函数不带参数的
![54f487e08e9d824cec399c6c431c9543.png](https://img-blog.csdnimg.cn/img_convert/54f487e08e9d824cec399c6c431c9543.png)
运行结果:
mon nov 30 16:35:50 2020 吃着火锅开始:
mon nov 30 16:35:50 2020哼着小曲1!
mon nov 30 16:35:51 2020 吃着火锅:涮羊肉
mon nov 30 16:35:52 2020 哼着小曲2!mon nov 30 16:35:52 2020 吃着火锅:涮牛肉
mon nov 30 16:35:53 2020 吃着火锅:土豆
mon nov 30 16:35:54 2020 哼着小曲3!mon nov 30 16:35:54 2020 吃火锅结束!
mon nov 30 16:35:56 2020 哼着小曲4!
mon nov 30 16:35:58 2020 哼着小曲5!
2.带参数的用args传元组类型(参数最后多加一个逗号“,”要不然会报错)
![59d007e96328cfe75b4a03bba6718918.png](https://img-blog.csdnimg.cn/img_convert/59d007e96328cfe75b4a03bba6718918.png)
3.或者用kwargs传字典{}类型
![1deac13d48ed1a3efaa9899d5bd30959.png](https://img-blog.csdnimg.cn/img_convert/1deac13d48ed1a3efaa9899d5bd30959.png)
以上是python笔记4全部内容,封装类和方法的调下篇会给大家介绍,如果觉得对你有帮助,就点击“收藏”吧!
如果还有疑问的地方,欢迎评论留言给我们~