Isih Perbandingan dalam C#: Isih lwn OrderBy
Apabila mengendalikan koleksi dalam C#, pengisihan selalunya diperlukan untuk menyusun data. Dua kaedah yang biasa digunakan untuk pengisihan ialah Sort dan OrderBy. Artikel ini meneroka perbezaan dan implikasi prestasinya.
Algoritma dan Kestabilan
Isih dan SusunMenggunakan algoritma pengisihan yang berbeza. Isih menggunakan algoritma pengisihan yang tidak stabil, seperti QuickSort. Ini bermakna jika berbilang elemen mempunyai nilai yang sama, susunannya mungkin berubah selepas mengisih.
Sebaliknya, OrderBy menggunakan algoritma pengisihan yang stabil, memastikan elemen dengan nilai yang sama mengekalkan susunan asalnya. Tingkah laku ini penting apabila mengekalkan integriti jujukan adalah penting.
Pertimbangan Prestasi
Perbandingan prestasi antara Sort dan OrderBy berbeza-beza bergantung pada pelaksanaan khusus dan saiz data. Walau bagaimanapun, secara umum:
Pembanding Tersuai
Apabila mengisih menggunakan mana-mana kaedah, pembanding tersuai boleh mentakrifkan logik pengisihan. Dengan Isih, ungkapan lambda disediakan. Untuk OrderBy, IComparer
Contoh:
Pertimbangkan contoh berikut:
List<Person> persons = new List<Person>(); persons.Add(new Person("P005", "Janson")); persons.Add(new Person("P002", "Aravind")); persons.Add(new Person("P007", "Kazhal"));
Menggunakan Isih:
persons.Sort((p1, p2) => string.Compare(p1.Name, p2.Name, true));
menggunakan OrderBy:
var query = persons.OrderBy(n => n.Name, new NameComparer()); class NameComparer : IComparer<string> { public int Compare(string x, string y) { return string.Compare(x, y, true); } }
Kesimpulan
Walaupun kedua-dua Sort dan OrderBy boleh mengisih koleksi dengan berkesan, algoritma asas dan ciri prestasinya berbeza. Untuk koleksi bersaiz kecil hingga sederhana, Isih mungkin lebih pantas sedikit. Untuk koleksi yang lebih besar, pengisihan stabil OrderBy dan penilaian malas boleh memberikan kelebihan. Pilihan harus dipandu oleh keperluan khusus aplikasi.
Atas ialah kandungan terperinci Isih vs. OrderBy dalam C#: Bilakah Saya Harus Menggunakan Kaedah Isih Yang Mana?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!