☆技术问答集锦(16)避免活跃性

1 活跃性的概念,哪些场景会存在活跃性问题?

概念:活跃性这个词代表着某件正确的事情最终会发生。活跃性失败发生在应用程序触及一种无法继续执行的状态。

场景:(1)在单线程的应用程序中,无限循环就是一个例子;(2)并发编程方面,为保证线程安全采用加锁的方式,但可能造成活跃性问题,例如死锁、活锁和饥饿;

2 System.identityHashCode的作用是什么?

identityHashCode()方法是System类中的静态方法,根据对象内存地址来计算哈希值。

对于String对象,只要a 和 b 的字符串是一样的,那么hashCode()方法返回的值必定相同,但是System.identityHashCode()方法不管什么情况下都不同。

3 多线程死锁情况下,如何解决或避免死锁?

下面这四个条件是产生死锁的必要条件,只要系统发生死锁,这些条件必然成立,而只要上述条件之一不满足,就不会发生死锁,因此可以通过破坏这四个条件之中的任意一个达到避免死锁的目的

  1. 互斥条件:一个资源每次只能被一个进程使用;
  2. 请求和保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放;
  3. 不可抢占条件:进程已获得的资源,在末使用完之前,不能强行剥夺,只能在进程使用完时由自己释放;
  4. 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系;

4 Thread Dump信息当中,如何确认哪两个线程死锁的?


5 饥饿锁是什么?如何产生的?带来什么问题?如何解决?

饥饿锁:一个或者多个线程因为种种原因无法获得所需要的资源,导致一直无法执行的状态。

产生原因:(1)高优先级线程吞噬所有的低优先级线程的CPU时间;(2)线程被永久堵塞在一个等待进入同步块的状态,因为其他线程总是能在它之前持续地对该同步块进行访问;

解决方案:(1)使用锁,而不是同步块;(2)公平锁;

6 Thread 优先级的作用?什么情况下不一定按优先级顺序?

优先级作用:线程的优先级只能确保CPU尽量将执行的资源让给优先级高的线程用,但不保证定义的高优先级的线程的都能先于低优先级的线程执行完;

不按照优先级顺序:不同的系统有不同的线程优先级的取值范围,Java定义了10个级别(1-10)。当不同优先级的线程对应操作系统的同一个优先级段时会出现不按优先级顺序执行

7 活锁是什么?如何产生的?带来什么问题?如何解决?

活锁概念:任务或者执行者没有被阻塞,但线程不断重复执行相同的操作,但每次操作的结果都是失败的;

产生原因:由于某些条件没有满足,导致一直重复尝试,失败,尝试,失败;

带来问题:尽管这个问题不会阻塞线程,但是程序也无法继续执;

解决方案:活锁的办法是在每次重复执行的时候引入随机机制,这样由于出现的可能性不同使得程序可以继续执行其他的任务;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在安全性与活跃性之间通常存在着某种制衡。我们使用加锁机制来确保线程安全, 但如果过度地使用加锁, 则可能导致锁顺序...
    好好学习Sun阅读 485评论 0 1
  • 又来到了一个老生常谈的问题,应用层软件开发的程序员要不要了解和深入学习操作系统呢? 今天就这个问题开始,来谈谈操...
    tangsl阅读 4,193评论 0 23
  • 本文主要讲了java中多线程的使用方法、线程同步、线程数据传递、线程状态及相应的一些线程函数用法、概述等。 首先讲...
    李欣阳阅读 2,517评论 1 15
  • Java多线程学习 [-] 一扩展javalangThread类 二实现javalangRunnable接口 三T...
    影驰阅读 3,008评论 1 18
  • 1.内存的页面置换算法 (1)最佳置换算法(OPT)(理想置换算法):从主存中移出永远不再需要的页面;如无这样的...
    杰伦哎呦哎呦阅读 3,370评论 1 9