多线程

1. 线程

​ 开启一个进程,操作系统会开辟一个进程空间,将进程的数据资源全部复制一份,然后cpu使线程执行代码。

进程负责开辟空间、加载数据资源,线程负责执行。

2. 线程vs进程

	1. 开启进程的开销大;
  1. 开启进程的速度满,线程比进程快10—100倍;

    3. 同一进程的线程之间可共享数据,进程与进程之间使隔离的。

线程的应用:多线程并发。比多进程并发开销小、速度快,可共享数据。

3. 开启线程的两种方法。

# 第一种方式
from threading import Thread def task():
print("===子线程") if __name__ == '__main__': # 在windows下也可不写
t1 = Thread(target=task)
t1.start()
print('===主线程')
"""
===子线程
===主线程
"""
# 第二种方式
from threading import Thread class MyThread(Thread): def __init__(self, name)
super().__init()
self.name=name def run(self):
print("==={self.name}子线程") if __name__ == '__main__':
t1 = MyThread("meet")
t1.start()
print('===主线程')
"""
===meet子线程
===主线程
"""

4. 线程的特性

  1. 同一进程中,每个线程的pid相同,因为它们在同一进程内。
  2. 主线程需等待其他子线程结束后,才能结束。(因为主线程结束代表本进程结束,而子线程需依赖进程存活。)
  3. 同一进程内的数据资源对于本进程的多个进程来说是共享的。

5. 线程的相关方法

Thread实例对象方法:
t.is_alive()(t.isAlive()) #判断线程是否活着
t.getName() # 获取线程名
print(t.name) # 获取线程名
t.setName() # 设置线程名 threading模块方法:
currentThread() # 获取当前线程的对象
enumerate() # 获取进程中所有线程对象,返回列表
activeCount() # 获取活跃的线程数量
from threading import Thread,currentThread,enumerate,activeCount
import time def task():
time.sleep(1)
print("is task") if __name__ == '__main__':
t1 = Thread(target=task,name='===子线程')
t1.start()
print(t1.name) # ===子线程
print(t1.is_alive()) # True
t1.setName('子线程')
print(t1.getName()) # 子线程 print(currentThread()) #主线程对象
print(enumerate()) # 列表中两个线程对象
print(activeCount()) # 2
print('===主线程')
"""
True
子线程
<_MainThread(MainThread, started 14876)>
[<_MainThread(MainThread, started 14876)>, <Thread(子线程, started 8736)>]
2
===主线程
is task
"""

6. join 阻塞

​ 告知主线程需等待子线程执行结束后,再开始执行。

from threading import Thread
import time
def sayhi(name):
time.sleep(2)
print('%s say hello' %name) if __name__ == '__main__':
t=Thread(target=sayhi,args=('meet',))
t.start()
t.join()
print(t.is_alive())
print('主线程')
'''
meet say hello
False
主线程
'''

7. 守护线程 daemon

若主线程运行结束,守护线程也会跟着结束。

对主线程来说,运行完毕指的是本进程内所有非守护线程统统运行完毕,主线程才算运行完毕(若守护线程的生命周期小于其他的线程,会先结束)。

