线程的安全与不安全

线程安全:

是指多个线程在执行同一段代码时加锁机制(synchronized)

线程不安全:

是指不提供加锁机制保护,有可能出现多个线程先后更改数据造成所得到的数据是混乱的。

解决线程都方法有

同步代码块, 同步方法, 显示锁,

出现问题是:多卖出去两张票

请添加图片描述

解决方法一:同步代码块

线程同步:synchronized
应该看同一把锁
格式: synchronized(锁对象){}

在这里插入图片描述

解决方法二:同步方法

在方法的返回值类型的前面加synchronized
在这里插入图片描述

解决方法三:显示锁 Lock 子类 ReentrantLock

在这里插入图片描述
l.Lock(); l.UnLock;

公平锁与不公平锁

在这里插入图片描述
公平锁:多个线程按照申请锁的顺序去获得锁,线程会直接进入队列去排队,永远都是队列的第一位才能得到锁。

优点:所有的线程都能得到资源,不会饿死在队列中。
缺点:吞吐量会下降很多,队列里面除了第一个线程,其他的线程都会阻塞,cpu唤醒阻塞线程的开销会很大。

非公平锁:多个线程去获取锁的时候,会直接去尝试获取,获取不到,再去进入等待队列,如果能获取到,就直接获取到锁。

优点:可以减少CPU唤醒线程的开销,整体的吞吐效率会高点,CPU也不必取唤醒所有线程,会减少唤起线程的数量。
缺点:你们可能也发现了,这样可能导致队列中间的线程一直获取不到锁或者长时间获取不到锁,导致饿死。

线程死锁

多个线程互等待相调用彼此,
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值