私はスレッディングの詳細を知りたいと思っていました。マルチスレッドアプリケーションとは何ですか?マルチスレッドアプリケーションとは何ですか?
答えて
Multithreading複数のスレッドが単一プロセスのコンテキスト内に存在することを可能にします。これらのスレッドはプロセスのリソースを共有しますが、独立して実行できます。スレッド型プログラミングモデルは、開発者に並列実行の有用な抽象化を提供します。しかし、この技術の最も興味深いアプリケーションは、マルチプロセッサシステムで並列実行を可能にする単一のプロセスに適用される場合です。単一processアプリケーションがより良い利用可能なハードウェア(複数のコア/プロセッサ)を使用することができ、多くの異なる「機能」executingconcurrentlyを有することができることを意味
。スレッドは、(彼らはshared memoryを持っている)それらの間で通信を行うことができますが、共有オブジェクト/メモリをaccesingときにそのhard problemはothersとすべてのスレッドbehave wellを持っています。長い操作を行うとき
スレッディングは、キャッチすべてのアプリケーションループを使用せずに、アプリケーションが応答を維持することができます。
例えば、スレッドなしのcopy
プログラムでは、コピーが完了するまで何もすることができません。
スレッド化は複雑で、長時間の独立した問題に役立ちますが、a lot more complexityになると、熟練した開発者でも難しくなります。彼は
スレッドとプロセスの実装では、別のオペレーティングシステムとは異なり、ほとんどの場合、スレッドは、プロセス内に含まれる言っ
threadを複数使用してその目的を達成するアプリケーションです。
ユーザと対話する必要があり、ほとんどのアプリケーションは、UIスレッドと作業スレッドのセットを持っているとして、多くの例があります。これは、アプリケーションが何らかのタスクを実行している間にUIを応答可能なままにするために行われます。
マルチスレッドアプリケーションは、物事をスピードアップするために、同時に複数のタスクを実行している利用しています。マルチスレッドでは、複数のCPUマシンを利用することもできます。
これは、複数のことを同時に行うことができるアプリケーションです。たとえば、Wordで文書を結んでいる場合は、キーボードに応答するスレッドがあります。スペルをチェックしているスレッドがあります。文法をチェックしているスレッドがあります。プログラムがクラッシュします。
それは、複数のthreadを使用するプログラムです。異なるスレッドは、共有メモリ構造にアクセスすることができる(通常、適切なsynchronization mechanisms、例えばlocksを使用することによって)。一例は、いくつかのファイルを同時にダウンロードするプログラムで、ダウンロードプロセスを高速化するために別のスレッドを使用してダウンロードします(それを実現するための高度な方法がありますが、これは単なる例です)。
マルチスレッドは、最近のコンピュータですべてのコアを使用する(複数のプロセッサを使用してサイファーを破るなどの)利点があるCPUバインドタスクでよく使用されます。
スレッドとプロセスの違いは、プロセス間で情報を共有するさまざまなメカニズムが存在するにもかかわらず(通常はスレッド間で情報を共有するよりもコストがかかります)、異なるプロセスが通常メモリとデータ構造を直接共有できないことです。広範なプログラミングおよび実行モデルとして
。複数のスレッドは同じプロセス内に存在し、メモリなどのリソースを共有できますが、異なるプロセスはこれらのリソースを共有しません。
スレッドのためには、プログラムのインスタンスが何であるかを知っておく必要があります。Windowsのペイントの例を取って実行します。それは、1つのインスタンスまたはペイントプログラムのプロセスです。 異なるウィンドウで複数の画像を開き、そのプログラムの複数のプロセスを作成するとき。 同様に、スレッドはプロセスの単位です。つまり、ペイントウィンドウが表示されますが、バックグラウンドには複数のスレッド(例:カラー、ブラシ、鉛筆など)があります。スレッドはプロセッサの負荷を軽減するためにあります
- 1. マルチスレッドアプリケーションでシングルトンを使用する危険性は何ですか?
- 2. QSqlモジュールとマルチスレッドアプリケーション
- 3. マルチスレッドアプリケーションとスレッドセーフリスト
- 4. マルチコアプロセッサでのマルチスレッドアプリケーション
- 5. WinAPIマルチスレッドアプリケーション
- 6. マルチスレッドアプリケーションでのBerkeley DB
- 7. マルチスレッドアプリケーションでHibernateを使用するには?
- 8. CURLはマルチスレッドアプリケーションでインターフェイスとクッキーを共有します
- 9. マルチスレッドアプリケーションのデバッグ
- 10. PyMySQL with Django、マルチスレッドアプリケーション
- 11. Berkeley DBのマルチスレッドアプリケーション
- 12. マルチスレッドアプリケーションのHTTPクライアント
- 13. マルチスレッドアプリケーションのGCOV
- 14. マルチスレッドアプリケーションのWCFプロキシシングルトン
- 15. マルチスレッドアプリケーションのSetCurrentDirectory
- 16. マルチスレッドアプリケーションでのFiredacの使用
- 17. マルチスレッドアプリケーションでopencv waitKey()を使用
- 18. マルチスレッドアプリケーションでのベクトルの使用
- 19. マルチスレッドアプリケーションでのアクセス違反、C++
- 20. シングルトンクラスはマルチスレッドアプリケーションで問題を作成しますか?
- 21. C#マルチスレッドアプリケーションはスレッドごとに作業ディレクトリを使用できますか?
- 22. Posixという名前のロックインタープロセスはマルチスレッドアプリケーションで動作しますか?
- 23. マルチスレッドアプリケーションのイベントハンドラの追加と削除
- 24. マルチスレッドアプリケーションでダブルバッファリングを同期する方法
- 25. マルチスレッドアプリケーションでファイルロギングを実行する方法
- 26. マルチスレッドアプリケーションがエラーチェーンでコンパイルに失敗する
- 27. マルチスレッドアプリケーションでMPIを使用する
- 28. Javaでマルチスレッドアプリケーションを開発する
- 29. freopen()を使用して、マルチスレッドアプリケーションのスレッドバイスログファイルでstdoutとstdinをリダイレクトできますか?
- 30. マルチスレッドアプリケーションでキャッシュパフォーマンスを測定するにはどうすればよいですか?
プロセス!=スレッド – ripper234