随笔 - 118  文章 - 33 评论 - 1 阅读 - 64751
< 2025年6月 >
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 1 2 3 4 5
6 7 8 9 10 11 12

1.线程是应用程序的最小控制单元

复制代码
import threading
import time

NUM = 10

def f():
    global NUM
    NUM -= 1
    time.sleep(2)
    print (NUM)

for i in range(5):
    t = threading.Thread(target=f)
    t.start()
复制代码

执行结果:

5
5
5
5
5

在这里,我们创建了5个线程,每个线程在程序还没有结束的时候就开始都对NUM进行了相应的操作,time.sleep(2)阻塞了进程的执行,造成进程的切换,所以在等待的2秒钟了,所有的线程都执行了-1的操作,最后都打印出来了最终的结果5.因为线程是共享一个进程中的资源,所以当线程之间的数据访问有交叉的时候,需要对线程进行加锁。

复制代码
import threading
import time

NUM = 10

lock = threading.RLock()
def f():
    global NUM
    lock.acquire()
    NUM -= 1
    time.sleep(2)
    lock.release()
    print (NUM)

for i in range(5):
    t = threading.Thread(target=f)
    t.start()
复制代码

执行结果:

9
8
7
6
5

加锁的方式有两种,一种是threading.Lock(),还有一种是threading.RLock(),后一种方式可以在锁里面嵌套锁,我们默认使用后面的方式比较多,兼容前面的Lock()锁。

posted on 2016-08-31 00:58  Alex0425  阅读(174)  评论(0)    收藏  举报
点击右上角即可分享
微信分享提示