Java线程的深入探讨ronized方法内。 现在假设一种情况:线程1与线程2都要访问某个数据区,并且要求线程1的访 问先于线程2, 则这时仅用synchronized是不能解决问题的。这在Unix或Windows NT中可用Simaphore来实现。而Java并不提供。在Java中提供的是wait()和noti fy()机制。使用如下: synchronized method-1(…){ call by thread 1. ∥access data area; available=true; notify() } synchronized method-2(…){∥call by thread 2. while(!available) try{ wait();∥wait for notify(). }catch (Interrupted Exception e){ } ∥access data area } 其中available是类成员变量,置初值为false。 如果在method-2中检查available为假,则调用wait()。wait()的作用是使线 程2进入非运行态,并且解锁。在这种情况下,method-1可以被线程1调用。当执行 notify()后。线程2由非运行态转变为可运行态。当method-1调用返回后。线程2 可重新对该对象加锁,加锁成功后执行wait()返回后的指令。这种机制也能适用于 其他更复杂的情况。 (2)死锁 如果程序中有几个竞争资源的并发线程,那么保证均衡是很重要的。系统均衡 是指每个线程在执行过程中都能充分访问有限的资源。系统中没有饿死和死锁的 线程。Java并不提供对死锁的检测机制。对大多数的Java程序员来说防止死锁是 一种较好的选择。最简单的防止死锁的方法是对竞争的资源引入序号,如果一个线 程需要几个资源,那么它必须先得到小序号的资源,再申请大序号的资源。 4.小结 线程是Java中的重要内容,多线程是Java的一个特点。虽然Java的同步互斥不 如某些系统那么丰富,但适当地使用它们也能收到满意的效果。 上一篇:JRun常见问题回答 下一篇:基于JSP的动态网站开发技术 更多相关文章
|
推荐文章
精彩文章
|