.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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
pthread_attr_tへの値の代入に...
-
WaitForSingleObjectの使い方に...
-
Macターミナルで実行中のプログ...
-
家電製品の電力周波数を変える機械
-
アセンブラ言語の数字を数値に...
-
スーパーのレジで並んでいたら...
-
緯度、経度の 10進法と 60進法...
-
Mac 乗数の入力方法
-
バックグラウンドのプロセスの...
-
怪しいプロセス教えてください。
-
C言語で、メモリを解放しないで...
-
VBSからbat実行(WMI)して戻り値...
-
VBAを使って二進法計算
-
Trend Micro Anti-Malware Solu...
-
フレームワーク「4.8.1」で、[S...
-
組み込みマイコンでのソフトウ...
-
C/C++→JAVAに変換するツール
-
スーパーのレジ待ち
-
ソケットでクライアントのipア...
-
動的メモリとexit(C言語)
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VC++スレッドの正しい終了のさ...
-
スレッドの監視方法について
-
Windows上で、シグナル(SIGTERM...
-
WaitForSingleObjectの使い方に...
-
スレッドの安全な終了のさせ方
-
スレッドの終了の仕方
-
MFC通信プログラムマルチスレッ...
-
マルチスレッドプログラミング...
-
別スレッドからメインダイアロ...
-
マルチスレッドについて
-
.NetのBackgroundWorkerクラス...
-
スレッドにて同一メモリの書き...
-
別スレッドのデータを受信できない
-
同一スレッドで、ロックをかけ...
-
マルチスレッドの同期方法
-
スレッドの終了はどうやるんで...
-
待機関数(WaitForMultipleObjec...
-
msec単位のWait Timerが作れない!
-
CWnd::OnTimerのスレッドの取得
-
_beginthreadexで生成したスレ...
おすすめ情報