【大学课件】实务与陷阱.ppt
,國立交通大學資訊工程學系分散式系統實驗室Distributed Computing Systems Lab,Java Thread Pool實務與陷阱,http:/,Agenda,Threads 數量上限容量滿載的處理策略異常處理天有不測風雲,http:/,參考資料,Scott Oaks&Henry Wong(2004),Java Threads,3rd edition,OReilly.Brian Goetz et.al(2006),Java Concurrency in Practice,Addison-Wesley.,http:/,Threads數量上限,http:/,Demo 1,Native thread 上限(C/C+),http:/,Demo 2,VM thread 上限(Java),http:/,Java Concurrency Facilities,http:/,java.lang,Keyword:synchronized,java.lang,Java Threads,1st Way,http:/,n,main,Java Threads,2nd Way,http:/,Thread,main,Thread 容量滿載,Win32 APICreateThread()return NULLJavaThrow java.lang.OutOfMemoryError,http:/,容量滿載處理策略,http:/,http:/,MyWorker,main,Demo 3,固定容量的 Thread Pool,http:/,newFixedThreadPool,public class TestThreadPool private static final int POOL_SIZE=10;private static final int MAX_COUNT=10000;public static void main(String args)Executor pool=Executors.newFixedThreadPool(POOL_SIZE);for(int i=0;i MAX_COUNT;+i)pool.execute(new ExecutorDemo(i);class ExecutorDemo implements Runnable public ExecutorDemo(int sn)/*/public void run()/*/,http:/,Executors 懶人包,FixedThreadPool固定數量彈性不足CachedThreadPool自動伸縮(0Integer.MAX_VALUE)無法處理瞬間巨量,http:/,Demo 4,兼顧並行性與系統負載的 Thread Pool,http:/,ThreadPool DIY!,public class TestThreadPool private static final int MAX_POOL_SIZE=10;private static final int CORE_POOL_SIZE=5;private static final long THREAD_KEEPALIVE_TIME=60;private static final int QUEUE_SIZE=3;/public static void main(String args)Executor pool=Executors.newThreadPoolExecutor(CORE_POOL_SIZE,MAX_POOL_SIZE,THREAD_KEEPALIVE_TIME,TimeUnit.SECONDS,new ArrayBlockingQueue(QUEUE_SIZE),new ThreadPoolExecutor.CallerRunsPolicy();/*/,http:/,異常處理,http:/,Demo 5,當 Thread Pool 遇見 exception,http:/,他抓得住我?,public class TestThreadPool/public static void main(String args)Executor pool=Executors.newFixedThreadPool(POOL_SIZE);for(int i=0;i MAX_COUNT;+i)try pool.execute(new ExecutorDemo(i);catch(Throwable e)/*/class ExecutorDemo implements Runnable public ExecutorDemo(int sn)/*/public void run()throw new RuntimeException();,http:/,Demo 6,除錯版:安裝自訂的 Thread.UncaughtExceptionHandler,http:/,安裝自訂的 ThreadFactory,public class TestThreadPool/public static void main(String args)Executor pool=Executors.newThreadPoolExecutor(CORE_POOL_SIZE,MAX_POOL_SIZE,THREAD_KEEPALIVE_TIME,TimeUnit.SECONDS,new ArrayBlockingQueue(QUEUE_SIZE),new SafeThreadFactory(),new ThreadPoolExecutor.CallerRunsPolicy();/*/class SafeThreadFactory implements ThreadFactory/*下一頁*/,http:/,自訂 UncaughtExceptionHandler,class SafeThreadFactory implements ThreadFactory Overridepublic Thread newThread(Runnable r)Thread thread=new Thread(r);thread.setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler()Overridepublic void uncaughtException(Thread t,Throwable e)/);return thread;,http:/,Demo 7,懶人版:不讓 thread 丟出 exception,http:/,Thread 防呆策略,class ErrorProofThread implements Runnable/public void run()try/*main program logic here*/catch(Throwable ignore)/you can do nothing here,http:/,天有不測風雲,http:/,HeartbeatWatchdog,http:/,Any Questions?,http:/,