import java.util.HashMap; import java.util.Map; import java.util.Map.Entry; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; /** * java 線程池實例 * @author lixin */ public class Test { public static void main(String[] args) { //採用固定大小線程池 ExecutorService exe = Executors.newFixedThreadPool(2); //要處理的數據 Map<String, String> map = new HashMap<String, String>(); map.put("a", "aaaa"); map.put("b", "bbbb"); map.put("c", "cc"); map.put("d", "d"); map.put("e", "e"); String m; int i = 0; for(Entry<String, String> entry: map.entrySet()) { m=entry.getValue(); //調用線程池 exe.execute(new MyThread(i,exe,m)); i++; } } } class MyThread implements Runnable { int id; ExecutorService exe; //m即實例對象 String m = ""; MyThread(int id, ExecutorService exe,String m) { this.exe = exe; this.id = id; this.m = m; } public void run() { //業務處理 System.out.println("exe info:" + exe.toString()+"start"); try { Thread.sleep(5000L); } catch (Exception e) { System.out.println(e); } System.out.println(id + "end"); } }