찾다
백엔드 개발GolangGo에서 설정된 길이의 빠르고 무작위 문자열을 어떻게 생성합니까?

How Do I Generate a Quick, Random String of a Set Length in Go?

Go에서 고정 길이의 임의 문자열을 생성하는 방법은 무엇입니까?

문제

문자의 임의 문자열(대문자 또는 소문자)만 원합니다. ), Go에서는 숫자가 없습니다. 이를 수행하는 가장 빠르고 간단한 방법은 무엇입니까?

답변

질문은 "가장 빠르고 간단한" 접근 방식을 추구합니다. Paul의 답변은 간단한 기술을 제공합니다. 그러나 "가장 빠른" 측면도 고려해 보겠습니다. 코드를 반복적으로 개선하여 최적화된 솔루션을 찾아보겠습니다.

I. 개선

1. 창세기(룬)

최적화할 초기 솔루션은 다음과 같습니다.

<code class="go">import (
    "math/rand"
    "time"
)

var letterRunes = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")

func RandStringRunes(n int) string {
    b := make([]rune, n)
    for i := range b {
        b[i] = letterRunes[rand.Intn(len(letterRunes))]
    }
    return string(b)
}</code>

2. 바이트

임의의 문자열에 사용되는 문자가 영어 대문자와 소문자로 제한되는 경우 영어 알파벳 문자가 UTF-8 인코딩의 바이트에 1:1로 매핑되므로 바이트로 작업할 수 있습니다( Go가 문자열을 저장하는 데 사용하는 것).

따라서 다음을

<code class="go">var letters = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")</code>

다음으로 바꿀 수 있습니다:

<code class="go">var letters = []byte("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")</code>

또는 더 나은 방법:

<code class="go">const letters = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"</code>

이제 const를 사용할 수 있기 때문에 이는 상당한 개선입니다(Go에서는 문자열 상수를 지원하지만 슬라이스 상수는 지원하지 않음). 추가적으로 len(문자)라는 표현도 상수입니다.

3. 나머지

이전 솔루션에서는 rand.Intn()(Rand.Intn() 및 추가로 Rand.Int31n()에 위임)을 호출하여 문자에 대한 임의의 숫자를 결정했습니다.

이것은 63개의 임의 비트로 난수를 생성하는 rand.Int63()을 사용하는 것보다 느립니다.

따라서 간단히 rand.Int63()을 호출하고 len(문자)로 나눈 후 나머지를 사용할 수 있습니다.

<code class="go">func RandStringBytesRmndr(n int) string {
    b := make([]byte, n)
    for i := range b {
        b[i] = letters[rand.Int63() % int64(len(letters))]
    }
    return string(b)
}</code>

