マルチスレッドアプリケーションの作成に異なる考え方を持たせるか、別のパラダイムがありますか?おそらく、プログラミングプログラミングのような手続き型プログラミングとはまったく異なると感じるものです。スレッディング・パラダイム?
答えて
同時実行性には、さまざまな問題に対してさまざまなモデルがあります。 concurrencyのWikipediaページにはいくつかのモデルが掲載されており、concurrency patternsのページもあります。これには、並行性にアプローチするさまざまな種類の出発点があります。
あなたが取るアプローチは、手元の問題に大きく依存しています。異なるモデルは、並行アプリケーションで発生する可能性のあるさまざまな異なる問題を解決します。
クラスIでは、並行性の問題を解決するために同時実行でmutual exclusionとsynchronizationを一緒に使用すると教えられました。一部のソリューションでは1つのみが必要ですが、どちらのソリューションでも同時実行性の問題を解決できるはずです。
大きく異なる概念のために、不変性と並行性を見ることができます。すべてのデータが不変の場合、従来の並行性のアプローチは必要ではありません。 This articleがそのトピックを探検します。
に見出すことができる(すべてを共有する)プロセス中心の並行性(アドレス空間分離に向かって)。このように、意図しないデータ共有を避けることができ、異なるサブシステム間で通信ポリシーを適用する方が簡単です。
このアイデアは古いもので、Micro-Kernel OSコミュニティによって伝播され、より信頼性の高いオペレーティングシステムを構築しています。興味深いことに、Microsoft ResearchのSingularity OSプロトタイプでは、このモデルで作業するときに従来のアドレススペースが不要であることが示されています。
私が気に入っている比較的新しいアイデアはtransactional memoryです。更新が常にアトミックであることを確認して並行性の問題を回避してください。
興味深いバリエーションについてはOpenMPを見てください。
- 1. Pythonのスレッディングでのスレッディング
- 2. cx_Oracleとデータソースのパラダイム
- 3. MongoDBの更新パラダイム
- 4. ContentProviderスレッディング
- 5. スレッディングiPhone
- 6. VBScriptスレッディング
- 7. Python。スレッディング
- 8. "Convention over Configuration"パラダイムのメリット
- 9. 機能パラダイムの動的プログラミング
- 10. エンティティコンポーネントのパラダイムについて
- 11. 機能パラダイムのJavaFX ContextMenu
- 12. は、反応性官能パラダイム
- 13. Java GUIスレッディング
- 14. VB.NET WPFスレッディング
- 15. スレッディング実装
- 16. Apache2.2のスレッディング
- 17. ラズベリーパイ、チキンとスレッディング
- 18. スレッディングとネットワーキング
- 19. Blocking Readのスレッディング
- 20. PyGTKとスレッディング
- 21. Qtでスレッディング
- 22. NSOperationとCoreDataスレッディング
- 23. Spidermonkeyのスレッディング
- 24. 'sys.excepthook'とスレッディング
- 25. Pythonのスレッディング/キュー
- 26. Python PYserial WxPythonスレッディング
- 27. スレッディングとシングルトン
- 28. スレッディング/同期化
- 29. ASIHTTPRequest内のスレッディング
- 30. スレッディングと条件