![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
![](http://oshiete.xgoo.jp/images/v2/common/profile/M/noimageicon_setting_09.png?5a7ff87)
.NetのBackgroundWorkerクラスについての質問です。
BackgroundWorkerクラスなるものを知るまでは、Threadクラス等でマルチスレッドを実装していました。
MSDNを読みながら、実装自体は非常に簡単に出来ましたが、このバックグラウンドスレッドとは如何なるものなのでしょうか。
フォアグラウンド/バックグラウンドタスクであるならば、CPU優先度(占有度)により、その実行タイミングが左右されるのは容易に想像できるのですが、バックグラウンドスレッドは、どのようにCPU優先度が決まるのでしょうか。(デスクトップWindowsでは、あまり機会がないかとは思いますが、リアルタイムな処理,クリティカルな処理を同クラスによって実装していいのか判断できませんでした。)
Formクラスから生成されるということは、Formウィンドウのメッセージスレッドをフォアグラウンドスレッドとし、そのバックグラウンドスレッドといった関係になるのでしょうか。(Formウィンドウのアイドル時間にバックグラウンドスレッドが実行されるという理解であっていますでしょうか。)
また、スレッド内でのsleep()呼出しで、スレッドは別スレッドに制御が切り替わるハズだったと思いますが、バックグラウンドスレッド内でThread::Sleep()呼出しをした場合、必ず、フォアグラウンドスレッドに制御が移り、フォアグラウンドスレッドのアイドル時間が発生するまで、バックグラウンドスレッドへ制御が戻ることがないということでしょか。(各スレッドへいつ制御が移るのか分かりませんでした。)
ご回答、または、参考サイト,参考文献等、教えてくださると非常に助かります。
No.2ベストアンサー
- 回答日時:
>sleep()ではなく、スレッドが待機状態(windows apiでいう、WaitForSingleObject
等による待機状態)であった場合も、変わらず、スレッド実行されてしまうので
しょうか。
>バックグラウンドスレッドを複数生成し、シグナル送信で、次々と実行スレッド
を変えていければ良いかなぁと考えていますが、回答頂いた内容から想像すると、
割当てられた時間待機しているだけになってしまうような気がします。
WaitForSingleObject等の場合、指定時間ではなくオブジェクトがシグナル状態になるまで待機するものです。こちらを使った場合は、割り当てられた時間待機しているだけということはなくなります。
オブジェクトにはミューテックス、セマフォ、イベントなどの同期オブジェクトのほか、プロセスやスレッド等も対象とすることができます。
>仮に、あるプロセスにフォアグラウンドスレッドA,バックグラウンドスレッドa1,a2しか存在しないとして、
>1.A,a1,a2を待機状態へ
>2.A,a1,a2のタイムスライスが、他のプロセスへ渡される
>3.a1へシグナル送信
>4.a1実行
>windows系osである以上、他プロセスとのCPUの取り合いが、ある程度までしかコントロール出来ないのは、あきらめています。
次に実行するスレッドの決定は、優先度を加味したラウンドロビン方式だったかと思います。
上記のような動作をある程度実現するには、先のWaitForSingleObject系とイベントを組み合わる方法になるかと思います。
あと、プロセスにも優先度があります。この動作をできる限り優先的に行いたいのであれば、プロセス優先度を通常より高く設定しておく方法が考えられます。これを行えば他のプロセスより優先的にタイムスライスを割り当てられるようになります。ただし、この設定を行った場合、他の操作が遅くなったり、場合によっては動作停止している状態に陥る恐れもあります。
優先度の定義については参考URLが表になっていましたので、参考に挙げておきます。(英語ですが・・・)
参考URL:http://msdn.microsoft.com/en-us/library/ms685100 …
お礼を申し上げるのが、遅れ申し訳ありませんでした。
今回windowsである程度のリアルタイム性を保持した機構を検討しており、勉強すべき点が多くあり、質問させて頂きました。
とりあえず、本件は、これでクローズとさせて頂きますが、また、お力を借りる時は、よろしくお願い致します。
No.1
- 回答日時:
>BackgroundWorkerクラスなるものを知るまでは、Threadクラス等でマルチスレッドを実装していました。
>MSDNを読みながら、実装自体は非常に簡単に出来ましたが、このバックグラウンドスレッドとは如何なるものなのでしょうか。
BackgroundWorkerクラスは一種のスレッドクラスですが、Threadクラスとは違ってフォームデザインモードで配置できます。
>フォアグラウンド/バックグラウンドタスクであるならば、CPU優先度(占有度)により、その実行タイミングが左右されるのは容易に想像できるのですが、バックグラウンドスレッドは、どのようにCPU優先度が決まるのでしょうか。(デスクトップWindowsでは、あまり機会がないかとは思いますが、リアルタイムな処理,クリティカルな処理を同クラスによって実装していいのか判断できませんでした。)
CPU優先度というのはスレッド優先度のことでしょうか?ThreadクラスではPriorityプロパティで設定できますが、BackgroundWorkerクラスではそれに該当するものがありません。確かNormal優先度だったかと思います。
>Formクラスから生成されるということは、Formウィンドウのメッセージスレッドをフォアグラウンドスレッドとし、そのバックグラウンドスレッドといった関係になるのでしょうか。(Formウィンドウのアイドル時間にバックグラウンドスレッドが実行されるという理解であっていますでしょうか。)
そのFormクラスがメインフォームであるのならば、Formウィンドウのメッセージスレッドがフォアグラウンドスレッドになっていますが、そのフォームがサブフォームであり、別のスレッドから生成されている場合はフォアグラウンドスレッドにはなりません。
また、BackgroundWorkerクラスは内部でスレッドを生成して実行要求があるまで待機しつづけています。実行状態になった場合、Formメッセージスレッドがいくら忙しくても、黙々とバックグラウンド処理をし続けています。そのため、オブジェクトをFormが所有しているだけで、スレッド間での関連性はありません。
>また、スレッド内でのsleep()呼出しで、スレッドは別スレッドに制御が切り替わるハズだったと思いますが、バックグラウンドスレッド内でThread::Sleep()呼出しをした場合、必ず、フォアグラウンドスレッドに制御が移り、フォアグラウンドスレッドのアイドル時間が発生するまで、バックグラウンドスレッドへ制御が戻ることがないということでしょか。(各スレッドへいつ制御が移るのか分かりませんでした。)
各スレッドにはタイムスライスが設定されており、CPUでその時間内スレッドを実行すると中断され、別のスレッドに切り替わって実行がされてゆきます。
Sleepメソッドは、そのスレッドの実行を指定時間中断するものですが、同時にそのスレッドに残っているタイムスライスを放棄する機能もあります。タイムスライスを放棄しているので、そのスレッドが即時中断され、別のスレッドが実行されることになります。ただし、スレッドが中断されたあと、次に実行されるスレッドがどれになるかはわかりません。別のプロセスが所有するスレッドかもしれないからです。
なので、「Sleepメソッドを呼び出したらフォアグラウンドスレッドに実行が移る」というのは間違いです。
返信が遅れ、申し訳ありません。
回答ありがとうございます。
概ね、予想していた通りでしたが、バックグラウンドスレッドの実行時間、及び、中断タイミングについては、理解が間違っており、参考になりました。
フォアグラウンド/バックグラウンドスレッドに関わらず、各々のスレッドにおいて、必要な時には、割り当てられたCPU実行時間を有効活用したいと考えています。(RealTime unixのマルチタスクをイメージして頂けると、一番近いです。)
sleep()ではなく、スレッドが待機状態(windows apiでいう、WaitForSingleObject等による待機状態)であった場合も、変わらず、スレッド実行されてしまうのでしょうか。
バックグラウンドスレッドを複数生成し、シグナル送信で、次々と実行スレッドを変えていければ良いかなぁと考えていますが、回答頂いた内容から想像すると、割当てられた時間待機しているだけになってしまうような気がします。
仮に、あるプロセスにフォアグラウンドスレッドA,バックグラウンドスレッドa1,a2しか存在しないとして、
1.A,a1,a2を待機状態へ
2.A,a1,a2のタイムスライスが、他のプロセスへ渡される
3.a1へシグナル送信
4.a1実行
windows系osである以上、他プロセスとのCPUの取り合いが、ある程度までしかコントロール出来ないのは、あきらめています。
質問に質問を重ねる形になり、申し訳ありません。
タスク,スレッドのCPU割当て方法がどうなっているのか知りたいのですが、参考になるサイト、本等、お教え願えますと、助かります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- システム CPUの問題について 2 2022/07/09 12:04
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- Java java 次の機能を有するメソッドを自クラスに作成し、実装したいです。 機能 名前判定機能 →名前が 3 2022/06/16 16:08
- PHP if(preg_match("/[^0-9]/",$gu_d)){意味を教えてください。 1 2022/05/06 05:37
- Java javaの質問です 次の機能を有するメソッド4つを自クラスに作成し、実装したいです 【機能】 足し算 1 2022/06/15 17:49
- ビデオカード・サウンドカード 1つのマザボでAMD&NVIDIAを同時使用できますか? 3 2022/04/22 14:36
- PHP アップロード画像数でCSSを分けることに成功したのですが、画像の横に文字を並べることが出来ません。 3 2023/07/28 17:16
- Java java 飾子を付けること(public static・・・) ・コンソールへの出力処理はmainメ 2 2022/06/16 19:34
- 予備校・塾・家庭教師 浪人生です。 予備校の授業で、予習復習の時間をしっかりとって理解もできてるのですがどうしても時間が余 1 2022/04/28 22:26
- その他(悩み相談・人生相談) 将来伸びる高校生って? 1 2022/05/14 14:39
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
スレッドの監視方法について
-
スレッドの終了の仕方
-
Windows上で、シグナル(SIGTERM...
-
C# スレッドから親ウィンドウへ...
-
スレッドの安全な終了のさせ方
-
同一スレッドで、ロックをかけ...
-
スレッド一覧の取得
-
複数スレッドを動作させるのに...
-
WindowAPI スレッドのステータ...
-
C# スレッド終了の監視について
-
DirectX LPDIRECT3DDEVICE9のマ...
-
CWnd::OnTimerのスレッドの取得
-
VC++スレッドの正しい終了のさ...
-
別スレッドのデータを受信できない
-
Win32APIでのスレッド処理
-
別スレッドからのフォームのテ...
-
マルチスレッドでブレイクポイ...
-
WaitForSingleObjectの使い方に...
-
WaitForSinbleObjectについて
-
pThreadのメインでなぜsleep?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VC++スレッドの正しい終了のさ...
-
WaitForSingleObjectの使い方に...
-
マイクロソフトedge で5チャン...
-
スレッドの安全な終了のさせ方
-
スレッドの終了はどうやるんで...
-
スレッドにて同一メモリの書き...
-
スレッドの監視方法について
-
マルチスレッドについて
-
スレッドの終了の仕方
-
Linuxでスレッド優先度って変え...
-
Windows上で、シグナル(SIGTERM...
-
LinuxでDoEvents()同等機能
-
VB2005 シリアル通信のClose処理
-
待機関数(WaitForMultipleObjec...
-
マルチスレッドプログラミング...
-
_beginthreadexで生成したスレ...
-
msec単位のWait Timerが作れない!
-
別スレッドからメインダイアロ...
-
マルチスレッドのスレッド数を...
-
.NetのBackgroundWorkerクラス...
おすすめ情報