Maison > développement back-end > Golang > Comment obtenir la longueur des caractères d'une rune en langage Go

Comment obtenir la longueur des caractères d'une rune en langage Go

藏色散人
Libérer: 2021-06-09 15:05:13
avant
2874 Les gens l'ont consulté

La colonne tutorielle suivante de golang vous présentera comment obtenir la longueur des caractères par rune dans le langage go. J'espère qu'elle sera utile aux amis qui en ont besoin !

Comment obtenir la longueur des caractères d'une rune en langage Go

rune est un type de données spécial dans le langage Go. C'est un alias de int32 et est équivalent à int32 dans presque tous les aspects. Il est utilisé pour distinguer les valeurs de caractères et les valeurs entières. suit :

// rune is an alias for int32 and is equivalent to int32 in all ways. It is
// used, by convention, to distinguish character values from integer values.

//int32的别名,几乎在所有方面等同于int32
//它用来区分字符值和整数值
type rune = int32
Copier après la connexion

Regardons cela à travers un exemple :

package mainimport "fmt"func main() {
    var str = "hello 你好啊"
    fmt.Println("len(str):", len(str))}
Copier après la connexion

Devinons le résultat, bonjour c'est 5 caractères + 1 espace + 3 caractères chinois, ce qui devrait faire 9 au total, et la longueur est 9, mais nous l'exécutons,

Comment obtenir la longueur des caractères dune rune en langage Go

et le résultat imprimé est 15. Pourquoi est-ce ?

La couche inférieure de la chaîne dans Golang est implémentée via un tableau d'octets. Les caractères chinois occupent 2 octets sous Unicode et 3 octets sous l'encodage utf-8, et l'encodage par défaut de Golang est exactement utf-8.

La longueur calculée est donc égale à 5+1+3*3=15
Si nous devons calculer la longueur de la chaîne au lieu du nombre d'octets sous-jacents, nous pouvons utiliser The méthode suivante :

package main

import (
    "fmt"
    "unicode/utf8"
)

func main() {
    var str = "hello 你好啊"
    //golang中string底层是通过byte数组实现的,座椅直接求len 实际是在按字节长度计算  所以一个汉字占3个字节算了3个长度
    fmt.Println("len(str):", len(str)) // 15
    //以下两种都可以得到str的字符串长度

    //1、golang中的unicode/utf8包提供了用utf-8获取长度的方法
    fmt.Println("RuneCountInString:", utf8.RuneCountInString(str))

    //2、通过rune类型处理unicode字符
    fmt.Println("rune:", len([]rune(str)))
}
Copier après la connexion

Le résultat en cours d'exécution est le suivant :
Comment obtenir la longueur des caractères dune rune en langage Go

Il y en a un autre au-dessus de la définition de la rune, byte = uint8

// byte is an alias for uint8 and is equivalent to uint8 in all ways. It is
// used, by convention, to distinguish byte values from 8-bit unsigned
// integer values.
type byte = uint8
Copier après la connexion
  • byte est équivalent Équivalent à int8, couramment utilisé pour traiter les caractères ascii
  • rune est équivalent à int32, couramment utilisé pour traiter les caractères unicode ou utf-8

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!

Étiquettes associées:
source:learnku.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal