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

  • 相关阅读:
    VLC播放器web插件接口(Part1)
    视频监控/存储系统设计要点
    CVR并发写入测试
    Darwin Streaming Server性能测试报告
    用Red5搭建支持WEB播放的实时监控视频
    RTSP协议-中文定义
    网格最短路径算法(Dijkstra & Fast Marching)
    三维网格精简算法(Quadric Error Metrics)附源码
    三维网格细分算法(Catmull-Clark subdivision & Loop subdivision)附源码
    网格测地线算法(Geodesics in Heat)附源码
  • 原文地址:https://www.cnblogs.com/saolv/p/9304340.html
Copyright © 2011-2022 走看看