python 线程
前言
携程与线程相比,携程省去了切换线程引起的开销,携程的切换都是我们指定的。正因为携程间的切换是由我们控制的,所以携程是没有锁的概念的,省去了解锁的麻烦
有人会问了,切换线程有什么开销啊?因为,线程是抢占式多任务,比如a线程执行的好好的,没遇到sleep叶没出现io,突然b线程抢走了执行权,这个时候计算机是不是得至少记录下a线程执行到哪里了?
在线程里,当线程运行到io操作时,当前线程被挂起,cpu转而执行其他线程。
第一次更新:上面这句话是错的,当县城遇到io时,并不会立即挂起,而是像普通代码一样去执行,只要遇到time.sleep的时候才是挂起。而携程不一样,asyncio模块里可以将io操作转为携程,这样当前运行的携程运行到await这个io的时候,当前携程就会立马被挂起。eventloop转而去执行别的携程。
1。threading.local方法
#coding=utf-8 import threading # 创建全局ThreadLocal对象: localVal = threading.local() localVal.val = "Main-Thread" def process_student(): print '%s (in %s)' % (localVal.val, threading.current_thread().name) def process_thread(name): #赋值 localVal.val = name process_student() t1 = threading.Thread(target= process_thread, args=('One',), name='Thread-A') t2 = threading.Thread(target= process_thread, args=('Two',), name='Thread-B') t1.start() t2.start() t1.join() t2.join() print localVal.val
打印结果:
One (in Thread-A)
Two (in Thread-B)
Main-Thread
threading.local()这个方法的特点用来保存一个全局变量,但是这个全局变量只有在当前线程才能访问,
localVal.val = name这条语句可以储存一个变量到当前线程,如果在另外一个线程里面再次对localVal.val进行赋值,
那么会在另外一个线程单独创建内存空间来存储,也就是说在不同的线程里面赋值 不会覆盖之前的值,因为每个
线程里面都有一个单独的空间来保存这个数据,而且这个数据是隔离的,其他线程无法访问
2线程event概念及使用
https://www.cnblogs.com/saolv/p/9329235.html
3线程condition概念使用
https://www.cnblogs.com/saolv/p/9330740.html