MDove:不要着急,接下来文章会好好针对volatile进行总结,毕竟是面试的常客。当然AtomicInteger也颇为重要,因为它是CAS思想的具体实现….
面试常客API
MDove:接下来,我们聊一聊一些基础的api的作用:
sleep() 方法:
sleep() 允许 指定以毫秒为单位的一段时间作为参数,它使得线程在指定的时间内进入阻塞状态,不能得到CPU 时间,指定的时间一过,线程重新进入可执行状态。(不释放锁)
suspend() 和 resume() 方法:
suspend()使得线程进入阻塞状态,并且不会自动恢复,必须其对应的resume() 被调用,才能使得线程重新进入可执行状态。典型地,suspend() 和 resume() 被用在等待另一个线程产生的结果的情形。
Thread 类中的方法;不会释放锁;可在任何位置调用。
yield() 方法:
yield() 使得线程放弃当前分得的 CPU 时间,但是不使线程阻塞,即线程仍处于可执行状态,随时可能再次分得 CPU 时间。
wait() 和 notify() 方法():
两个方法配套使用,wait() 使得线程进入阻塞状态,它有两种形式,一种允许 指定以毫秒为单位的一段时间作为参数,另一种没有参数,前者当对应的 notify() 被调用或者超出指定时间时线程重新进入可执行状态,后者则必须对应的 notify() 被调用。
Object中的方法; 会释放锁;这一对方法却必须在 synchronized 方法或块中调用。原因也很好理解:只有在synchronized这类同步代码块中,当前线程才占有锁,才有锁可以释放。同理,调用方法的对象上的锁必须为当前线程所拥有,这样才有锁可以释放。因此,这一对方法调用必须放置在synchronized这样的同步代码中。注意:若不满足这一条件,仍能编译,但在运行时会出现IllegalMonitorStateException异常。
interrupt():
不要以为它是中断某个线程!它只是线线程发送一个中断信号,让线程在无限等待时(如死锁时)能抛出抛出,从而结束线程,但是如果你吃掉了这个异常,那么这个线程还是不会中断的!
MDove:这些方法可需要好好的去体会呦。不光是面试中常常遇到,更多是它们是我们操作Thread的利器。