线程锁

作者: 基本密码宋 | 来源:发表于2018-01-03 16:10 被阅读17次
from threading import Thread, Lock
import time

num = 0


# 线程一
def work_1():
    global num
    lock.acquire()
    for i in range(100000):
        num += 1
    lock.release()
    print("数据1是:", num)


# 线程二
def work_2():
    global num
    lock.acquire()  # 对这个线程进行上锁  当检测到有地方已经上锁了,那么这里等待锁被打开 才会执行下面的代码
    for i in range(100000):
        num += 1
    lock.release()  # 对这个线程进行解锁
    print("数据2是:", num)


if __name__ == '__main__':
    lock = Lock()
    t1 = Thread(target=work_1)
    t1.start()
    t2 = Thread(target=work_2)
    t2.start()
    print(num)

相关文章

  • 4.0.6.守护线程,线程死锁

    守护线程会随着主线程的结束而结束DaemonThread 线程 1, 线程 2,锁1,锁2 线程1 有锁1,想拿锁...

  • 悲观锁:一个线程得到锁,其它线程挂起,synchronized 乐观锁:一个线程得到锁,其它线程不断重试, cas...

  • sleep,wait, join yield

    锁池:所有需要竞争同步锁的线程都会放在锁池中,当一个线程得到锁后,其他线程都会在锁池中等待,当线程释放锁之后,其他...

  • 并发编程-线程

    线程 GIL 守护线程 线程锁(互斥锁 and 递归锁) 信号量 事件 条件 定时器 1.线程: 特点在多线程的操...

  • 深入理解AQS(二)- 共享模式

    共享锁与独占锁 独占锁被某个线程持有时,其他线程只能等待当前线程释放后才能去竞争锁,而且只有一个线程能竞争锁成功。...

  • iOS中各种锁的性能对比

    自旋锁 与 互斥锁 自旋锁 (spin lock): 如果一个线程需要获取自旋锁,该锁已经被其他线程占用,该线程不...

  • 死锁

    什么是死锁 简单的说:线程1持有A锁,线程2持有B锁;线程1尝试获取B锁,线程2尝试获取A锁。两个线程各持有了一把...

  • 公平锁和非公平锁-ReentrantLock是如何实现公平、非公

    1、什么是公平锁与非公平锁 公平锁:公平锁就是保障了多线程下各线程获取锁的顺序,先到的线程优先获取锁。非公平锁:非...

  • 2020-03-11 公平锁与非公平锁

    补: 公平锁:多个线程情况下排队,先到先获得锁 非公平锁:当锁被释放后,所有线程竞争锁,抢到的线程就会获得锁 非公...

  • LINUX线程

    创建线程 启动线程 线程锁

网友评论

      本文标题:线程锁

      本文链接:https://www.haomeiwen.com/subject/ibohnxtx.html