StaTaskScheduler dan mesej utas STA mengepam
StaTaskScheduler dalam ParallelExtensionsExtras daripada pasukan Parallel direka untuk mengehoskan objek STA COM legasi yang disediakan oleh pihak ketiga. Perihalan pelaksanaan menyatakan bahawa ia menyokong urutan MTA dan STA dan mengendalikan perbezaan dalam API asas seperti WaitHandle.WaitAll.
Walau bagaimanapun, adalah tidak betul untuk menganggap bahawa StaTaskScheduler akan menggunakan API tunggu yang mengepam mesej (seperti CoWaitForMultipleHandles) untuk mengelakkan kebuntuan pada urutan STA. Bahagian menyekat TPL mungkin tidak mengepam mesej, menyebabkan kebuntuan.
Dalam senario yang dipermudahkan, masalah timbul apabila objek STA COM A dalam proses memanggil objek B di luar proses dan menjangka mendapat panggilan balik daripada B. Panggilan ke a.Method(b) tidak pernah kembali disebabkan oleh menunggu yang menyekat (bukan mengepam mesej) di suatu tempat di dalam BlockingCollection
Penyelesaian adalah untuk melaksanakan konteks penyegerakan tersuai yang secara eksplisit mengepam mesej menggunakan CoWaitForMultipleHandles dan memasangnya pada setiap urutan STA yang dimulakan oleh StaTaskScheduler.
MsgWaitForMultipleObjectsEx lebih sesuai untuk mengepam mesej daripada CoWaitForMultipleHandles. Kaedah Tunggu konteks penyegerakan tersuai boleh dilaksanakan sebagai pemaju kepada SynchronizationContext.WaitHelper atau mengandungi gelung pengepaman mesej berfungsi sepenuhnya.
Kod berikut menunjukkan pelaksanaan konteks penyegerakan tersuai yang termasuk gelung pengepaman mesej:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
Menggunakan konteks penyegerakan tersuai ini dan gelung pengepaman mesej memastikan mesej dipam walaupun semasa menggunakan sekatan menunggu pada utas STA dan mengelakkan kebuntuan benang STA.
Atas ialah kandungan terperinci Bagaimanakah Kebuntuan Boleh Dihalang pada Benang STA Apabila Menggunakan StaTaskScheduler dengan Menunggu Menyekat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!