찾다
웹 프론트엔드프런트엔드 Q&A자바스크립트에서 깊은 복사와 얕은 복사의 차이점은 무엇입니까?

JavaScript에서 얕은 복사본은 원본 데이터의 메모리 주소만 복사합니다. 이는 동일한 주소를 가리키는 두 개의 데이터 포인터와 동일합니다. 동일한 주소에 대한 딥 카피 포인트. 하나의 요소가 변경되더라도 다른 주소에는 영향을 미치지 않습니다.

자바스크립트에서 깊은 복사와 얕은 복사의 차이점은 무엇입니까?

이 튜토리얼의 운영 환경: Windows 10 시스템, JavaScript 버전 1.8.5, Dell G3 컴퓨터.

JavaScript에서 Deep Copy와 Shallow Copy의 차이점은 무엇인가요?

Shallow Copy와 Deep Copy를 살펴보기 전에 먼저 힙과 스택의 개념을 이해해 봅시다

힙과 스택은 모두 메모리에서 나누어 저장하는 영역입니다. 스택에는 자동으로 할당된 메모리 공간이 있으며, 이는 시스템에 의해 자동으로 해제됩니다. 힙은 동적으로 할당된 메모리이며 크기는 가변적이며 자동으로 해제되지 않습니다.

그럼 기본 데이터 유형 및 참조 데이터 유형(복합 데이터 유형이라고도 함)을 살펴보겠습니다.

1. 기본 유형: 문자열, 숫자, 부울, 정의되지 않음, 기호(ES6의 새로운 기능, 고유한 값을 나타냄) 유형 값은 메모리에서 고정된 크기를 차지하고 스택 메모리에 저장됩니다.

2. 참조 유형: 객체, 배열, 날짜, 함수 등 참조 유형의 값은 객체이며 힙 메모리에 저장됩니다.

어둡고 얕은 복사본의 개념

참고: 어두운 복사본과 얕은 복사본의 차이점은 배열 및 개체와 같은 복잡한 개체에만 적용됩니다.

1. 얕은 복사: 원본 데이터의 메모리 주소만 복사합니다. 이는 동일한 주소를 가리키는 두 개의 데이터 포인터에 해당합니다.

2. 딥 카피: 두 데이터는 서로 다른 주소를 가리키며 데이터 요소가 변경되더라도 서로 영향을 미치지 않습니다.

예제 연구

1. 얕은 복사

var arr = [0, 1, 2];
var arrB;
 
//把arr赋值给arrB
arrB = arr;
console.log("arr:", arr);
console.log("arrB:", arrB);
console.log("-----------改变arrB中数组元素的值后-----------");
arrB[0] = 5;
console.log("arr:", arr);
console.log("arrB:", arrB);

작업 결과: arrB 배열 요소가 변경됨에 따라 arr 배열 요소도 변경됩니다.

2. Deep Copy(깊은 복사의 첫 번째 레이어만 수행됨)

참고: Deep Copy를 사용할 때 이를 수행할 때 전체 복사에 대한 요구 사항을 명확히 해야 합니다. 이는 첫 번째 수준 개체 특성이나 배열 요소의 전체 복사본인가요, 아니면 모든 수준의 개체 특성 및 배열 요소에 대한 재귀적 복사본인가요?

Deep copy array

①. 직접 순회

var arr = [1, 2, 3, 4];
function copy(arr){
    var newArr = [];
    for(var i=0;i<arr.length;i++){
        newArr.push(arr[i]);
    }
    return newArr;
}
 
var arrB = copy(arr);
console.log("arrB:", arrB);
console.log("-----------改变arrB中数组元素的值后-----------");
arrB[0] = 5;
console.log("arr:", arr);
console.log("arrB:", arrB);

실행 결과: arrB 배열 요소의 변경은 arr 배열 요소의 값에 영향을 주지 않습니다.

②. concat(): 두 개 이상의 배열을 연결하는 데 사용됩니다. 이 메서드는 기존 배열을 수정하지 않고 단순히 연결된 배열의 복사본을 반환합니다.

var arr = [0, 1, 2];
var arrB;
 
//把arr赋值给arrB
arrB = arr.concat();
console.log("arr:", arr);
console.log("arrB:", arrB);
console.log("-----------改变arrB中数组元素的值后-----------");
arrB[0] = 5;
console.log("arr:", arr);
console.log("arrB:", arrB);

실행 결과: arrB 배열의 요소 변경으로 인해 arr 배열의 요소가 변경되지 않았습니다

3.slice(): 이 메서드는 기존 배열에서 가로채온 요소 조각의 일부를 반환하여 새 배열(원래 배열은 변경되지 않음) .

var arr = [0, 1, 2, 4, 5];
var arrB;
 
//把arr赋值给arrB
arrB = arr.slice();
console.log("arr:", arr);
console.log("arrB:", arrB);
console.log("-----------改变arrB中数组元素的值后-----------");
arrB[0] = 10;
arr[4] = 8;
console.log("arr:", arr);
console.log("arrB:", arrB);

작업 결과: 배열 요소의 변경 사항은 서로 영향을 미치지 않습니다.

위의 세 가지 방법은 배열 요소가 기본 데이터 유형인 단순 배열과 첫 번째 수준 배열 요소가 있는 배열에만 적합합니다. 객체나 배열과 같은 참조 유형 변수 일반적으로 위의 모든 방법은 효과적이지 않습니다.

