预览加载中,请您耐心等待几秒...
1/9
2/9
3/9
4/9
5/9
6/9
7/9
8/9
9/9

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

Java多线程同步问题 Java多线程的同步依靠的是对象锁机制,synchronized关键字的背后就是利用了封锁来实现对共享资源的互斥访问。 下面以一个简单的实例来进行对比分析。实例要完成的工作非常简单,就是创建10个线程,每个线程都打印从0到99这100个数字,我们希望线程之间不会出现交叉乱序打印,而是顺序地打印。 先来看第一段代码,这里我们在run()方法中加入了synchronized关键字,希望能对run方法进行互斥访问,但结果并不如我们希望那样,这是因为这里synchronized锁住的是this对象,即当前运行线程对象本身。代码中创建了10个线程,而每个线程都持有this对象的`对象锁,这不能实现线程的同步。 代码 packagecom.vista; classMyThreadimplementsjava.lang.Runnable{ privateintthreadId; publicMyThread(intid){ this.threadId=id; } @Override publicsynchronizedvoidrun(){ for(inti=0;i《100;++i){ System.out.println(“ThreadID:”+this.threadId+“:”+i); } } } publicclassThreadDemo{ /** *@paramargs *@throwsInterruptedException */ publicstaticvoidmain(String[]args)throwsInterruptedException{ for(inti=0;i《10;++i){ newThread(newMyThread(i))。start(); Thread.sleep(1); } } } 从上述代码段可以得知,要想实现线程的同步,则这些线程必须去竞争一个唯一的共享的对象锁。 基于这种思想,我们将第一段代码修改如下所示,在创建启动线程之前,先创建一个线程之间竞争使用的Object对象,然后将这个Object对象的引用传递给每一个线程对象的lock成员变量。这样一来,每个线程的lock成员都指向同一个Object对象。我们在run方法中,对lock对象使用synchronzied块进行局部封锁,这样就可以让线程去竞争这个唯一的共享的对象锁,从而实现同步。 代码 packagecom.vista; classMyThreadimplementsjava.lang.Runnable{ privateintthreadId; privateObjectlock; publicMyThread(intid,Objectobj){ this.threadId=id; this.lock=obj; } @Override publicvoidrun(){ synchronized(lock){ for(inti=0;i《100;++i){ System.out.println(“ThreadID:”+this.threadId+“:”+i); } } } } publicclassThreadDemo{ /** *@paramargs *@throwsInterruptedException */ publicstaticvoidmain(String[]args)throwsInterruptedException{ Objectobj=newObject(); for(inti=0;i《10;++i){ newThread(newMyThread(i,obj))。start(); Thread.sleep(1); } } }