Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk Memeriksa Kewujudan Elemen dengan Cekap dalam Go Slices?

Bagaimana untuk Memeriksa Kewujudan Elemen dengan Cekap dalam Go Slices?

Linda Hamilton
Lepaskan: 2024-12-11 04:54:08
asal
296 orang telah melayarinya

How to Efficiently Check for Element Existence in Go Slices?

Go Slices: The Missing Contains Method

In Go, slices tidak secara asli menawarkan kaedah untuk memeriksa dengan cekap sama ada unsur tertentu wujud dalam mereka. Ini boleh menjadi operasi yang menyusahkan jika mengulangi setiap elemen untuk mencari secara manual diperlukan.

Pendekatan Alternatif

Walaupun mungkin untuk melaksanakan kaedah mengandungi tersuai, ia tidak disyorkan secara universal. Sebaliknya, pertimbangkan alternatif berikut:

  • Menggunakan pakej isihan: Pakej isihan menyediakan fungsi carian binari yang boleh dimanfaatkan untuk melaksanakan dengan cekap mengandungi semakan pada kepingan yang diisih.
  • Menggunakan Peta: Untuk senario yang melibatkan pemeriksaan kerap mengandungi, peta boleh menjadi lebih sesuai. Peta asli menyokong nilai idiom, ok := yourmap[key] untuk mengesahkan kewujudan kunci tertentu. Untuk mengoptimumkan lagi, cipta peta[rentetan]struct{} untuk menghapuskan overhed storan nilai. Struktur kosong dioptimumkan dalam pelaksanaan peta Go, menjadikannya pilihan yang sesuai untuk set.

Contoh:

Pertimbangkan sepotong rentetan bernama perkataan:

words := []string{"apple", "banana", "cherry"}
Salin selepas log masuk

Untuk menyemak kewujudan "ceri" menggunakan jenis pakej:

i := sort.SearchStrings(words, "cherry")
if i < len(words) && words[i] == "cherry" {
  fmt.Println("cherry found")
}
Salin selepas log masuk

Untuk menyemak menggunakan peta:

existsMap := map[string]struct{}{}
for _, word := range words {
  existsMap[word] = struct{}{}
}

if _, ok := existsMap["cherry"]; ok {
  fmt.Println("cherry found")
}
Salin selepas log masuk

Pendekatan ini menyediakan mekanisme yang cekap dan fleksibel untuk melaksanakan mengandungi semakan dalam kepingan Go tanpa memerlukan kaedah slice.contains khusus .

Atas ialah kandungan terperinci Bagaimana untuk Memeriksa Kewujudan Elemen dengan Cekap dalam Go Slices?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan