Python学习并发之threading库

1.简介:

  • Python 很早就开始使用多种不同的并发编程方法,包括多线程加载子进程等。

2.单线程引入:

  • 先看一段代码:
    #coding=utf-8
    import time
    
    def greet(index):
        print '人生苦短,我用Python!-%d' % index
        time.sleep(0.5)
        
    def line_run():
        for i in range(5):
            greet(i)
    
    if __name__ == "__main__":#入口函数的判断
        line_run()
    
    #结果:当然是依次顺序的打印这句话了,,,
    人生苦短,我用Python!-0
    人生苦短,我用Python!-1
    人生苦短,我用Python!-2
    人生苦短,我用Python!-3
    人生苦短,我用Python!-4
    
    Process finished with exit code 0
    
注意:
  • if __name__ == "__main__":----------------简要说明如下:
    • 有句话经典的概括了这段代码的意义:Make a script both importable and executable
    • 意思就是让你写的脚本模块既可以导入到别的模块中用,另外该模块自己也可执行。
    • 调试代码的时候,在if __name__ == '__main__'中加入一些我们需要调试的代码,可以让外部模块调用的时候不执行调试代码,但是如果我们想排查问题的时候,直接执行该模块文件,调试代码能够正常运行!

3.多线程引入:

  • 改进后的代码:
    #coding=utf-8
    import time
    import threading
    def greet(index):
        print '人生苦短,我用Python!-%d'%index
        time.sleep(0.5)
    
    def async_run():
        for i in range(5):
            th = threading.Thread(target=greet,args=[i])#target指的函数名args为参数
            th.start()
    
    if __name__ == "__main__":
        async_run()
    #结果:同时打印下列的语句:请自己亲测方能看到效果。
    人生苦短,我用Python!-0
    人生苦短,我用Python!-1
    人生苦短,我用Python!-2
    人生苦短,我用Python!-3
    人生苦短,我用Python!-4
    

4.threading库可用来在单独的线程中执行任意的Python可调用对象。

  • t = threading.Thread(target=函数名,args=[参数])#创建线程t。
  • t.start()执行线程。
  • 当创建一个线程实例时,在调用它的start()方法之前(需要提供目标函数以及相应的参数),线程并不会立即执行。
  • 该线程实例完全由操作系统来管理。一旦启用后,线程就开始独立运行,直到目标函数返回为至。
  • 可以通过查询线程实例来判断它是否还在运行。t.is_alive()---查看线程是否运行
  • t.join()请求连接到某个线程上,这个方法会等待线程结束。
  • 对于需要长时间运行的线程或者一直不断运行的后台任务,应该考虑将这些线程设置为daemon(即,守护线程):t = threading.Thread(target=函数名,args=[参数],daemon=True)
    注意:daemon线程是无法被连接的。但是当主线程结束后则会自动销毁。

5.举例:生产者和消费者

  • 代码:两个线程对公共变量MONEY操作
    #coding=utf-8
    import time
    import threading
    import random
    MONEY = 0#全局变量MONEY
    gLock = threading.Lock()#锁
    #生产者
    def procuder():
        while True:
            global MONEY#声明一个全局变量
            rand_money = random.randint(10,100)#随机生产一个数值
            gLock.acquire()#用acquire()申请锁
            MONEY += rand_money
            gLock.release()#释放锁
            print '生产者%s-生产了:%d' % (threading.current_thread, MONEY)
            time.sleep(0.5)#睡眠
    
    #消费者
    def customer():
        while True:
            global MONEY #声明一个全局变量
            rand_money = random.randint(10,100)#随机生成一个数值
            if MONEY > rand_money:
                print '消费者%s-消费了:%d' %(threading.current_thread,rand_money)
                gLock.acquire#加锁
                MONEY -= rand_money
                gLock.release#释放
            else:
                print '需要消费的钱为:%d,余额为:%d' %(rand_money,MONEY)
    
  • threading.Lock()创建锁,用acquire()申请锁,每次只有一个线程获得锁,其他线程必须等此线程release()后才能获得锁。
  • RLock允许在同一线程中被多次acquire。而Lock却不允许这种情况。
    注意:如果使用RLock,那么acquirerelease必须成对出现,即同一线程中调用了n次acquire,必须调用n次的release才能真正释放所占用的琐。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,710评论 4 376
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,839评论 2 308
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,295评论 0 255
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,776评论 0 223
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,198评论 3 297
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,074评论 1 226
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,200评论 2 322
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,986评论 0 214
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,733评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,877评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,348评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,675评论 3 265
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,393评论 3 246
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,209评论 0 9
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,996评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,212评论 2 287
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 36,003评论 2 280

推荐阅读更多精彩内容

  • 线程状态新建,就绪,运行,阻塞,死亡。 线程同步多线程可以同时运行多个任务,线程需要共享数据的时候,可能出现数据不...
    KevinCool阅读 746评论 0 0
  • 线程 1.同步概念 1.多线程开发可能遇到的问题 同步不是一起的意思,是协同步调 假设两个线程t1和t2都要对nu...
    TENG书阅读 582评论 0 1
  • 1.进程和线程 队列:1、进程之间的通信: q = multiprocessing.Queue()2、...
    一只写程序的猿阅读 1,066评论 0 17
  • 线程 引言&动机 考虑一下这个场景,我们有10000条数据需要处理,处理每条数据需要花费1秒,但读取数据只需要0....
    不浪漫的浪漫_ea03阅读 343评论 0 0
  • Excel是许多职位都会用到的工具,可能大部分人都是不怎么会有技巧地使用该工具的。首推看视频加实践进行学习。下面简...
    瘦长的丰一禾阅读 1,006评论 4 18