zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    [SAP Rolling Out] Unit TEST/INTEGRATION TEST/UAT TEST/PARREL TESTING
    针式PKM与众不同的地方
    针式PKM拖动收集功能兼容所有的浏览器
    周九常:个人知识管理的三个重点领域
    关闭word文件老是说normal.dot被另外一人使用
    针式PKM初级应用:修改知识点的颜色评介
    寻找识货的人
    针式PKM中级应用如何将知识管理应用到新项目研发中
    针式PKM中级应用在10秒以内找到本月收集的任意文章
    针式PKM中级应用:知识点之间如何链接
  • 原文地址:https://www.cnblogs.com/saolv/p/9304340.html
Copyright © 2011-2022 走看看