更新時間:2020-11-09 17:24:04 來源:動力節(jié)點 瀏覽1247次
實現(xiàn)多線程是采用一種并發(fā)執(zhí)行機制,從軟件或者硬件上實現(xiàn)多個線程并發(fā)執(zhí)行。Java多線程實現(xiàn)方式主要有四種:繼承Thread類、實現(xiàn)Runnable接口、實現(xiàn)Callable接口通過FutureTask包裝器來創(chuàng)建Thread線程、使用ExecutorService、Callable、Future實現(xiàn)有返回結(jié)果的多線程。
其中前兩種方式線程執(zhí)行完后都沒有返回值,后兩種是帶返回值的,接下來我們一一看一下這4種java多線程實現(xiàn)方式。
1、繼承Thread類創(chuàng)建線程
Thread類本質(zhì)上是實現(xiàn)了Runnable接口的一個實例,代表一個線程的實例。啟動線程的唯一方法就是通過Thread類的start()實例方法。start()方法是一個native方法,它將啟動一個新線程,并執(zhí)行run()方法。這種方式實現(xiàn)多線程很簡單,通過自己的類直接extend Thread,并復(fù)寫run()方法,就可以啟動新線程并執(zhí)行自己定義的run()方法。例如:
public class MyThread extends Thread {
public void run() {
System.out.println("MyThread.run()");
}
}
MyThread myThread1 = new MyThread();
MyThread myThread2 = new MyThread();
myThread1.start();
myThread2.start();
2、實現(xiàn)Runnable接口創(chuàng)建線程
如果自己的類已經(jīng)extends另一個類,就無法直接extends Thread,此時,可以實現(xiàn)一個Runnable接口,如下:
public class MyThread extends OtherClass implements Runnable {
public void run() {
System.out.println("MyThread.run()");
}
}
為了啟動MyThread,需要首先實例化一個Thread,并傳入自己的MyThread實例:
MyThread myThread = new MyThread();
Thread thread = new Thread(myThread);
thread.start();
事實上,當(dāng)傳入一個Runnable target參數(shù)給Thread后,Thread的run()方法就會調(diào)用target.run(),參考JDK源代碼:
public void run() {
if (target != null) {
target.run();
}
}
3、實現(xiàn)Callable接口通過FutureTask包裝器來創(chuàng)建Thread線程
Callable接口(也只有一個方法)定義如下:
public interface Callable
V call() throws Exception; }
public class SomeCallable
@Override
public V call() throws Exception {
// TODO Auto-generated method stub
return null;
}
}
Callable
//由Callable
FutureTask
//注釋:FutureTask
//由FutureTask
Thread oneThread = new Thread(oneTask);
oneThread.start();
//至此,一個線程就創(chuàng)建完成了。
4、使用ExecutorService、Callable、Future實現(xiàn)有返回結(jié)果的線程
ExecutorService、Callable、Future三個接口實際上都是屬于Executor框架。返回結(jié)果的線程是在JDK1.5中引入的新特征,有了這種特征就不需要再為了得到返回值而大費周折了。而且自己實現(xiàn)了也可能漏洞百出。
可返回值的任務(wù)必須實現(xiàn)Callable接口。類似的,無返回值的任務(wù)必須實現(xiàn)Runnable接口。
執(zhí)行Callable任務(wù)后,可以獲取一個Future的對象,在該對象上調(diào)用get就可以獲取到Callable任務(wù)返回的Object了。get方法是阻塞的,即:線程無返回結(jié)果,get方法會一直等待。
再結(jié)合線程池接口ExecutorService就可以實現(xiàn)傳說中有返回結(jié)果的多線程了。
以上就是4種Java多線程實現(xiàn)方式,總的來說,就是把一個處理器劃分為若干個短的時間片,每個時間片依次輪流地執(zhí)行處理各個應(yīng)用程序,由于一個時間片很短,相對于一個應(yīng)用程序來說,就好像是處理器在為自己單獨服務(wù)一樣,從而達到多個應(yīng)用程序在同時進行的效果 。
初級 202925
初級 203221
初級 202629
初級 203743