Java中線程Thread的三種方式和對比
介紹
多線程主要的作用就是充分利用cpu的資源。單線程處理,在文件的加載的過程中,處理器就會一直處於空閑,但也被加入到總執行時間之內,串行執行切分總時間,等於每切分一個時間*切分後字符串的個數,執行程序,估計等幾分鐘能處理完就不錯瞭。而多線程處理,文件加載與差分過程中
一、Java實現多線程的三種方式
1.繼承Thread
通過Thread繼承,並重寫run方法來實現多線程,案例如下:
public class ThreadPattern extends Thread { @Override public void run() { System.out.println("繼承Thread當前執行線程"+Thread.currentThread().getName()); } } // 測試 public void threadTest() throws ExecutionException, InterruptedException { ThreadPattern pattern = new ThreadPattern(); pattern.start(); }
2.實現Runnable接口
Runable的實現類作為Thread的構造參數,來實現多線程,案例如下:
public class RunnablePattern implements Runnable{ @Override public void run() { System.out.println("實現Runnable方式,當前執行線程"+Thread.currentThread().getName()); } } // 測試 public void runnableTest() throws ExecutionException, InterruptedException { RunnablePattern runnablePattern = new RunnablePattern(); Thread thread = new Thread(runnablePattern); thread.start(); }
3.實現Callable接口
實現Callable接口重寫call()方法,然後包裝成FutureTask,然後再包裝成Thread,其實本質都是實現Runnable 接口。案例如下:
public class CallablePattern implements Callable { @Override public Object call() throws Exception { System.out.println("實現Callable方式,當前執行線程"+Thread.currentThread().getName()); return "1"; } } // 測試 public void callableTest() throws ExecutionException, InterruptedException { CallablePattern callablePattern = new CallablePattern(); FutureTask<String> futureTask = new FutureTask<>(callablePattern); new Thread(futureTask).start(); }
二、總結對三種使用方式的對比
1、Thread:繼承的方式,由於java的單一繼承機制。就無法繼承其他類,使用起來就不夠靈活。
2、Runnable:實現接口,比Thread類更加的靈活,沒有單一繼承的限制。
3、Callable:Thread和runnable都重寫run方法並且沒有返回值,Callable是重寫call()方法並且有返回值,借助FutureTask類來判斷線程是否執行完畢或者取消線程執行, 一般情況下不直接把線程體的代碼放在Thread類中,一般通過Thread類來啟動線程。
4:Thread類實現Runnable ,Callable封裝成FutureTask,FutureTask實現RunnableFuture,RunnableFuture實現Runnable,所以Callable也算是一種Runnable,所以實現的方式本質都是Runnable實現。
到此這篇關於Java中線程Thread的三種方式和對比的文章就介紹到這瞭,更多相關Java 線程Thread內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- None Found