Java多線程是Java高級特性之一,透過多線程,我們可以實現多任務同時協同工作,在一定情況下提升程式效率,但是Java多線程仍要慎重使用。 (建議學習:java課程)
首先第一點,Java多執行緒需要較高的編碼技巧,一旦使用不當就會造成程式錯誤,執行緒間惡意競爭死鎖,導致程式卡死。
其二,濫用多執行緒可能會造成某些關鍵參數紊亂,這時需要做好執行緒間的同步和鎖定管理。
其三,線程的切換是需要額外的代價的,也就是常說的“上下文切換”,如果使用不當,不僅不會提高效率,反而會造成效率的急劇降低。
Java多執行緒的實作方式
繼承Thread來實作多執行緒
Java提供了一個超類別Thread給我們來extends,一旦繼承了它,就可以透過override 其中的run方法,來實作多執行緒,具體程式碼如下:
package com.dingtao.test; import java.io.*; public class MyThread extends Thread{ @Override public void run() { System.out.println(Thread.currentThread().getName()); } public static void main(String[] args) throws IOException { Thread t1 = new MyThread(); Thread t2 = new MyThread(); t1.start(); t2.start(); } }
透過實作Runnable介面來實作
#因為對於某些類別來說,他們不能繼承Thread來實現多線程,因為Java規定同時只能繼承一個超類,但是卻可以同時實作多個接口,因此Runnable就更格外受歡迎。具體程式碼如下:
package com.dingtao.test; import java.io.*; public class MyThread implements Runnable{ @Override public void run() { System.out.println(Thread.currentThread().getName()); } public static void main(String[] args) throws IOException { Thread t1 = new Thread(new MyThread()); Thread t2 = new Thread(new MyThread()); t1.start(); t2.start(); } }
透過Callable來實作一個Thread
具體程式碼如下:
package com.dingtao.test; import java.util.concurrent.Callable; import java.util.concurrent.FutureTask; public class MyThread implements Callable<Integer>{ public static void main(String[] args){ MyThread t1 = new MyThread(); FutureTask<Integer> future = new FutureTask<Integer>(t1); new Thread(future,"呵呵哒").start(); } @Override public Integer call() throws Exception { System.out.println(Thread.currentThread().getName()); return null; } }
以上是java如何實作多執行緒的詳細內容。更多資訊請關注PHP中文網其他相關文章!