문자열에 대한 Rune 대 바이트 범위
range를 사용하여 문자열을 반복할 때 rune 유형의 문자를 얻고, 다음을 사용하여 특정 문자에 액세스합니다. str[index]는 바이트를 반환합니다. 이는 Go 언어의 기본 설계 때문입니다.
문자열 유형:
문자열은 0에서 len( s)-1. 각 바이트는 문자열의 단일 코드 단위를 나타냅니다.
범위 절:
for 루프의 범위 절은 문자열의 유니코드 코드 포인트를 반복합니다. 하나 이상의 바이트로 구성됩니다. 각 반복에서:
특정 캐릭터 액세스:
str[index]를 사용하여 특정 문자에 액세스하면 해당 인덱스의 바이트 값이 반환됩니다. 이는 바이트가 아닌 코드 포인트를 반복하는 범위를 사용한 반복과 다릅니다.
언어가 이렇게 정의한 이유:
범위에 룬 문자를 사용하는 선택 문자열 처리 작업을 단순화하기 위해 반복이 이루어졌습니다. 이를 통해 개발자는 바이트 구성에 관계없이 유니코드 문자를 반복할 수 있습니다. 이는 문자열을 처리하는 보다 일관되고 직관적인 방법을 제공합니다.
바이트 반복으로 되돌리기:
룬 반복 대신 바이트 반복이 필요한 경우 다음을 사용할 수 있습니다. 메서드:
정수 인덱스가 있는 for 루프를 사용하여 바이트를 반복합니다. 직접:
for i := 0; i < len(s); i++ { // Process byte at index i }
문자열을 바이트 배열로 변환하고 반복합니다.
for _, b := range []byte(s) { // Process byte b }
적절한 반복 방법 선택 , 개발자는 특정 요구 사항에 따라 문자열을 효과적으로 처리할 수 있습니다.
위 내용은 Go 문자열의 룬 대 바이트: 언제 범위 대 인덱스 액세스를 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!