관련 권장 사항: javascript 학습 튜토리얼

위 내용은 자바스크립트에서 깊은 복사와 얕은 복사의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
usestate ()로 상태 관리 : 실용적인 자습서usestate ()로 상태 관리 : 실용적인 자습서Apr 24, 2025 pm 05:05 PM

Usestate는 클래스 구성 요소 및 기타 상태 관리 솔루션보다 우수합니다. 국가 관리를 단순화하고 코드를 더 명확하게하고 읽기 쉽고 React의 선언적 특성과 일치하기 때문입니다. 1) Usestate는 함수 구성 요소에서 상태 변수를 직접 선포 할 수있게합니다. 2) 후크 메커니즘을 통해 다시 렌더링하는 동안 상태를 기억합니다.

usestate ()를 사용하고 대체 상태 관리 솔루션을 고려할 때usestate ()를 사용하고 대체 상태 관리 솔루션을 고려할 때Apr 24, 2025 pm 04:49 PM

useUsestate () forlocalcomponentStateManagement; 고려 사항 forglobalstate, complexlogic, orperformanceissues.1) usestate () isidealforsimple, localstate.2) useglobalstatesolutionslikereduxorcontextforsharedstate.3) optforredooxtoolkitormobxcomcoccomcoccomcoccomcoccomcoccomcoccomcoccomcoccomporccomcoccomporccomcoccomport

React의 재사용 가능한 구성 요소 : 코드 유지 관리 및 효율성 향상React의 재사용 가능한 구성 요소 : 코드 유지 관리 및 효율성 향상Apr 24, 2025 pm 04:45 PM

reusablecomponentsinreacececodemainabenabilityandefficiency는 hallowingesamecomponentacrossdifferentpartsofanapplicationorprojects.1) 그들을 retuduceredundancyandsimplifyupdates.2) theyseconsistencyinuserexperience.3) theyquireoptim

React의 가상 DOM : 효율적인 업데이트를 통한 성능 향상React의 가상 DOM : 효율적인 업데이트를 통한 성능 향상Apr 24, 2025 pm 04:41 PM

thevirtualdomisAlightIgentin-memorycopyofTherealDoModedByReaCtTooptimizeUiUpdates.itboostSperformanceByminiMizingDirectDomManipulationThevirtOdMomfirst, thenecessAppledOnyCesseAcTeActualDom.

HTML 및 React의 통합 : 실용 가이드HTML 및 React의 통합 : 실용 가이드Apr 21, 2025 am 12:16 AM

HTML 및 React는 JSX를 통해 완벽하게 통합하여 효율적인 사용자 인터페이스를 구축 할 수 있습니다. 1) JSX를 사용하여 HTML 요소를 포함시킵니다. 2) Virtual DOM을 사용하여 렌더링 성능을 최적화, 3) 구성 요소화를 통해 HTML 구조를 관리하고 렌더링합니다. 이 통합 방법은 직관적 일뿐 만 아니라 응용 프로그램 성능을 향상시킵니다.

React 및 HTML : 데이터 렌더링 및 처리 이벤트React 및 HTML : 데이터 렌더링 및 처리 이벤트Apr 20, 2025 am 12:21 AM

상태 및 소품을 통해 데이터를 효율적으로 렌더링하고 합성 이벤트 시스템을 통해 사용자 이벤트를 처리합니다. 1) usestate를 사용하여 카운터 예제와 같은 상태를 관리하십시오. 2) 버튼 클릭과 같은 JSX에 함수를 추가하여 이벤트 처리가 구현됩니다. 3) Todolist 구성 요소와 같은 목록을 렌더링하려면 주요 속성이 필요합니다. 4) 양식 처리의 경우 양식 구성 요소와 같은 usestate 및 e.preventDefault ().

백엔드 연결 : 반응이 서버와 상호 작용하는 방법백엔드 연결 : 반응이 서버와 상호 작용하는 방법Apr 20, 2025 am 12:19 AM

반응은 HTTP 요청을 통해 서버와 상호 작용하여 데이터를 획득, 전송, 업데이트 및 삭제합니다. 1) 사용자 작동 이벤트 트리거, 2) HTTP 요청 시작, 3) 프로세스 서버 응답, 4) 구성 요소 상태 및 재 렌더 업데이트.

React : 사용자 인터페이스 (Frontend)에 중점을 둡니다.React : 사용자 인터페이스 (Frontend)에 중점을 둡니다.Apr 20, 2025 am 12:18 AM

React는 구성 요소 개발 및 가상 DOM을 통해 효율성을 향상시키는 사용자 인터페이스를 구축하기위한 JavaScript 라이브러리입니다. 1. 구성 요소 및 JSX : JSX 구문을 사용하여 구성 요소를 정의하여 코드 직관과 품질을 향상시킵니다. 2. 가상 DOM 및 렌더링 : 가상 DOM 및 DIFF 알고리즘을 통해 렌더링 성능을 최적화합니다. 3. 상태 관리 및 고리 : usestate 및 useffect와 같은 후크는 상태 관리 및 부작용 처리를 단순화합니다. 4. 사용의 예 : 기본 양식에서 고급 글로벌 주 관리에 이르기까지 ContextApi를 사용하십시오. 5. 일반적인 오류 및 디버깅 : 부적절한 상태 관리 및 구성 요소 업데이트 문제를 피하고 ReactDevTools를 사용하여 디버그를 사용하십시오. 6. 성능 최적화 및 최적 성

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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.