Masalah:
Panggilan pangkalan data Rangka Kerja Entiti Asynchronous mempamerkan prestasi yang jauh lebih perlahan daripada rakan sejawatnya, selalunya mengalami peningkatan sepuluh kali ganda dalam masa pelaksanaan. Pertimbangkan contoh ini:
<code class="language-csharp">// Retrieve albums var albums = await this.context.Albums .Where(x => x.Artist.ID == artist.ID) .ToListAsync();</code>
Punca Punca:
Isu prestasi ini berpunca daripada kecacatan dalam pelaksanaan tak segerak EF 6. Apabila berurusan dengan jadual yang mengandungi lajur binari, EF tersilap menggunakan pengambilan data bukan urutan (CommandBehavior.Default) dan bukannya akses berjujukan yang lebih cekap (CommandBehavior.SequentialAccess).
Walaupun versi EF akan datang dijangka menangani perkara ini, penyelesaian melibatkan pembungkusan operasi segerak secara manual dalam kaedah tak segerak menggunakan TaskCompletionSource<T>
. Ini memintas pelaksanaan tak segerak EF yang tidak cekap.
Penurunan prestasi dalam operasi Rangka Kerja Entiti tak segerak tidak wujud pada pengaturcaraan tak segerak tetapi pepijat khusus dalam pelaksanaan EF 6. Menggunakan pembalut tak segerak manual mengurangkan kesesakan prestasi ini dengan berkesan dan meningkatkan responsif aplikasi.
Atas ialah kandungan terperinci Mengapa Rangka Kerja Entiti Saya Operasi Async 10x Lebih Lambat Daripada Segerak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!