모든 문자의 균등한 확률 분포를 유지하면서 더 빠릅니다(왜곡은 무시할 수 있지만 52개의 문자 수는 1

4. 마스킹

문자 수를 나타낼 수 있을 만큼 난수의 가장 낮은 비트만 사용하면 문자의 균등한 분포를 유지할 수 있습니다. 52개의 문자에는 6비트가 필요합니다: 52 = 110100b. 따라서 rand.Int63()에서 반환된 숫자의 가장 낮은 6비트만 사용합니다.

또한 숫자가 0..len(letterBytes)-1 범위 내에 있는 경우에만 숫자를 "수락"합니다. . 가장 낮은 비트가 더 크면 폐기하고 새 번호를 요청합니다.

<code class="go">const (
    letterIdxBits = 6                    // 6 bits to represent a letter index
    letterIdxMask = 1<p><strong>5. 마스킹 개선</strong></p>
<p>이전 솔루션은 rand.Int63()의 63개 임의 비트 중 가장 낮은 6비트만 사용했습니다. 무작위 비트를 얻는 것이 우리 알고리즘에서 가장 느린 부분이기 때문에 이는 비효율적입니다.</p>
<p>52개의 문자가 있으므로 6비트는 문자 인덱스를 코딩합니다. 63개의 무작위 비트는 63/6 = 10개의 다른 문자 인덱스를 지정할 수 있습니다. 10개를 모두 활용해보자:</p>
<pre class="brush:php;toolbar:false"><code class="go">const (
    letterIdxBits = 6                    // 6 bits to represent a letter index
    letterIdxMask = 1= 0; {
        if remain == 0 {
            cache, remain = rand.Int63(), letterIdxMax
        }
        if idx := int(cache & letterIdxMask); idx >= letterIdxBits
        remain--
    }
    return string(b)
}</code>

6. 소스

Masking Improved는 상당히 효율적입니다. 또 다른 측면, 즉 난수의 출처를 고려해 보겠습니다.

crypto/rand 패키지는 Read(b []byte) 기능을 제공합니다. 그러나 crypto/rand는 속도가 느린 암호학적으로 안전한 의사 난수 생성기를 구현하기 때문에 성능에 도움이 되지 않습니다.

그래서 우리는 math/rand 패키지를 계속 사용하겠습니다. rand.Rand는 rand.Source를 무작위 비트의 소스로 사용합니다. 따라서 rand.Source를 직접 사용할 수 있습니다:

<code class="go">import (
    "math/rand"
    "time"
)

var letterRunes = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")

func RandStringRunes(n int) string {
    b := make([]rune, n)
    for i := range b {
        b[i] = letterRunes[rand.Intn(len(letterRunes))]
    }
    return string(b)
}</code>

7. strings.Builder

를 활용하면 이전 솔루션에서는 먼저 슬라이스(Genesis의 []rune 및 이후의 []byte)에서 구성된 문자열을 반환한 다음 문자열로 변환했습니다. 문자열 값은 변경할 수 없으므로 이 최종 변환에서는 슬라이스 내용을 복사해야 합니다.

Go 1.10에서는 strings.Builder가 도입되었습니다. 이 새로운 유형은 bytes.Buffer와 유사하게 문자열 내용을 작성하는 데 사용할 수 있습니다. 내부적으로 []바이트를 사용하며 문자열을 생성하기 위해 내용을 복사할 필요가 없습니다.

<code class="go">var letters = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")</code>

8. unsafe

strings.Builder 패키지를 사용하여 strings.Builder를 "모방"하는 것은 우리가 했던 것처럼 내부 []바이트에 문자열을 빌드합니다. 따라서 strings.Builder를 사용하면 약간의 오버헤드가 발생하므로 최종 복사를 피하기 위해 전환했습니다.

그러나 unsafe:

<code class="go">var letters = []byte("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")</code>
패키지를 사용하여 이 복사를 피할 수도 있습니다.

위 내용은 Go에서 설정된 길이의 빠르고 무작위 문자열을 어떻게 생성합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Go Language Pack 가져 오기 : 밑줄과 밑줄이없는 밑줄의 차이점은 무엇입니까?Go Language Pack 가져 오기 : 밑줄과 밑줄이없는 밑줄의 차이점은 무엇입니까?Mar 03, 2025 pm 05:17 PM

이 기사에서는 GO의 패키지 가져 오기 메커니즘을 설명합니다. 명명 된 수입 (예 : 가져 오기 & quot; fmt & quot;) 및 빈 가져 오기 (예 : import _ & quot; fmt & quot;). 명명 된 가져 오기는 패키지 내용을 액세스 할 수있게하고 빈 수입은 t 만 실행합니다.

Beego 프레임 워크에서 페이지간에 단기 정보 전송을 구현하는 방법은 무엇입니까?Beego 프레임 워크에서 페이지간에 단기 정보 전송을 구현하는 방법은 무엇입니까?Mar 03, 2025 pm 05:22 PM

이 기사에서는 웹 애플리케이션에서 페이지 간 데이터 전송에 대한 Beego의 NewFlash () 기능을 설명합니다. NewFlash ()를 사용하여 컨트롤러간에 임시 메시지 (성공, 오류, 경고)를 표시하여 세션 메커니즘을 활용하는 데 중점을 둡니다. 한계

MySQL 쿼리 결과 목록을 GO 언어로 사용자 정의 구조 슬라이스로 변환하는 방법은 무엇입니까?MySQL 쿼리 결과 목록을 GO 언어로 사용자 정의 구조 슬라이스로 변환하는 방법은 무엇입니까?Mar 03, 2025 pm 05:18 PM

이 기사에서는 MySQL 쿼리 결과를 GO 구조 슬라이스로 효율적으로 변환합니다. 수동 구문 분석을 피하고 최적의 성능을 위해 데이터베이스/SQL의 스캔 방법을 사용하는 것을 강조합니다. DB 태그 및 Robus를 사용한 구조물 필드 매핑에 대한 모범 사례

이동 중에 테스트를 위해 모의 개체와 스터브를 작성하려면 어떻게합니까?이동 중에 테스트를 위해 모의 개체와 스터브를 작성하려면 어떻게합니까?Mar 10, 2025 pm 05:38 PM

이 기사는 단위 테스트를 위해 이동 중에 모의와 스터브를 만드는 것을 보여줍니다. 인터페이스 사용을 강조하고 모의 구현의 예를 제공하며 모의 집중 유지 및 어설 션 라이브러리 사용과 같은 모범 사례에 대해 설명합니다. 기사

GO에서 제네릭에 대한 사용자 정의 유형 제약 조건을 어떻게 정의 할 수 있습니까?GO에서 제네릭에 대한 사용자 정의 유형 제약 조건을 어떻게 정의 할 수 있습니까?Mar 10, 2025 pm 03:20 PM

이 기사에서는 GO의 제네릭에 대한 사용자 정의 유형 제약 조건을 살펴 봅니다. 인터페이스가 일반 함수에 대한 최소 유형 ​​요구 사항을 정의하여 유형 안전 및 코드 재사성을 향상시키는 방법에 대해 자세히 설명합니다. 이 기사는 또한 한계와 모범 사례에 대해 설명합니다

편리하게 GO 언어로 파일을 작성하는 방법?편리하게 GO 언어로 파일을 작성하는 방법?Mar 03, 2025 pm 05:15 PM

이 기사는 OS.WriteFile (작은 파일에 적합)과 OS.OpenFile 및 Buffered Writes (큰 파일에 최적)를 비교하여 효율적인 파일 쓰기를 자세히 설명합니다. 강력한 오류 처리, 연기 사용 및 특정 오류 확인을 강조합니다.

GO에서 단위 테스트를 어떻게 작성합니까?GO에서 단위 테스트를 어떻게 작성합니까?Mar 21, 2025 pm 06:34 PM

이 기사는 GO에서 단위 테스트 작성, 모범 사례, 조롱 기술 및 효율적인 테스트 관리를위한 도구를 다루는 것에 대해 논의합니다.

추적 도구를 사용하여 GO 응용 프로그램의 실행 흐름을 이해하려면 어떻게해야합니까?추적 도구를 사용하여 GO 응용 프로그램의 실행 흐름을 이해하려면 어떻게해야합니까?Mar 10, 2025 pm 05:36 PM

이 기사는 추적 도구를 사용하여 GO 응용 프로그램 실행 흐름을 분석합니다. 수동 및 자동 계측 기술, Jaeger, Zipkin 및 OpenTelemetry와 같은 도구 비교 및 ​​효과적인 데이터 시각화를 강조합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는