ホームページ  >  記事  >  Java  >  Javaの基礎を取り戻す(17):マルチスレッドについてのまとめ

Javaの基礎を取り戻す(17):マルチスレッドについてのまとめ

黄舟
黄舟オリジナル
2017-01-16 10:27:13904ブラウズ

Javaの基礎を取り戻す(Seventeen): マルチスレッドに関するまとめ

1. プロセス

1. ctrl+shift+esc タスクマネージャーウィンドウ 2. プログラムはオペレーティングシステム環境で実行されます。 CPU とメモリのリソースを占有するため、プログラムの開始からプログラムが終了するまで、このプロセスはプロセスと呼ばれます 3. プロセスはオペレーティング システム独自の概念であり、プロセス = 実行中のプログラム 4. 実行中のプログラムは、少なくとも 1 つのプログラムに対応します。プロセス 5. 一部のプログラムはマルチプロセス アーキテクチャ設計を採用します 7. プロセスは互いに独立しており、相互にアクセスしたりリソースを共有したりすることはできません

2. スレッド

1. 生産ラインファクトリ内のスレッドはスレッドと呼ばれます。 3. プロセスには、より小さな独立した実行単位であるスレッドが含まれます。 4. プロセスには、1 つのスレッド (シングルスレッド) または複数のスレッド (マルチスレッド) が含まれます。 5. QQ はプログラム (プロセス) です。 )、開いている各チャット ウィンドウはスレッドです。 6. 以前に作成したプログラムはすべてシングルスレッドであり、JVM は自動的に main メソッドをスレッド (生産ライン) として扱い、実行します。 7. スレッドは独立して実行できず、実行することもできません。プロセスとは別に、プロセス リソースをスレッド間で共有できます。 8. スレッドは独立しています

3. マルチスレッド プログラミング

1. 以前に作成したプログラムはすべてシングルスレッドであり、JVM は自動的にmain メソッドをスレッド (生産ライン) として実行します。 2. プログラム内に関数 A/B の 2 つがあり、マルチスレッド プログラミングを使用すると、関数 A を 1 つのスレッド (生産ライン) で実行できます。 1 つのスレッド (生産ライン) で実行 3. 画像を 1 つずつアップロード b. 複数の画像を同時にアップロード 4. マルチスレッドにより、CPU とメモリのリソースがさらに活用され、プログラムの実行効率が向上します。 . 工場


1. 学生は同時に執筆と映画鑑賞をすることができますか?脳は、書くことと映画を見ることを切り替えます 2. 映画は非常に高速で、脳は錯覚を生み出します 3. 本当の「同時性」は存在しません、CPU は非常に高速で、順番に、複数のスレッド間でランダムに切り替わります

5. Java はマルチスレッドをサポートします


1. Java には、ユーザー スレッド (ユーザー スレッド) とデーモン スレッド (デーモン スレッドまたはバックグラウンド サービス スレッド) の 2 種類のスレッドがあります。デーモン スレッドの役割は、GC スレッドなどの他のスレッドの実行にサービスを提供することです。 2. 方法 1: Thread クラスを継承する 方法 2: Runnable インターフェイスを実装する

6. 方法 1


1 では、これらのクラスのコードは実行できないため、これらのクラスはすべて通常のクラスです。生産ライン クラスではありません 2. Java は特別に生産ライン クラス java.lang.Thread クラスを提供します。このクラスのコードは同時に実行できます。 3. 手順: カスタマイズしたクラスに Thread クラスを継承させます。と定義したクラスが生産ラインクラスになりました。 カスタムクラスの run メソッドを書き換えて、同時に実行する必要があるコードを main メソッドに入れます。まず生産ラインを作成してから開始します。 start()

7. スレッドクラス


public long getId()、スレッドの作成時に生成されるスレッド番号 (スレッド ID) を取得します。スレッド ID は一意であり、生涯変更されません。 public Final void setName(String name), スレッドに名前を付けます。名前が付けられていない場合は、デフォルトが使用されます。形式は次のとおりです: Thread-0, Thread-1... public Final String getName(), スレッドの名前を取得しますpublic void start() を実行すると、スレッドが実行を開始し、JVM が自動的にスレッドの run() メソッドを呼び出します。 public static void sleep(long millis)、スレッドをミリ秒間スリープ (一時停止) させます public static Thread currentThread()、現在実行中のスレッド オブジェクトへの参照を取得します。 (方法 2 が使用されます)

8. マルチスレッド実行プロセス


1. JVM が最初に見つけたものは main メソッドであり、実行のために main のコードをスレッドに入れます。メインスレッド 2. さらに、手動で作成したスレッドを子スレッドと呼ぶこともできます。 3. プログラムは、すべてのスレッドの実行が完了するまで待機してから終了する必要があります。 欠点: メソッド 1 はスレッドを継承します。 class その後、他のクラスを継承することはできません。 利点: シンプルで実装が簡単です。 a. カスタム クラスは java.lang.Runnable インターフェイスを実装します。 b. 同時に実行する必要があるコードを実行します。メインの生産ライン (スレッド) で作成し、3 を開始します。方法 2 には方法 1 の欠点はありませんが、方法 10 よりも複雑です。スレッドの安全性の問題、

1 どのような状況でスレッドの安全性の問題が発生しますか。 ? a. 複数のスレッドが互いに独立している b. 複数のスレッドが共有リソースを動作または使用している 2. 複数のスレッドが同じ共有リソースを動作させているが、各スレッドは互いに独立しており、互いに接触していないため、次のような状況が発生します。データが同期的に更新されない場合、これはスレッドの安全性の問題です 3. 電車の切符を販売する場合 同時に実行されるコード: 10 枚の電車の切符を販売する 共有リソース: 10 枚の電車の切符 通常は属性として存在します

11. スレッドの安全性の問題を解決する方法

1. アイデア: 電車のトイレに 1 つずつ入る... 2. 同期ロック、専門用語ではモニターと呼ばれます3. モニターが自動的に構築されます。ロックはどこにでもあります 4. 実装するには 2 つの方法があります: 同期コード ブロック 同期メソッド

12. 同期コード ブロック

1. まず、どのコードをロックする必要があるかを分析します。 2. synchronized( Lock) { } 3. 複数のスレッド間で使用するロックは同じロックである必要があります

13. 同期方法

1. ロックが必要なコードを最初にメソッドに入れます 2. メソッドを入れます 同期メソッドになります public synchronized void sell(){ 共有データを操作するコードが同期が必要なコードです;} 3. 同期メソッドのロックはデフォルトでこれで固定です

14. 同期ロックのメリットとデメリット

同期の利点: 同期の出現により、マルチスレッドのセキュリティ問題が解決されます。 同期の欠点: スレッドが多数ある場合、各スレッドが同期のロックを判断するため、リソースが非常に消費され、実行速度が実質的に減少します。プログラムの効率。 (パフォーマンスとスレッドの安全性を同時に実現することはできません)

15. 詳細

1. 静的メソッドを同期メソッドに変更できますか? はい、ただしロックはこれではありません。ロードされたクラスのバイトコード ファイルは Student.class2 です。スレッド セーフティの問題の前提条件は、共有リソースが存在し、複数のスレッドが同じロックである必要があります


上記は、「Java の基礎を取り戻す (Seventeen): マルチスレッド」の概要です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) に注目してください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。