from threading import Thread
import time def foo():
print(123)
time.sleep(3)
print("end123") def bar():
print(456)
time.sleep(1)
print("end456") if __name__ == '__main__':
t1=Thread(target=foo)
t2=Thread(target=bar)
t1.daemon=True # 设置t1为守护进程
t1.start()
t2.start()
print("main---")
"""
123
456
main---
end456
"""
# 面试题---迷惑人的例子
from threading import Thread
import time def foo():
print(123) # 1
time.sleep(1)
print("end123") # 4 def bar():
print(456) # 2
time.sleep(2)
print("end456") # 5 if __name__ == '__main__': t1=Thread(target=foo)
t2=Thread(target=bar)
t1.daemon=True # 设置t1为守护进程
t1.start()
t2.start()
print("main-------") # 3 """
123
456
main---
end123
end456
"""
# 因为bar需2s执行完毕,2s足够守护进程的foo执行完毕。因此在主线程结束前,守护线程以及结束。

8. 互斥锁

​ 多线程的同步锁与多进程的同步锁是一个道理,就是多个线程抢占同一个数据(资源)时,我们要保证数据的安全,合理的顺序,因此需串行。

from threading import Thread
from threading import Lock
import time
import random x = 100 def task(lock):
global x
lock.acquire()
num = x
time.sleep(random.random())
x = num-1
lock.release() if __name__ == '__main__':
mutex = Lock()
for i in range(100):
t = Thread(target=task, args=(mutex,))
t.start()
time.sleep(2)
print(f'主线程{x}') # 输出不固定 串行执行

python 35 多线程的更多相关文章

  1. Python的多线程(threading)与多进程(multiprocessing )

    进程:程序的一次执行(程序载入内存,系统分配资源运行).每个进程有自己的内存空间,数据栈等,进程之间可以进行通讯,但是不能共享信息. 线程:所有的线程运行在同一个进程中,共享相同的运行环境.每个独立的 ...

  2. Python GIL 多线程机制 (C source code)

    最近阅读<Python源码剖析>对进程线程的封装解释: GIL,Global Interpreter Lock,对于python的多线程机制非常重要,其如何实现的?代码中实现如下: 指向一 ...

  3. Python实现多线程HTTP下载器

    本文将介绍使用Python编写多线程HTTP下载器,并生成.exe可执行文件. 环境:windows/Linux + Python2.7.x 单线程 在介绍多线程之前首先介绍单线程.编写单线程的思路为 ...

  4. Python实现多线程调用GDAL执行正射校正

    python实现多线程参考http://www.runoob.com/python/python-multithreading.html #!/usr/bin/env python # coding: ...

  5. Python之多线程和多进程

    一.多线程 1.顺序执行单个线程,注意要顺序执行的话,需要用join. #coding=utf-8 from threading import Thread import time def my_co ...

  6. python的多线程到底有没有用?

    在群里经常听到这样的争执,有人是虚心请教问题,有人就大放厥词因为这个说python辣鸡.而争论的核心无非就是,python的多线程在同一时刻只会有一条线程跑在CPU里面,其他线程都在睡觉.这是真的吗? ...

  7. 通过编写聊天程序来熟悉python中多线程及socket的用法

    1.引言 Python中提供了丰富的开源库,方便开发者快速就搭建好自己所需要的应用程序.本文通过编写基于tcp/ip协议的通信程序来熟悉python中socket以及多线程的使用. 2.python中 ...

  8. Python的多线程和多进程

    (1)多线程的产生并不是因为发明了多核CPU甚至现在有多个CPU+多核的硬件,也不是因为多线程CPU运行效率比单线程高.单从CPU的运行效率上考虑,单任务进程及单线程效率是最高的,因为CPU没有任何进 ...

  9. Python【多线程与多进程】

    import time,threading print("=======串行方式.并行两种方式调用run()函数=======")def run(): print('哈哈哈') # ...

随机推荐

  1. Python基础总结之第三天开始重新认识‘字符串’(新手可相互督促)

    年薪20万的梦想,又进了一步... 戏好多 ’字符串‘开始啦~ 字符串的定义:字符串可以用英文单引号或双引号又或者三引号包围起来. 为毛有单引号,还要有双引号和三引号??? 看案例吧: 字符串的其他使 ...

  2. grafana 4 升级到 grafana 5错误处理

    遇到2个错误: 1. UNIQUE KEY 问题 INFO[07-16|15:34:36] Executing migration logger=migrator id="Remove un ...

  3. [转]jQuery不同版本区别

    原文转载自csdn:http://blog.csdn.net/u010167032/article/details/23666145 了解不同版本之间的差异,与助于选择适合自己项目的版本. ⒈4重要新 ...

  4. angular6组件通信

    此文章是用markdown书写,赋值全部到vscode打开即可. # Angular组件通信 ## .父组件传递数据到子组件 - `@Input`:属性绑定,父组件向子组件传递数据 ```js // ...

  5. 100天搞定机器学习|Day13-14 SVM的实现

    昨天我们学习了支持向量机基本概念,重申数学推导原理的重要性并向大家介绍了一篇非常不错的文章.今天,我们使用Scikit-Learn中的SVC分类器实现SVM.我们将在day16使用kernel-tri ...

  6. Jquery事件和选择器 纠错

    1: 试题分析:该题考的是jQuery中事件绑定的知识.绑定事件用bind()方法,选项A是正确的绑定事件语法,因此是正确的答案.选项BCD的语法是错误的. 2: 试题分析:opacity 必需.规定 ...

  7. Redhat 离线安装 Docker (Community from binaries)

    需求 在离线环境安装Docker (Community版),因为Enterprise版要花钱.当然资金充裕的客户可参考https://docs.docker.com/install/linux/doc ...

  8. 用HTML5的Audio标签做一个歌词同步的效果

    HTML5出来这么久了,但是关于它里面的audio标签也就用过那么一次,当然还仅仅只是把这个标签插入到了页面中.这次呢就刚好趁着帮朋友做几个页面,拿这个audio标签来练练手. 首先你需要向页面中插入 ...

  9. kafka同步异步消费和消息的偏移量(四)

    1. 消费者位置(consumer position) 因为kafka服务端不保存消息的状态,所以消费端需要自己去做很多事情.我们每次调用poll()方法他总是返回已经保存在生产者队列中还未被消费者消 ...

  10. HTML/CSS:div水平与元素垂直居中(2)

    单个div水平居中:设置margin的左右边距为自动 div水平和垂直居中,text-align和vertical-align不起作用,因为标签div没有这两个属性,所以再css中设置这两个值不能居中 ...