「[[マイクロソフト系技術情報 Wiki>http://techinfoofmicrosofttech.osscons.jp/]]」は、「[[Open棟梁Project>https://github.com/OpenTouryoProject/]]」,「[[OSSコンソーシアム .NET開発基盤部会>https://www.osscons.jp/dotNetDevelopmentInfrastructure/]]」によって運営されています。

-[[戻る>プログラミング]]

* 目次 [#lc8e4fa8]
#contents

*概要 [#u945caf6]
非同期処理の実装方式について。

*非同期処理の実装史 [#z67fe1ac]
**1. Thread、ThreadPool [#c79c02e2]
従来の、マルチスレッド・プログラミング。

-スレッドの並列実行はOSが裏で無意識にしてくれていた。
--タイムスライスで細切れ/ラウンドロビンで論理的に並列実行。
--CPUのコア数に応じて、物理的に並列実行。

-しかし、以下の処理は意識的に実装する必要があった。
--非同期処理をスレッド関数として分離して実装する。
--スレッド関数を作成したワーカースレッドに渡す。
--スレッド関数の結果をメインスレッドで待ち合わせる。

**2. APM、EAP ([[Control.Invoke、.BeginInvoke]]) [#x24ad95f]
-「Windowsメッセージングキュー([[Control.Invoke、.BeginInvoke]])」による方式。

--APM(Asynchronous Programming Model)~
[[Control.Invoke>http://www.atmarkit.co.jp/ait/articles/0506/17/news111.html]]
--EAP(Event-based Asynchronous Pattern)~
[[BackgroundWorker>http://www.atmarkit.co.jp/fdotnet/dotnettips/436bgworker/bgworker.html]]

-この非同期処理方式では、

--Foregroundスレッド(UIスレッド)からBackgroundスレッドを使用して非同期処理を実行し、
--非同期処理の実行結果をUIスレッドを使用して画面に反映させる事ができる。

-上記をラップするライブラリ
--[[BackgroundWorker クラス>https://msdn.microsoft.com/ja-jp/library/system.componentmodel.backgroundworker.aspx]]
---方法 : バックグラウンド ワーカーを使用する~
http://www.atmarkit.co.jp/fdotnet/dotnettips/436bgworker/bgworker.html
---BackgroundWorkerクラスを使用して進行状況ダイアログを作成する: .NET Tips: C#, VB.NET~
http://dobon.net/vb/dotnet/programing/progressdialogbw.html

--Open棟梁の「[[非同期呼出フレームワーク>https://opentouryo.osscons.jp/index.php?%E9%9D%9E%E5%90%8C%E6%9C%9F%E5%91%BC%E5%87%BA%E3%83%95%E3%83%AC%E3%83%BC%E3%83%A0%E3%83%AF%E3%83%BC%E3%82%AF]]」。

**3. TAP ([[async/await]]) [#ae25c1af]
[[async/await]]は、TAP(Task-based Asynchronous Pattern)の方式で実装されている。

[[async/await]]は、
-メッセージ(番号)のような制約のある単純固定長値のキューではなく、~
実行コードの任意のコード断片そのものをキュー(同期コンテキスト)を使用して繋いでいる。
-.NET 3.5用のasync/await互換NuGetパッケージでは、~
.NET 4のTask互換クラスを、内部をBeginInvoke等で実装して、async/awaitを使えるようにしていた。
**4. [[Reactive Extensions(Rx)]] [#lf9e0bc2]

***概要 [#q74e6e48]
-[[async/await]]の登場で、マルチスレッド処理として実装しなくても、~
非同期処理を同期型処理と、ほぼ変わらない記述で容易に実装可能になった。
*[[Rx>#lf9e0bc2]] + [[async/await>#ae25c1af]] [#nefc1c9b]

-awaitの意味は、スレッドを止めずノンブロッキングで非同期から同期に復帰するという意味らしい。
-neue cc - Reactive Extensions + asyncによるC#5.0の非同期処理~
http://neue.cc/2012/07/11_377.html
--非同期メソッド入門 (11) - Rxとの相互運用 - xin9le.net~
http://blog.xin9le.net/entry/2012/12/11/005445
--Curing Your Event Processing Blues with Reactive Extensions (Rx) | TechEd Europe 2012 | Channel 9~
https://channel9.msdn.com/Events/TechEd/Europe/2012/DEV413

>実際、[[async/await]]はそういう動きをする。

--スレッドやWindowsメッセージングキューでTask化される。~
昔懐かしい、[[ノンプリエンプティブ・マルチタスク]](Win3.1)のようなイメージ。

--しかし、その実態はとても複雑、詳しくは[[コチラ>#nc344611]]を参照。
---内部がどう動いているか詳しく把握せんとシステムは安定しない、
---中身をシッカリ理解して使用している人が少ないので注意。

***余談? [#ef267401]
[[async/await]]の夫々の意味。

-async修飾子~
asyncは、呼び出し元と同じ同期コンテキストで実行されることを示す。

-await演算子~
asyncをawaitすると、スレッドを止めずに同期コンテキストで同期する。

この動作は想像し難いが、具体的には、
-同じ同期コンテキスト(Windowsメッセージングキュー)に
-コールバックを順番に並べる(Control.BeginInvoke()的な)。

というイメージ。

-・・・結局、APM、EAPと同じ技術(同期コンテキスト)を使っている。

-なお、同期コンテキストの種類によって、動きも異なる。
--同期コンテキストはキュー的なもので実装されている。~
例えば、前述の、
---Windowsメッセージングキュー、
---ThreadPool
---I/O 完了ポート
---, etc.

--なので、言葉尻だけで動作を想像し難く、~
[[利用の際は注意が必要になってくる>async/await#c3aa7761]]。

**4. [[Reactive Extensions(Rx)]] [#lf9e0bc2]

*参考 [#b6ba428d]
-.NET開発における非同期処理の基礎と歴史 - @IT~
http://www.atmarkit.co.jp/fdotnet/chushin/masterasync_01/masterasync_01_02.html

-C#次世代非同期処理概観 - Task vs Reactive Extensions~
http://www.slideshare.net/neuecc/asynchronous-rx-andtask

----
Tags: [[:プログラミング]], [[:その他、開発の色々]], [[:.NET開発]]


トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS