Maison > Article > développement back-end > Comment utiliser slice en langage Go ?
Le langage Slice in Go est un type de données puissant qui vous permet d'effectuer facilement des opérations sur des tableaux ou des tranches. Cet article présentera les concepts de base des tranches et comment utiliser les tranches dans le langage Go.
En langage Go, slice est utilisé pour représenter un tableau dynamique. Contrairement à un tableau, la longueur d'une tranche n'est pas fixe et augmentera ou diminuera automatiquement en fonction du nombre d'éléments stockés. Le format de définition de
slice est le suivant :
var s []type
où, s représente le nom de la variable de la tranche et type représente le type d'éléments stockés dans la tranche. Les tranches peuvent également être initialisées à l'aide de la fonction make(), au format suivant :
var s = make([]type, length, capacity)
où length représente la longueur initiale de la tranche et capacité représente la capacité de la tranche (c'est-à-dire la longueur du tableau sous-jacent). Si la capacité n’est pas spécifiée, elle est par défaut la même que la longueur. Si vous opérez sur une tranche non initialisée, une erreur d'exécution se produira.
Comme les tableaux, slice prend également en charge les opérations d'accès et de modification de base. Comme indiqué ci-dessous :
s[0] = 1 // 修改元素 x := s[1] // 获取元素 s = append(s, 3) // 在尾部追加元素 s = s[:len(s)-1] // 删除尾部元素
Ces opérations sont similaires aux opérations sur les tableaux, mais slice prend également en charge certaines opérations spéciales, qui seront décrites en détail ci-dessous.
slice peut être parcourue à l'aide du mot-clé range, le format est le suivant :
for i, v := range s { fmt.Printf("s[%d] = %d ", i, v) }
où, i représente l'indice de l'élément et v représente la valeur de l'élément. La boucle de plage traversera toute la tranche.
slice a une fonction très puissante - l'opération de tranchage. Cette opération peut intercepter la tranche d'origine et générer une nouvelle tranche. Le format est le suivant :
s1 := s[start:end] // 基于下标[start, end)截取slice s2 := s[:end] // 截取slice的前end个元素 s3 := s[start:] // 从下标为start的元素截取slice的末尾元素
Comme indiqué ci-dessus, nous pouvons utiliser l'opération de découpage pour diviser la tranche d'origine en plusieurs sous-tranches.
slice prend également en charge une fonction très importante - append(). La fonction append() peut ajouter un ou plusieurs éléments à la fin d'une tranche pour générer une nouvelle tranche. Le format est le suivant :
s = append(s, elem1, elem2, ...)
Lors de l'utilisation de la fonction append(), si la capacité du tableau sous-jacent de la tranche est insuffisante, la capacité sera automatiquement augmentée. Si la capacité du tableau sous-jacent n'augmente pas suffisamment, un tableau sous-jacent plus grand sera réaffecté et les valeurs d'origine seront copiées dans le nouveau tableau sous-jacent.
Le langage Go fournit également une fonction copy() qui peut copier des éléments d'une tranche vers une autre tranche. Le format est le suivant :
copy(destSlice, srcSlice)
où destSlice représente la tranche de destination et srcSlice représente la tranche source. Il convient de noter que les tableaux sous-jacents des deux tranches doivent avoir une capacité suffisante, sinon une erreur d'exécution se produira.
Cet article présente les concepts de base et l'utilisation des tranches dans le langage Go. Slice est un type de données très important dans le langage Go. Il peut facilement fonctionner sur des tableaux et des tranches. C'est un outil important pour réaliser des structures de données dynamiques. Maîtriser l'utilisation des tranches peut rendre votre programmation en langage Go plus efficace et flexible.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!