Antara Muka Setanding: Melaksanakan Fungsi Perbandingan
Tugas di tangan berkisar tentang membandingkan nilai yang dimasukkan ke dalam senarai terpaut untuk mengekalkan sisipan yang diisih. Dalam Go, apabila beban berlebihan operator tidak disokong, kami memerlukan mekanisme untuk memastikan medan Nilai struct Elemen boleh dibandingkan menggunakan operator kurang daripada (<).
Penyelesaian yang mungkin melibatkan penciptaan Antara muka setanding. Walau bagaimanapun, Go tidak menyediakan antara muka khusus untuk mengendalikan perbandingan. Sebaliknya, kita boleh meniru kefungsian yang diingini melalui kaedah Bandingkan tersuai dalam antara muka yang ditentukan pengguna.
Mengkonsepkan Antara Muka Sebanding
Pertimbangkan antara muka Sebanding yang dipermudahkan berikut dan kaedah Bandingkan yang sepadan dengannya:
<code class="go">type Comparable interface { Compare(x Comparable) bool }</code>
Antara muka ini memerlukan mana-mana jenis yang melaksanakan Comparable mempunyai kaedah Compare yang mengambil contoh Comparable yang lain sebagai input dan mengembalikan nilai boolean yang menunjukkan hasil perbandingan.
Melaksanakan Comparable untuk Jenis Custom
Untuk memastikan bahawa struct Elemen boleh dibandingkan, kita boleh melaksanakan kaedah Bandingkan untuk jenis tersuai yang membalut medan Nilai:
<code class="go">type ComparableValue struct { Value interface{} } func (c ComparableValue) Compare(other ComparableValue) bool { // Perform comparison logic based on the underlying Value field }</code>
Dengan membungkus medan Nilai dalam struktur ComparableValue, kita boleh melaksanakan kaedah Bandingkan khusus untuk logik perbandingan yang diingini.
Menggunakan Antara Muka Sebanding
Dengan jenis ComparableValue dan kaedah Bandingkannya, kita boleh mengubah suai struct Elemen seperti berikut:
<code class="go">type Element struct { next, prev *Element Value ComparableValue }</code>
Dalam kaedah Tambah senarai terpaut, kini kami boleh memanggil kaedah Bandingkan untuk menyemak titik sisipan yang sesuai:
<code class="go">for { if this.next.Value.Compare(val) < 0 { // Compare ComparableValue instances this = this.next } else { return l.insert(&e, this) } }</code>
Pendekatan ini membolehkan kami melaksanakan fungsi perbandingan tanpa bergantung pada beban berlebihan operator atau antara muka Sebanding terbina dalam, menjadikannya sesuai untuk jenis tersuai yang memerlukan logik perbandingan khusus.
Atas ialah kandungan terperinci Bagaimanakah Kami Boleh Melaksanakan Fungsi Perbandingan dalam Go Tanpa Operator Lebih Muatan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!