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

426 阅读3分钟

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 活锁是什么?如何产生的?带来什么问题?如何解决?

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

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

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

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