java.util.concurrent包的并发处理.doc_第1页
java.util.concurrent包的并发处理.doc_第2页
java.util.concurrent包的并发处理.doc_第3页
java.util.concurrent包的并发处理.doc_第4页
java.util.concurrent包的并发处理.doc_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

浅谈java.util.concurrent包的并发处理收藏新一篇:国耻日-永远的1937年12月13日,悼念反人类的南京大屠杀七十周年我们都知道,在JDK1.5之前,Java中要进行业务并发时,通常需要有程序员独立完成代码实现,而当针对高质量Java多线程并发程序设计时,为防止死蹦等现象的出现,比如使用java之前的wait()、notify()和synchronized等,每每需要考虑性能、死锁、公平性、资源管理以及如何避免线程安全性方面带来的危害等诸多因素,往往会采用一些较为复杂的安全策略,加重了程序员的开发负担.万幸的是,在JDK1.5出现之后,Sun大神终于为我们这些可怜的小程序员推出了java.util.concurrent工具包以简化并发完成。开发者们借助于此,将有效的减少竞争条件(race conditions)和死锁线程。concurrent包很好的解决了这些问题,为我们提供了更实用的并发程序模型。java.util.concurrent下主要的接口和类:Executor:具体Runnable任务的执行者。ExecutorService:一个线程池管理者,其实现类有多种,比如普通线程池,定时调度线程池ScheduledExecutorService等,我们能把一个Runnable,Callable提交到池中让其调度。Future:是与Runnable,Callable进行交互的接口,比如一个线程执行结束后取返回的结果等等,还提供了cancel终止线程。BlockingQueue:阻塞队列。下面我写一个简单的事例程序:FutureProxy.javapackageorg.test.concurrent;/*/*Title:LoonFramework*Description:利用Future模式进行处理*Copyright:Copyright(c)2007*Company:LoonFramework*authorchenpeng*email:*version0.1*/importjava.lang.reflect.InvocationHandler;importjava.lang.reflect.Method;importjava.lang.reflect.Proxy;importjava.util.concurrent.Callable;importjava.util.concurrent.ExecutorService;importjava.util.concurrent.Executors;importjava.util.concurrent.Future;importjava.util.concurrent.ThreadFactory;publicabstractclassFutureProxy.privatefinalclassCallableImplimplementsCallable.publicTcall()throwsException.returnFutureProxy.this.createInstance();privatestaticclassInvocationHandlerImplimplementsInvocationHandler.privateFuturefuture;privatevolatileTinstance;InvocationHandlerImpl(Futurefuture).this.future=future;publicObjectinvoke(Objectproxy,Methodmethod,Objectargs)throwsThrowable.synchronized(this).if(this.future.isDone().this.instance=this.future.get();else.while(!this.future.isDone().try.this.instance=this.future.get();catch(InterruptedExceptione).Thread.currentThread().interrupt();returnmethod.invoke(this.instance,args);/*/*实现java.util.concurrent.ThreadFactory接口*authorchenpeng*/privatestaticfinalclassThreadFactoryImplimplementsThreadFactory.publicThreadnewThread(Runnabler).Threadthread=newThread(r);thread.setDaemon(true);returnthread;privatestaticExecutorServiceservice=Executors.newCachedThreadPool(newThreadFactoryImpl();protectedabstractTcreateInstance();protectedabstractClassgetInterface();/*/*返回代理的实例*return*/SuppressWarnings(unchecked)publicfinalTgetProxyInstance().ClassinterfaceClass=this.getInterface();if(interfaceClass=null|!interfaceClass.isInterface().thrownewIllegalStateException();Callabletask=newCallableImpl();Futurefuture=FutureProxy.service.submit(task);return(T)Proxy.newProxyInstance(interfaceClass.getClassLoader(),newCerfaceClass,newInvocationHandlerImpl(future);Test.javapackageorg.test.concurrent;importjava.util.Calendar;/*/*Title:LoonFramework*Description:*Copyright:Copyright(c)2007*Company:LoonFramework*authorchenpeng*email:*version0.1*/interfaceDateTest.StringgetDate();classDateTestImplimplementsDateTest.privateString_date=null;publicDateTestImpl().try._date+=Calendar.getInstance().getTime();/设定五秒延迟Thread.sleep(5000);catch(InterruptedExceptione).publicStringgetDate().returndate+_date;classDateTestFactoryextendsFutureProxy.OverrideprotectedDateTestcreateInstance().returnnewDateTestImpl();OverrideprotectedClassgetInterface().returnDateTest.class;publicclassTest.publicstaticvoidmain(Stringargs).DateTestFactoryfactory=newDateTestFactory();DateTestdts=newDateTest100;for(inti=0;idts.length;i+).dtsi=factory.getProxyInstance();/遍历执行for(DateTestdt:dts).System.out.println(dt.getDate();原来很麻烦的并发处理,现在轻松的得以完成

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论