執行緒的建立方式
#1、繼承Thread類別實作多執行緒
2、覆寫Runnable ()介面實作多線程,而後同樣覆寫run()。推薦此方式
3、使用Callable和Future建立執行緒
相關影片教學推薦:java學習影片
##實例如下:1、繼承Thread類別實作多執行緒/* * 继承Thread类创建线程 * 1、重写run方法 * 2、创建thread类的实例,即创建线程对象 * 3、调用线程对象的start()来启动该线程 * 注意:Thread类的每个进程之间不能共享该实例变量;具有单继承局限 * */ public class StartThread extends Thread{ private int i; @Override //重写run方法 public void run() { // TODO Auto-generated method stub for(i=0;i<10;i++) { System.out.println(getName()+" "+i); } } public static void main(String[] args) { for(int i=0;i<10;i++) { System.out.println(Thread.currentThread().getName()+ " ,"+i); //创建thread类的实例 StartThread h1=new StartThread(); StartThread h2=new StartThread(); if(i==2) { //启动第一个进程 h1.start(); //启动第二个进程 h2.start(); } } } }
2、覆寫Runnable()介面實作多執行緒,而後同樣覆寫run()
定義Runnable ()介面的實作類,重寫Run()方法。 建立Runnable實作類別的實例,並以此實例作為Thread的target來建立Thread物件。這個Thread物件才是真正的執行緒物件透過呼叫執行緒物件的start()方法來啟動執行緒/*创建线程方式二 * 1、创建:实现Runnable+重写run * 2、启动:创建实现类对象+Thread对象+start * * 注意:推荐使用,避免单继承的局限性,优先使用接口 * 方便共享资源 * */ public class MyThread2 implements Runnable {//实现Runnable接口 public void run(){ //重写run方法 // TODO Auto-generated method stub //当线程类实现Runnable接口时 //如果想要获取当前线程,只能使用Thread.currentThread方法 for(;i<100;i++) { System.out.println(Thread.currentThread().getName()+" "+i); } } public class Main { public static void main(String[] args){ //启动线程1 //不像继承Thread类一样,直接可以实例化对象即可,Runnable接口必须要 //先创建实例,再将此实例作为Thread的target来创建Thread对象 //创建并启动线程 MyThread2 myThread=new MyThread2(); Thread thread=new Thread(myThread); thread().start(); //或者 new Thread(new MyThread2()).start(); } }
3、使用Callable和Future建立執行緒
和Runnable介面不一樣,Callable介面提供了一個call()方法作為執行緒執行體,call()方法比run()方法功能強大。 call()方法可以有回傳值call()方法可以宣告拋出例外public class Main { public static void main(String[] args){ MyThread3 th=new MyThread3(); //使用Lambda表达式创建Callable对象 //使用FutureTask类来包装Callable对象 FutureTask<Integer> future=new FutureTask<Integer>( (Callable<Integer>)()->{ return 5; } ); //实质上还是以Callable对象来创建并启动线程 new Thread(task,"有返回值的线程").start(); try{ //get()方法会阻塞,直到子线程执行结束才返回 System.out.println("子线程的返回值:"+future.get()); }catch(Exception e){ ex.printStackTrace(); } } }相關文章教學推薦:
以上是java中創建線程有幾種方式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Java如何緩解平台特定的問題? Java通過JVM和標準庫來實現平台無關性。 1)使用字節碼和JVM抽像操作系統差異;2)標準庫提供跨平台API,如Paths類處理文件路徑,Charset類處理字符編碼;3)實際項目中使用配置文件和多平台測試來優化和調試。

java'splatformentenceenhancesenhancesmicroservicesharchitecture byferingDeploymentFlexible,一致性,可伸縮性和便攜性。 1)DeploymentFlexibilityAllowsibilityAllowsOllowsOllowSorlowsOllowsOllowsOllowSeStorunonAnyPlatformwithajvM.2)penterencyCrossServAccAcrossServAcrossServiCessImplifififiesDeevelopmentandeDe

GraalVM通過三種方式增強了Java的平台獨立性:1.跨語言互操作,允許Java與其他語言無縫互操作;2.獨立的運行時環境,通過GraalVMNativeImage將Java程序編譯成本地可執行文件;3.性能優化,Graal編譯器生成高效的機器碼,提升Java程序的性能和一致性。

效率testjavaapplicationsforplatformcompatibility oftheSesteps:1)setUpautomatedTestingTestingActingAcrossMultPlatFormSusingCitoolSlikeSlikeJenkinSorgithUbactions.2)contuctualtemualtemalualTesteTESTENRETESTINGINREALHARTWARETOLEALHARDOELHARDOLEATOCATCHISSUSESUSEUSENINCIENVIRENTMENTS.3)schictcross.3)schoscross.3)

Java編譯器通過將源代碼轉換為平台無關的字節碼,實現了Java的平台獨立性,使得Java程序可以在任何安裝了JVM的操作系統上運行。

ByteCodeachievesPlatFormIndenceByByByByByByExecutedBoviratualMachine(VM),允許CodetorunonanyplatformwithTheApprepreprepvm.Forexample,Javabytecodecodecodecodecanrunonanydevicewithajvm

Java不能做到100%的平台獨立性,但其平台獨立性通過JVM和字節碼實現,確保代碼在不同平台上運行。具體實現包括:1.編譯成字節碼;2.JVM的解釋執行;3.標準庫的一致性。然而,JVM實現差異、操作系統和硬件差異以及第三方庫的兼容性可能影響其平台獨立性。

Java通過“一次編寫,到處運行”實現平台獨立性,提升代碼可維護性:1.代碼重用性高,減少重複開發;2.維護成本低,只需一處修改;3.團隊協作效率高,方便知識共享。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Dreamweaver CS6
視覺化網頁開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。