欢迎来到天天文库
浏览记录
ID:61462326
大小:55.04 KB
页数:21页
时间:2021-02-02
《java5多线程新特性.docx》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、在Java5.0之前Java里的多线程编程主要是通过Thread类,Runnable接口,Object对象中的wait()、notify()、notifyAll()等方法和synchronized关键词来实现的。这些工具虽然能在大多数情况下解决对共享资源的管理和线程间的调度,但存在以下几个问题1. 过于原始,拿来就能用的功能有限,即使是要实现简单的多线程功能也需要编写大量的代码。这些工具就像汇编语言一样难以学习和使用,比这更糟糕的是稍有不慎它们还可能被错误地使用,而且这样的错误很难被发现。2.
2、 如果使用不当,会使程序的运行效率大大降低。3. 为了提高开发效率,简化编程,开发人员在做项目的时候往往需要写一些共享的工具来实现一些普遍适用的功能。但因为没有规范,相同的工具会被重复地开发,造成资源浪费。4. 因为锁定的功能是通过Synchronized来实现的,这是一种块结构,只能对代码中的一段代码进行锁定,而且锁定是单一的。如以下代码所示:synchronized(lock){ //执行对共享资源的操作 ……} 一些复杂的功能就很难被实现。比如说如果程序需要取得
3、lockA和lockB来进行操作1,然后需要取得lockC并且释放lockA来进行操作2,Java5.0之前的多线程框架就显得无能为力了。 因为这些问题,程序员对旧的框架一直颇有微词。这种情况一直到Java5.0才有较大的改观,一系列的多线程工具包被纳入了标准库文件。这些工具包括了一个新的多线程程序的执行框架,使编程人员可方便地协调和调度线程的运行,并且新加入了一些高性能的常用的工具,使程序更容易编写,运行效率更高。本文将分类并结合例子来介绍这些新加的多线程工具。 在我们开始介绍Java5.0里的新
4、Concurrent工具前让我们先来看一下一个用旧的多线程工具编写的程序,这个程序里有一个Server线程,它需要启动两个Component,Server线程需等到Component线程完毕后再继续。相同的功能在Synchronizer一章里用新加的工具CountDownLatch有相同的实现。两个程序,孰优孰劣,哪个程序更容易编写,哪个程序更容易理解,相信大家看过之后不难得出结论。publicclassServerThread{ ObjectconcLock=newObject();
5、intcount=2;publicvoidrunTwoThreads(){ //启动两个线程去初始化组件 newThread(newComponentThread1(this)).start(); newThread(newComponentThread1(this)).start(); //Waitforotherthreadwhile(count!=0){ synchronized(concLock)
6、{ try{ concLock.wait(); System.out.println("Wakeup."); }catch(InterruptedExceptionie){//处理异常} } } System.out.println("
7、Serverisup."); } publicvoidcallBack(){synchronized(concLock){ count--; concLock.notifyAll(); } } publicstaticvoidmain(String[]args){ ServerThreadserver=newServerThread(); serve
8、r.runTwoThreads(); }} publicclassComponentThread1implementsRunnable{ privateServerThreadserver; publicComponentThread1(ServerThreadserver){ this.server=server; }publicvoidrun(){ //做组件初始化的工作
此文档下载收益归作者所有