Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Task.waitall menyebabkan kebuntuan dalam operasi asynchronous API Web ASP.NET?
Task.wait vs menunggu: Bahaya Deadlock dalam Asynchronous. NET Programming
Memahami perbezaan antara dan Task.Wait
adalah yang paling penting ketika bekerja dengan operasi tak segerak dalam .net. Walaupun seolah -olah serupa, penggunaan yang tidak betul boleh menyebabkan kebuntuan. await
Masalah: API Web Deadlocked
Contoh kod menunjukkan tiga kaedah asynchronous (, Foo
, Bar
) yang dipanggil dari API web ASP.NET mendapatkan titik akhir. Masalahnya timbul apabila Ros
digunakan secara serentak menunggu tugas sepuluh Task.WaitAll
. Ini membawa kepada kebuntuan. Ros
vs Task.Wait
dijelaskan await
Serap menyekat benang semasa sehingga tugas yang ditunggu -tunggu selesai. Sebaliknya, Task.Wait
secara tidak sengaja menangguhkan kaedah semasa, mengembalikan tugas yang tidak lengkap kepada pemanggil. Pelaksanaan disambung semula hanya apabila tugas yang ditunggu -tunggu selesai. await
Mengapa kebuntuan berlaku
kebuntuan berlaku kerana menyekat benang utama, menghalang tugas Task.WaitAll
(dalam gelung) dari berjalan. Tugas -tugas ini bergantung kepada kaedah tak segerak sebelumnya (Ros
), yang mereka tunggu tugas lain. Dengan benang utama disekat, tugas -tugas yang bergantung ini tidak dapat diselesaikan, menyebabkan kebuntuan. Ros
Bar
Foo
Mengelakkan penyekatan: Pendekatan pilihan
Walaupun kelihatannya menggoda, menggunakan penyekatan koperasi untuk menyelesaikannya secara umumnya tidak digalakkan. Ia memperkenalkan ketidakpastian dan merumitkan analisis tingkah laku aplikasi. Penyelesaian terbaik adalah untuk membolehkan tugas menyelesaikan secara asynchronously, dengan itu mengelakkan kebuntuan.
Atas ialah kandungan terperinci Bagaimanakah Task.waitall menyebabkan kebuntuan dalam operasi asynchronous API Web ASP.NET?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!