1.线程开始运行,拥有自己的栈空间,就如同一个脚本一样,按照既定的代码一步一步地执行,直到终止。但是,每个运行中的线程,如果仅仅是孤立地运行,那么没有一点价值了,或者说价值很少了,如果多个线程能够相互配合的完成工作,那么会带来巨大的价值。
等待/通知机制:
一个线程修改了一个对象的值,而另一个线程感知到了变化,然后进行相应的操作,整个过程开始于一个线程而最终执行又是另一个线程。前者是生产者,后者是消费者,这种模式隔了了“做什么”和“怎么做”,在功能层面上实现了解耦。
while(value!=desire){
Thread.sleep(1000);
}
dosomething();
上面的代码就是实现了,等待/通知机制,让消费者的线程不断的循环检查变量是否符合预期,如下面的代码所示,while循环中设置不满足的条件,如果添加满足则退出while循环,从而完成消费者的工作。
但是,上面的代码却存在如下的问题:
(1).难以确保及时性(2).难以降低开销
针对上的两个问题,可以运用如下的方法解决:
notify() 通知一个在对象上等待的线程,使其从wait()方法返回,而返回的前提是该线程获取到了对象的锁。
notifyAll() 通知所有等待在该对象上的线程。
wait() 调用该方法的线程进入WAITING状态,只有等待另外的线程的通知或被中断才会返回,需要注意,调用wait()方法后,会释放对象的锁。
wait(long)超时等待一段时候,这里的参数时间是毫秒,也就是等待长达n毫秒,如果没有通知就超时返回。
wait(long,int)对于超时时间更细粒度的控制,可以达到纳秒。