inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

따라하며 배우는 자바스크립트 A-Z

얕은 복사 vs 깊은 복사

Shallow Freeze 관련 질문드립니다!

198

여노

작성한 질문수 1

0

// 얕은 동결 (shallow freeze)
const obj1 = {
    a: 1,
    b: 2,
    c: {
        d: 3,
        e: 4
    }
};
Object.freeze(obj1); // 얕은 동결
obj1.a = 10;
console.log(obj1); // {a: 1, b: 2, c: {d: 3, e: 4}}
obj1.c.d = 30;
console.log(obj1); // {a: 1, b: 2, c: {d: 30, e: 4}}

이렇게 작성했을 때 당연히 오른쪽 코멘트처럼 출력이 나올 것이라고 생각했었는데, 출력이 이렇게 나옵니다.

image.png

d가 첫 콘솔 로그에도 30으로 출력되는데, 이런 현상 관련해서 구글링을 해봐도 답을 찾기가 어려워 게시판에 질문 드립니다.

혹시 왜 이런지 알 수 있을까요?

javascript

답변 1

0

여노

답변을 찾은 것 같은데,, 맞는지 확실치 않아서 올려둡니다! 확인해주시면 감사하겠습니다.

이때 실제 예상값과 다르게 처음 로그도 d: 30으로 출력이 될 수 있다. 이는 브라우저 콘솔이 객체를 참조로 출력하기 때문인데, 그 객체의 내용이 나중에 변경되면 콘솔에 표시된 내용도 변경된 값을 반영할 수 있기 때문이다. 이와 관련하여 객체가 큰 경우나 디버깅 과정에서 혼란을 초래할 수 있으므로, 이런 경우에 깊은 복사하여 로그를 출력하면 된다.

const obj1 = {
    a: 1,
    b: 2,
    c: {
        d: 3,
        e: 4
    }
};

obj1.a = 10; // obj1.a의 값이 10으로 변경됨
console.log("First log:", JSON.parse(JSON.stringify(obj1)));
// 현재 상태를 문자열로 변환하여 깊은 복사 후 로그 출력
// {a: 10, b: 2, c: {d: 3, e: 4}}

obj1.c.d = 30; // obj1.c.d의 값이 30으로 변경됨
console.log("Second log:", JSON.parse(JSON.stringify(obj1)));
// 현재 상태를 문자열로 변환하여 깊은 복사 후 로그 출력
// {a: 10, b: 2, c: {d: 30, e: 4}}

3강 질문

0

13

1

74. 데이터 캐시 - 1 (이론) 강의 영상 누락

0

25

1

2강 nodejs 3단계 설명 질문

0

32

1

imagesLoaded에 관한 질문

0

19

2

useEffect와 lifecycle문의

0

26

2

프론트엔드 학습 수준 문의

0

37

2

리액트 챕터별 코드에서 eslint 설정파일이 없어요

0

47

2

최근 코테, 과제 테스트 트렌드

0

67

2

lucide react 아이콘 설치

0

46

2

17강 zustand store 서버에서 생성

1

36

1

주석처리한 buttons가 작동하는 이유

0

93

1

document 객체가 콘솔에 화면처럼 뜨질않는데 무슨이유일까요?

0

140

1

vscode 에서 LiveSever를 통해 연 페이지에 왜 코드가 바로 연동이 되어 출력이 안될까요??

0

169

1

Start 버튼을 연속으로 두 번 누르면 Stop버튼이랑 Reset 버튼이 작동하지 않습니다.

0

116

1

var 로 선언해서 window 객체의 프로퍼티로 만들기

0

137

1

랜덤 난수의 정수화

0

178

1

섹션9 Todo App 질문드립니다.

0

194

1

강의 자료 소스 복사

0

309

1

Todo App(1) 스타일 파일 코드

0

448

2

변수를 먼저 let val; 선언하는 이유가 있나요?

0

231

1

[섹션2 Document Object 이용해보기] lists라는 변수를 forEach를 사용하려면...

0

186

1

해당 강의의 index.html 소스코드 파일을 받고 싶습니다!

0

243

1

[Event Delegation] 요소의 id를 변수 선언 없이 바로 사용할 수 있는 이유?

1

394

1

얕은 복사가 주소만 복사하는 것 아닌가요?

0

495

1