Go에서 `append(x, x...)`가 슬라이스를 새로운 백업 배열에 복사하는 이유는 무엇입니까?
php 편집자 Yuzi는 모두가 공통적으로 묻는 질문에 답할 것입니다. Go에서 'append(x, x...)'가 슬라이스를 새로운 지원 배열에 복사하는 이유는 무엇입니까? Go 프로그래밍 언어에서 `append` 함수는 요소를 슬라이스에 추가하는 데 사용됩니다. 'append' 함수를 사용할 때 슬라이스 용량이 충분하지 않으면 Go는 새 기본 배열을 만들고 원본 슬라이스의 요소를 새 기본 배열에 복사합니다. Go에서 슬라이스는 동적 배열에 대한 참조이기 때문입니다. 슬라이스 용량이 충분하지 않으면 더 많은 요소를 수용하기 위해 새 배열을 만들어야 합니다. 이 메커니즘은 슬라이스의 연속성과 확장성을 보장하지만 일부 성능 손실도 가져옵니다.
질문 내용
go의 슬라이싱 팁 wiki 및 go 라이브러리(예: 이 예)에서는 슬라이스를 새 백업 배열에 복사하기 위해 다음과 같은 코드를 볼 수 있습니다.
으아아아내가 이해한 내용은 다음과 같습니다.
-
append
의 두 번째 인수로 제공된 슬라이스의 모든 항목은 새 백업 배열에 복사됩니다. -
append
的第一个参数中,代码使用完整切片表达式。 (我们可以将第一个参数重写为a[0:0:0]
,但如果省略,将提供第一个0
의 첫 번째 매개변수에서 코드는 전체 슬라이스 표현식을 사용합니다. (첫 번째 인수를a[0:0:0]
로 다시 작성할 수 있지만 생략하면 첫 번째 가 제공됩니다. 여기서는 더 큰 의미와 관련이 없다고 생각합니다.) - 사양에 따라 생성된 슬라이스는 원본 슬라이스와 동일한 유형이어야 하며 길이와 용량이 0이어야 합니다.
-
copy
代替append
(다시 말하지만 직접적인 관련은 없지만 대신
copy
를 사용하면 더 명확하게 읽을 수 있습니다.)
append(someslice[:0:0], someslice...)
创建一个新的支持数组。我最初也很困惑为什么 append
그러나 append(someslice[:0:0], someslice...)
구문이 왜 새로운 백업 배열을 생성하는지 완전히 이해하지 못합니다. 또한 처음에는
내 추측:
-
newslice := oldslice
이 모든 것이 필요하고 유용하다고 생각합니다. 왜냐하면 만 할당하면 하나의 변경 사항이 다른 하나에도 반영되기 때문입니다. 일반적으로 당신은 이것을 원하지 않습니다. -
append
의 결과를 원본 슬라이스에 할당하지 않기 때문에(go에서는 일반적임) 원본 슬라이스에는 아무 일도 일어나지 않습니다. 어떤 방식으로든 잘리거나 변경되지 않습니다. -
anyslice[:0:0]
的长度和容量均为零,因此如果 go 要将anyslice
요소가 결과에 할당되므로 새로운 백업 배열을 만들어야 합니다. 이것이 새로운 백업 어레이를 만드는 이유 인가요? -
anyslice...
没有元素会发生什么? go playground 上的一个片段表明,如果您在空切片上使用此附加技巧,则副本和原始副本最初具有相同的支持数组。 (编辑:正如评论者所解释的,我误解了这个片段。该片段显示这两个项目最初是相同的,但是都没有支持数组。它们都指向最初为通用零值。)由于两个切片的长度和容量都为零,因此当您向其中一个切片添加任何内容时,该切片将获得一个新的后备数组。所以我猜,效果还是一样的。即append
anyslice...
에 요소가 없으면 어떻게 되나요? Go Playground의 스니펫은 빈 슬라이스에 이 추가 트릭을 사용하면 복사본과 원본이 처음에 동일한 백업 배열을 갖는다는 것을 보여줍니다. (편집: 댓글 작성자가 설명했듯이 이 스니펫을 오해했습니다. 스니펫은 두 프로젝트가 원래 동일했지만 어느 쪽도 배열을 지원하지 않습니다는 것을 보여줍니다. 둘 다 일반을 가리킵니다. 0 값.) 두 슬라이스 모두 길이와 용량이 0이므로 슬라이스 중 하나에 무엇이든 추가하면 해당 슬라이스는 새로운 지원 어레이를 얻습니다. 그래서 그 효과는 여전히 같다고 생각합니다. 즉, 두 조각은 복사 후에 서로 영향을 미칠 수 없습니다. - 이 다른 플레이그라운드 스니펫은 슬라이스에 0개 이상의 요소가 있는 경우
append
복사 메소드가 즉시 새로운 백업 배열을 생성한다는 것을 보여줍니다. 이 경우 결과로 나온 두 조각은 즉각적으로 분리됩니다.
아마도 이것에 대해 너무 걱정할 것입니다. 하지만 왜 트릭이 그렇게 작동하는지에 대해 좀 더 철저한 설명을 듣고 싶습니다. append(a[:0:0], a...)
용량이
이니까 그렇죠. 0
https://pkg.go.dev/[이메일 보호됨]#append
용량이 충분하면 새 요소를 수용할 수 있도록 대상이 다시 슬라이스됩니다. 그렇지 않은 경우 새로운 기본 배열이 할당됩니다.
- 비어 있지 않은 슬라이스로는 충분하지 않습니다. 새 배열을 할당해야 합니다.
cap=0
위 내용은 Go에서 `append(x, x...)`가 슬라이스를 새로운 백업 배열에 복사하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











보안 통신에 널리 사용되는 오픈 소스 라이브러리로서 OpenSSL은 암호화 알고리즘, 키 및 인증서 관리 기능을 제공합니다. 그러나 역사적 버전에는 알려진 보안 취약점이 있으며 그 중 일부는 매우 유해합니다. 이 기사는 데비안 시스템의 OpenSSL에 대한 일반적인 취약점 및 응답 측정에 중점을 둘 것입니다. DebianopensSL 알려진 취약점 : OpenSSL은 다음과 같은 몇 가지 심각한 취약점을 경험했습니다. 심장 출혈 취약성 (CVE-2014-0160) :이 취약점은 OpenSSL 1.0.1 ~ 1.0.1F 및 1.0.2 ~ 1.0.2 베타 버전에 영향을 미칩니다. 공격자는이 취약점을 사용하여 암호화 키 등을 포함하여 서버에서 무단 읽기 민감한 정보를 사용할 수 있습니다.

이 기사는 프로파일 링 활성화, 데이터 수집 및 CPU 및 메모리 문제와 같은 일반적인 병목 현상을 식별하는 등 GO 성능 분석을 위해 PPROF 도구를 사용하는 방법을 설명합니다.

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

Go Language의 부동 소수점 번호 작동에 사용되는 라이브러리는 정확도를 보장하는 방법을 소개합니다.

Go Crawler Colly의 대기열 스레딩 문제는 Colly Crawler 라이브러리를 GO 언어로 사용하는 문제를 탐구합니다. � ...

이 기사에서는 GO.MOD를 통해 GO 모듈 종속성 관리, 사양, 업데이트 및 충돌 해상도를 포함합니다. 시맨틱 버전 작성 및 정기 업데이트와 같은 모범 사례를 강조합니다.

이 기사는 테스트 케이스 테이블을 사용하여 여러 입력 및 결과로 기능을 테스트하는 방법 인 GO에서 테이블 중심 테스트를 사용하는 것에 대해 설명합니다. 가독성 향상, 중복 감소, 확장 성, 일관성 및 A와 같은 이점을 강조합니다.

백엔드 학습 경로 : 프론트 엔드에서 백엔드 초보자로서 프론트 엔드에서 백엔드까지의 탐사 여행은 프론트 엔드 개발에서 변화하는 백엔드 초보자로서 이미 Nodejs의 기초를 가지고 있습니다.
