python多线程复习

import threading,time
locka=threading.Lock()
lockb=threading.Lock()
def myprint1():
for i in range(1,53,2):
locka.acquire()
print(str(i)+str(i+1),end=’’)
lockb.release()
time.sleep(0.01)
def myprint2():
for i in list(‘ABCDEFGHIJKLMNOPQRSTUVWXYZ’):
lockb.acquire()
print(i)
locka.release()
time.sleep(0.02)
lockb.acquire()
t1=threading.Thread(target=myprint1,args=())
t2=threading.Thread(target=myprint2,args=())
t1.start()
t2.start()
t1.join()
t2.join()

ident 线程标识符daemon 布尔类型,表示线程是否是守护线程
如果为 True 说明这个线程是守护线程,表示该线程不重要,整个 Python 程序在所有非守护线程会出之后才退出一个子线程会继承父线程的守护标记守护线程一般是一个等待客户端请求服务的服务器、如果没有客户端请求,守护线程就是空闲的,运行在一个无线循环,不会退出,进程退出时不需要等待它结束。
init 构造函数,
target 表示一个可调用对象start 启动run 定义线程功能方法,通常在子类中重写
join 在启动的线程终止前一直挂起,timeout 阻塞
利用线程和锁可以实现俩个数字配对一个字母输出
python的多线程并发并不是真正意义上的并发,而是由GIL分别交替地运行各个线程,从而实现并发效果。
线程的替代方案:
由于 Python 中 GIL 的限制,多线程更适合于 I/O 密集型应用,而不是计算密集型应用。为了实现更好的并发性,可以使用多进程,让 CPU 使用其他内核来执

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值