El segmento de lenguaje de Go es más poderoso, flexible y conveniente que una array y es una estructura de datos liviana. El segmento es una secuencia de longitud variable que almacena elementos de un tipo similar, no está permitido almacenar diferentes tipos de elementos en el mismo segmento.
En el segmento de bytes de Go, se le permite dividir el segmento después del separador especificado usando una función SplitAfter() . Esta función divide un segmento de bytes en todos los subsectores después de cada instancia del separador dado y devuelve un segmento que contiene estos subsectores. Se define en el paquete de bytes, por lo que debe importar el paquete de bytes en su programa para acceder a la función SplitAfter.
Sintaxis:
func SplitAfter(o_slice, sep []byte) [][]byte
Aquí, o_slice es el segmento de bytes y sep es el separador. Si la separación está vacía, se dividirá después de cada secuencia UTF-8. Discutamos este concepto con la ayuda de los ejemplos dados:
Ejemplo 1:
// Go program to illustrate the concept // of splitting a slice of bytes package main import ( "bytes" "fmt" ) func main() { // Creating and Splitting // the slice of bytes // Using SplitAfter function res1 := bytes.SplitAfter([]byte("****Welcome, to, GeeksforGeeks****"), []byte(",")) res2 := bytes.SplitAfter([]byte("Learning x how x to x trim x a x slice of bytes"), []byte("x")) res3 := bytes.SplitAfter([]byte("GeeksforGeeks, Geek"), []byte("")) res4 := bytes.SplitAfter([]byte(""), []byte(",")) // Display the results fmt.Printf("\nFinal Result after splitting:\n") fmt.Printf("\nSlice 1: %s", res1) fmt.Printf("\nSlice 2: %s", res2) fmt.Printf("\nSlice 3: %s", res3) fmt.Printf("\nSlice 4: %s", res4) }
Producción:
Final Result after splitting: Slice 1: [****Welcome, to, GeeksforGeeks****] Slice 2: [Learning x how x to x trim x a x slice of bytes] Slice 3: [G e e k s f o r G e e k s , G e e k] Slice 4: []
Ejemplo 2:
// Go program to illustrate the concept // of splitting a slice of bytes package main import ( "bytes" "fmt" ) func main() { // Creating and initializing // the slice of bytes // Using shorthand declaration slice_1 := []byte{'!', '!', 'G', 'e', 'e', 'k', 's', 'f', 'o', 'r', 'G', 'e', 'e', 'k', 's', '#', '#'} slice_2 := []byte{'A', 'p', 'p', 'l', 'e'} slice_3 := []byte{'%', 'g', '%', 'e', '%', 'e', '%', 'k', '%', 's', '%'} // Displaying slices fmt.Println("Original Slice:") fmt.Printf("Slice 1: %s", slice_1) fmt.Printf("\nSlice 2: %s", slice_2) fmt.Printf("\nSlice 3: %s", slice_3) // Splitting the slice of bytes // Using SplitAfter function res1 := bytes.SplitAfter(slice_1, []byte("eek")) res2 := bytes.SplitAfter(slice_2, []byte("")) res3 := bytes.SplitAfter(slice_3, []byte("%")) // Display the results fmt.Printf("\n\nAfter splitting:\n") fmt.Printf("\nSlice 1: %s", res1) fmt.Printf("\nSlice 2: %s", res2) fmt.Printf("\nSlice 3: %s", res3) }
Producción:
Original Slice: Slice 1: !!GeeksforGeeks## Slice 2: Apple Slice 3: %g%e%e%k%s% After splitting: Slice 1: [!!Geek sforGeek s##] Slice 2: [A p p l e] Slice 3: [% g% e% e% k% s% ]
Publicación traducida automáticamente
Artículo escrito por ankita_saini y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA