Cara Mendapatkan N Elemen Terakhir Koleksi Menggunakan LINQ
Untuk mendapatkan N elemen terakhir koleksi, LINQ menawarkan yang cekap Langkau() kaedah. Dengan menggabungkannya dengan pernyataan bersyarat melalui Math.Max(), kita boleh mengelakkan ralat yang berpunca daripada input negatif.
collection.Skip(Math.Max(0, collection.Count() - N));
Pendekatan ini mengekalkan susunan item asal tanpa perlu mengisih dan serasi dengan berbilang penyedia LINQ .
Untuk lebih fleksibiliti, kaedah sambungan yang disediakan merangkumi perkara di atas logik:
public static class MiscExtensions { public static IEnumerable<T> TakeLast<T>(this IEnumerable<T> source, int N) { return source.Skip(Math.Max(0, source.Count() - N)); } }
Penggunaan:
collection.TakeLast(5);
Semasa panggilan Count() menimbulkan penghitungan untuk struktur data tertentu, pengoptimuman wujud untuk yang biasa seperti Senarai dan Tatasusunan. Untuk enumerable hadapan sahaja, algoritma satu laluan alternatif (cth., oleh Lasse V. Karlsen atau Mark Byers) mengelakkan berbilang hantaran ke atas data.
Atas ialah kandungan terperinci Bagaimana Mendapatkan Elemen N Terakhir Koleksi Menggunakan LINQ dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!