python多线程中线程锁的使用

python多线程中线程锁的使用

定义两个函数分别循环输出数字和字母

import time
import string

def func1():
    for i in range(1,52,2):
        print(i,end='')
        print(i+1,end='')
        time.sleep(0.1)

def func2():
    for j in list(string.ascii_uppercase):
        print(j)
        time.sleep(0.1)

if __name__ == '__main__':
    func1()
    func2()

执行结果为:在这里插入图片描述
为了让两个函数能够同时执行,我们尝试添加线程让其交替执行
添加线程threading后的代码:

import time
import string
import threading

def func1():
    for i in range(1,52,2):
        print(i,end='')
        print(i+1,end='')
        time.sleep(0.1)

def func2():
    for j in list(string.ascii_uppercase):
        print(j)
        time.sleep(0.1)

if __name__ == '__main__':
    t1 = threading.Thread(target=func1)
    t2 = threading.Thread(target=func2)
    t1.start()
    t2.start()
    t1.join()
    t2.join()
    print('----执行结束-----')

结果如下:
发现并没有按想象的那样顺序交替执行,而是有点无章则的输出

在这里插入图片描述
于是乎想到了线程中线程锁这个东西,添加后果然能够按我们所想的那样顺序交替执行输出了
添加线程锁之后的代码:

import time
import string
import threading

def func1():
    for i in range(1,52,2):
        lock2.acquire() # 上第二把锁
        print(i,end='')
        print(i+1,end='')
        lock1.release() # 释放第一把锁
        time.sleep(0.1)

def func2():
    for j in list(string.ascii_uppercase):
        lock1.acquire() # 重新又把第一把锁上
        print(j)
        lock2.release() # 释放第二把锁
        time.sleep(0.1)

if __name__ == '__main__':
    lock1 = threading.Lock()
    lock2 = threading.Lock()
    t1 = threading.Thread(target=func1)
    t2 = threading.Thread(target=func2)
    lock1.acquire() # 提前上一把锁lock1
    t1.start()
    t2.start()
    t1.join()
    t2.join()
    print('----执行结束-----')

打印输出结果:
在这里插入图片描述

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python线程锁是一种用于保护共享资源的同步机制,可以确保同一时刻只有一个线程访问共享资源,避免多个线程同时修改数据而导致数据不一致的问题。下面是一个使用线程锁的示例: ```python import threading # 定义一个共享资源,初始值为0 shared_resource = 0 # 定义一个线程锁 lock = threading.Lock() # 定义一个线程函数,用于修改共享资源的值 def update_shared_resource(): global shared_resource # 获取线程锁 lock.acquire() # 修改共享资源的值 shared_resource += 1 # 释放线程锁 lock.release() # 创建多个线程,同时访问共享资源 threads = [] for i in range(10): thread = threading.Thread(target=update_shared_resource) threads.append(thread) # 启动多个线程 for thread in threads: thread.start() # 等待所有线程执行完毕 for thread in threads: thread.join() # 输出共享资源的最终值 print("Shared resource: ", shared_resource) ``` 在上面的示例,定义了一个共享资源`shared_resource`和一个线程锁`lock`。在`update_shared_resource()`函数,先获取线程锁,然后修改共享资源的值,最后释放线程锁。在创建多个线程时,每个线程都会调用`update_shared_resource()`函数来修改共享资源的值,但是由于使用线程锁,每次只有一个线程能够获得线程锁并修改共享资源的值,其他线程需要等待线程锁释放才能继续执行。 注意,获取线程锁后,需要在适当的时候释放线程锁,否则会导致死锁等问题。在上面的示例使用了`lock.acquire()`获取线程锁,并在`lock.release()`处释放线程锁

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值