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

posted @ 2018-07-13 12:45  扫驴  阅读(122)  评论(0编辑  收藏  举报