线程面试问题整理

1、线程的实现方式

    Java多线程实现方式主要有四种

   (1)没有返回值

    继承Thread类、实现Runnable接口

   (2)有返回值

    实现Callable接口通过FutureTask包装器来创建Thread线程

    使用ExecutorService、Callable、Future实现有返回结果的多线程

2、线程的周期

   新建(new Thread)
   当创建Thread类的一个实例(对象)时,此线程进入新建状态(未被启动)。
   例如:Thread  t1=new Thread();


   就绪(runnable)
   线程已经被启动,正在等待被分配给CPU时间片,也就是说此时线程正在就绪队列中排队等候得到CPU资      源。例如:t1.start();

   运行(running)
   线程获得CPU资源正在执行任务(run()方法),此时除非此线程自动放弃CPU资源或者有优先级更高的线程    进入,线程将一直运行到结束。

   死亡(dead)
   当线程执行完毕或被其它线程杀死,线程就进入死亡状态,这时线程不可能再进入就绪状态等待执行。  

   堵塞(blocked)
   由于某种原因导致正在运行的线程让出CPU并暂停自己的执行,即进入堵塞状态。

3、线程状态改变使用的几种方法

线程面试问题整理_第1张图片


   sleep():使当前线程进入计时等待状态,所以执行sleep()的线程在指定的时间内肯定不会执行, 同时      sleep函数不会释放锁资源。

   wait():使当前线程进入等待状态,但是该线程会释放掉自己占有的“锁标识”,从而让别的线程有机会抢    占该锁。

   yield():暂停当前正在执行的线程对象,使当前线程重新回到可执行状态,只能使同优先级或者更高优先    级的线程执行。

   join():等待调用Join方法的线程结束在继续执行。

4、线程池   

线程面试问题整理_第2张图片

5、线程同步

(一)sychronized、lock、volatile

http://blog.csdn.net/u011760575/article/details/53999596




你可能感兴趣的:(【多线程/并发】)