簡單了解Java多線程實現(xiàn)的四種方式
第一種方式為繼承Thread類然后重寫run方法再調用start方法,因為java為單繼承多實現(xiàn),所以不建議使用這種方式,代碼如下:
public class Demo extends Thread{
public static void main(String[] args) {
new Demo().start();
}
@Override
public void run() {
System.out.println("繼承Thread類實現(xiàn)多線程");
}
}
第二種為實現(xiàn)Runnable接口方式,該方式用的較多,代碼如下:
public class Demo2 implements Runnable{
public static void main(String[] args) {
new Thread(new Demo2()).start();
}
@Override
public void run() {
System.out.println("實現(xiàn)Runnable接口的多線程");
}
}
第三種為實現(xiàn)Callable接口方式,該方式run方法具有返回值,代碼如下:
public class Demo3 implements Callable {
public static void main(String[] args) throws ExecutionException, InterruptedException {
FutureTask task=new FutureTask(new Demo3());
new Thread(task).start();
System.out.println(task.get());
}
@Override
public String call() throws Exception {
return "實現(xiàn)Callable接口的多線程";
}
}
第四種是采用線程池的方式,代碼如下:
public class Demo4 {
public static void main(String[] args) {
ExecutorService executorService= Executors.newCachedThreadPool();
executorService.execute(new Runnable() {
@Override
public void run() {
System.out.println("線程池實現(xiàn)多線程");
}
});
executorService.shutdown();
}
}
從上面我們可以看出線程的調用都是采用start()方法,那么調用直接調用run()方法其實也是可以輸出結果的,但是有著本質的區(qū)別,因為調用start()方法會使得當前線程的數(shù)量增加,而單純得調用run()方法是不會的,在start()方法的內部其實包含了調用run()方法。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Java并發(fā)LinkedBlockingQueue源碼分析
這篇文章主要為大家介紹了Java并發(fā)LinkedBlockingQueue源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02
spring boot org.junit.jupiter.api不存在的解決
這篇文章主要介紹了spring boot org.junit.jupiter.api不存在的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
SpringBoot使用slf4j日志并輸出到文件中的操作方法
這篇文章主要介紹了SpringBoot使用slf4j日志并輸出到文件中,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08
jdk中keytool的使用以及如何提取jks文件中的公鑰和私鑰
JKS文件由公鑰和密鑰構成利用Java?Keytool工具生成的文件,它是由公鑰和密鑰構成的,下面這篇文章主要給大家介紹了關于jdk中keytool的使用以及如何提取jks文件中公鑰和私鑰的相關資料,需要的朋友可以參考下2024-03-03

