Meningkatkan Penapisan Koleksi dalam C#
Dalam C#, penapisan koleksi memainkan peranan penting dalam manipulasi data. Terdapat beberapa kaedah untuk menapis koleksi, termasuk pendekatan yang disebut dalam soalan, yang melibatkan penciptaan senarai baharu dan lelaran melalui senarai asal, menyalin elemen padanan ke dalam senarai baharu. Walau bagaimanapun, pendekatan ini mempunyai had dari segi prestasi dan kecekapan.
Penyelesaian alternatif ialah memanfaatkan LINQ (Language Integrated Query), yang diperkenalkan dalam C# 3.0. LINQ menyediakan sintaks yang berkuasa untuk menyoal dan menapis koleksi dengan cara yang ringkas dan ekspresif. Operator Where() dalam LINQ membenarkan penapisan berdasarkan predikat yang ditentukan:
List<int> myList = GetListOfIntsFromSomewhere(); // Filter ints that are not greater than 7 out of the list. // Where returns an IEnumerable<T>, so ToList is used to convert back to a List<T>. List<int> filteredList = myList.Where(x => x > 7).ToList();
Pendekatan ini menawarkan kelebihan yang ketara. Pertama, ia jauh lebih ringkas dan elegan daripada mencipta senarai baharu dan mengulangi koleksi secara manual. Kedua, pertanyaan LINQ adalah malas, bermakna operasi penapisan tidak dilakukan sehingga koleksi yang ditapis benar-benar digunakan. Ini boleh menghasilkan peningkatan prestasi dalam senario di mana koleksi yang ditapis tidak diperlukan serta-merta.
Selain itu, LINQ boleh dikembangkan dan membolehkan penciptaan pengendali pertanyaan tersuai yang boleh memenuhi keperluan penapisan tertentu. Dengan menggunakan LINQ, pembangun boleh menyelaraskan kod mereka, meningkatkan prestasi dan memperoleh lebih fleksibiliti dalam tugas penapisan koleksi.
Atas ialah kandungan terperinci Bagaimanakah LINQ Boleh Meningkatkan Penapisan Koleksi dalam C#?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!