Slice Chunking in Go
Anda mahu membahagikan sekeping kira-kira 2.1 juta rentetan kepada ketulan teragih sama rata. Segmen kod yang disediakan menggunakan teknik yang menduplikasi bongkah pertama dan bukannya mengedarkan rentetan secara sama rata.
Penyelesaian terletak pada menambahkan hirisan log pada kepingan yang dibahagikan dan bukannya membuat kepingan baharu. Dengan mengira saiz ketulan berdasarkan bilangan CPU dan panjang kepingan, log boleh diagihkan sama rata ke atas ketulan.
Kod yang diubah suai:
var divided [][]string chunkSize := (len(logs) + numCPU - 1) / numCPU for i := 0; i < len(logs); i += chunkSize { end := i + chunkSize if end > len(logs) { end = len(logs) } divided = append(divided, logs[i:end]) }
Pendekatan ini memastikan rentetan diedarkan sekata mungkin merentasi bahagian, memaksimumkan prestasi dan penggunaan sumber sistem.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Memotong Sekeping Rentetan Dalam Go dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!