Accès aux caractères dans une chaîne Go
Cette question explore comment accéder aux caractères dans une chaîne Go, en approfondissant la nature des chaînes en tant que tranches d'octets et la relation entre les caractères, les runes et les points de code Unicode.
Original Question :
Comment puis-je obtenir le caractère "E" au lieu de la valeur numérique 69 lors de l'accès à "HELLO"[1] ?
Réponse :
Pour récupérer des caractères d'une chaîne, il faut comprendre la représentation des caractères de Go. Les chaînes littérales interprétées sont des séquences de caractères codés en UTF-8, où les caractères ASCII n'occupent qu'un seul octet. Ainsi, pour obtenir le caractère "E", la conversion suivante est nécessaire :
fmt.Println(string("Hello"[1])) // ASCII only
Alternative : Utiliser des runes
Pour le support Unicode, les runes, qui représentent Unicode des points de code peuvent être utilisés. Ceux-ci sont compatibles avec les chaînes UTF-8 :
fmt.Println(string([]rune("Hello, 世界")[1])) // UTF-8
Ce code affichera le caractère "e".
Capacités de gestion des caractères de Go
Il convient de noter que Go fournit des fonctions de conversion entre caractères et octets. Par exemple, la méthode byte(c) convertit un caractère (rune) en son octet correspondant, tandis que rune(b) convertit un octet en caractère.
Lectures supplémentaires :
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!