Java中线程的高级应用
2010-10-05 01:23:09 来源:WEB开发网Java多线程互斥及同步控制和通信
多个线程的执行是并发的,也就是在逻辑上“同时”,而不管是否是物理上的“同时”。如果系统只有一个CPU,那么真正的“同时”是不可能的,但是由于CPU的速度非常快,用户感觉不到其中的区别,因此我们也不用关心它,只需要设想各个线程是同时执行即可。
多线程和传统的单线程在程序设计上最大的区别在于,由于各个线程的控制流彼此独立,使得各个线程之间的代码是乱序执行的,由此带来的线程调度,同步等问题。
1、线程互斥与线程同步
线程互斥:并发执行的多个线程在某一时间内只允许一个线程在执行以访问数据。
线程同步:并发执行的多个线程之间互相发送消息进行合作、互相等待,按一定速度配合执行。
2、线程互斥
由于同一进程的多个线程共享同一片存储空间,在带来方便的同时,也带来了访问冲突这个严重的问题。Java语言提供了专门机制以解决这种冲突,有效避免了同一个数据对象被多个线程同时访问。
(1)应用的场合:
当两个或多个线程同时访问共享数据时,可能对数据进行读、写、修改、删除等操作时,应保证同时只有一个线程访问共享数据。
(2)线程互斥的实现机制
① 监视器(同步锁定):
线程进入监视器后其它线程则不能再进入监视器,直到被锁定的线程退出监视器,下一个线程才能进入监视器被执行。
如何产生监视器(同步互斥方法):通过在被多个线程所共享的方法前加上synchronized关键字定义出同步互斥方法,每一个拥有synchronized方法的对象都含有一个独立的监视器,只有某一个线程的synchronized方法执行完后其它线程的synchronized方法才能被执行。
public synchronized void myFun() { }
② 编程要点:
l 应将访问共享数据的代码设计为synchronized方法;
l synchronized可以用来限定一个方法或一小段语句或整个类(可将类的静态成员函数声明为 synchronized ,以控制其对类的静态成员变量的访问),即类方法,实例方法,一个方法中的任何代码块。
l 由于可以通过 private 关键字来保证数据对象只能被方法访问,所以只需针对方法提出一套同步锁定机制。通过synchronized 方法来控制对类中的成员变量(共享数据)的访问。
更多精彩
赞助商链接