Java多线程面试题:描述一下线程安全活跃态问题,竞态条件?

一、线程安全活跃态问题

线程因为某件事情得不到执行

1、活锁

线程没有阻塞,但一直重复执行某个操作,并且失败重试

1)例子

  • 在消息队列中,消费者没有正确ack消息,并且执行过程中报错了,消息会被重复执行,一直失败并重试
  • for循环忘记break
  • 递归忘记写结束条件

2)解决方案

等待随机时间,按照时间轮去重试,到达一定时间退出重试

2、 饥饿

线程因为无法访问所需资源而一直在等待

1)两种情况

  • 线程优先级问题,不合理分配,导致部分线程始终无法获得CPU资源而一直无法执行
    例如,读写锁,读优先,会造成饥饿,写一直在等
  • 一些线程在临界区无限循坏等待资源,让其他线程一直拿不到锁进去临界区,进入了饥饿状态

2)解决方案

  • 保证资源充足(但很多场景下,资源稀缺无法解决)
  • 公平分配资源(使用公平锁,FIFO策略)
  • 避免持有锁的线程长时间执行

3、死锁

多个线程互相等待对方释放锁的过程

二、竞态条件

多个线程同时访问相同资源,如果对资源的访问顺序敏感,就称存在竞态条件

最常见的情况

  • 先检查后执行:检查值的状态,根据这个状态去更新,但期间可能被其它线程修改,导致执行结果出现各种问题
  • 延迟初始化,单例
posted @ 2023-02-24 23:43  程序员Forlan  阅读(63)  评论(0编辑  收藏  举报