この記事では、Java でスレッドを作成する 3 つの方法 (コード) を紹介します。必要な方は参考にしていただければ幸いです。
Java でスレッドを作成する場合は、通常、次の 3 つの方法があります。
#Thread クラスを継承します。 #implementation Runnable インターフェイス;
Callable と Future を使用してスレッドを作成します。
- 1. Thread クラスを継承する
Thread クラスを継承する場合は、run メソッドをオーバーライドし、必要なタスクを定義する必要があります。 run メソッドで実行されます。 class MyThread extends Thread{
private static int num = 0;
public MyThread(){
num++;
}
@Override
public void run() {
System.out.println("主动创建的第"+num+"个线程");
}
}
独自のスレッド クラスを作成した後、スレッド オブジェクトを作成し、start() メソッドを通じてスレッドを開始できます。 run() メソッドは、スレッドを開始するために呼び出されるわけではないことに注意してください。 run メソッドが呼び出される場合、それはメインスレッドで run メソッドを実行することと同じになります。現時点では、通常のメソッド呼び出しと何の違いもありません。定義されたタスクを実行するために新しいスレッドが作成されます。
public class Test { public static void main(String[] args) { MyThread thread = new MyThread(); thread.start(); } } class MyThread extends Thread{ private static int num = 0; public MyThread(){ num++; } @Override public void run() { System.out.println("主动创建的第"+num+"个线程"); } }
上記のコードでは、start() メソッドを呼び出すことで、新しいスレッドが作成されます。 start() メソッド呼び出しと run() メソッド呼び出しの違いを区別するには、次の例を参照してください。
public class Test { public static void main(String[] args) { System.out.println("主线程ID:"+Thread.currentThread().getId()); MyThread thread1 = new MyThread("thread1"); thread1.start(); MyThread thread2 = new MyThread("thread2"); thread2.run(); } } class MyThread extends Thread{ private String name; public MyThread(String name){ this.name = name; } @Override public void run() { System.out.println("name:"+name+" 子线程ID:"+Thread.currentThread().getId()); } }
実行結果:
## 出力結果から次の結論が導き出されます。
1) thread1 と thread2 のスレッド ID は異なり、thread2 とメイン スレッド ID は同じです。これは、run メソッドを呼び出していることを示しています。新しいスレッドは作成されませんが、メインスレッドで run メソッドを直接実行することは通常のメソッド呼び出しと変わりません。
2. Runnable インターフェイスの実装
Java でスレッドを作成するときに Thread クラスを継承するだけでなく、Runnable インターフェイスを実装することで同様の機能を実装することもできます。 Runnable インターフェイスを実装するには、その run メソッドをオーバーライドする必要があります。以下は例です:
public class Test { public static void main(String[] args) { System.out.println("主线程ID:"+Thread.currentThread().getId()); MyRunnable runnable = new MyRunnable(); Thread thread = new Thread(runnable); thread.start(); } } class MyRunnable implements Runnable{ public MyRunnable() { } @Override public void run() { System.out.println("子线程ID:"+Thread.currentThread().getId()); } }Runnable の中国語の意味はその名前が示すように、Runnable インターフェイスを実装することでサブタスクを定義し、そのサブタスクを渡します。実行用のスレッドに。このメソッドは、Thread クラスのパラメータとして Runnable を使用し、次に Thread の start メソッドを使用してサブタスクを実行する新しいスレッドを作成する必要があることに注意してください。 Runnable の run メソッドを呼び出した場合、この通常のメソッド呼び出しでは新しいスレッドは作成されません。 実際、Thread クラスの実装ソース コードを見ると、Thread クラスが Runnable インターフェイスを実装していることがわかります。 Java では、これら 2 つのメソッドを使用してサブタスクを実行するスレッドを作成できます。どちらのメソッドを選択するかは、ユーザー自身のニーズによって異なります。 Thread クラスを直接継承することは、Runnable インターフェイスを実装するより簡単に見えるかもしれませんが、Java では単一の継承しか許可されないため、カスタム クラスが他のクラスを継承する必要がある場合、Runnable インターフェイスの実装を選択することしかできません。
3. Callable と Future を使用してスレッドを作成する
Runnable インターフェイスとは異なり、Callable インターフェイスはスレッドの実行本体として call() メソッドを提供します。 ) メソッド run() メソッドよりも強力です。戻り値を持つスレッドを作成して開始する手順は次のとおりです。
Callable インターフェイスの実装クラスを作成し、call() メソッドを実装します。次に、インスタンスの実装クラスを作成します (java8 以降では、Lambda 式を直接使用して Callable オブジェクトを作成できます)。- FutureTask クラスを使用して Callable オブジェクトをラップします。FutureTask オブジェクトは、Callable オブジェクトの call() メソッドの戻り値をカプセル化します。 ##FutureTask オブジェクトを使用する Thread オブジェクトのターゲットとしてスレッドを作成して開始します (FutureTask は Runnable インターフェイスを実装しているため)
- FutureTask オブジェクトの get() メソッドを呼び出して取得します子スレッドの実行終了後の戻り値
- 次は例です:
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; } ); new Thread(task,"有返回值的线程").start();//实质上还是以Callable对象来创建并启动线程 try{ System.out.println("子线程的返回值:"+future.get());//get()方法会阻塞,直到子线程执行结束才返回 }catch(Exception e){ ex.printStackTrace(); } } }
スレッドを作成する 3 つの方法の比較: - Runnable の実装と Callable インターフェイスの実装 これらのメソッドは基本的に同じですが、後者には call() メソッドの実行時に戻り値があり、後者には run() メソッドの実行時に戻り値がない点が異なります。したがって、この 2 つのメソッドは Thread クラスを継承するメソッドと同じです。
この方法では、複数のスレッドがターゲット オブジェクトを共有できます。これは、複数のスレッドが同じリソースを処理する状況に非常に適しています。
- ただし、現在のスレッドにアクセスする必要がある場合、プログラミングは少し複雑です。Thread.currentThread() メソッドを呼び出す必要があります。
- #Thread クラスを継承するスレッド クラスは、他の親クラスから継承することはできません (Java 単一継承の決定)。
- PS: 一般的には、インターフェイスを実装してマルチスレッドを作成することをお勧めします
以上がJava でスレッドを作成する 3 つの方法 (コード) の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 中国語版
中国語版、とても使いやすい

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
