sharingStorage

참조에 의한 객체 복사 본문

Front-End/Javascript

참조에 의한 객체 복사

Anstrengung 2021. 12. 28. 14:07

객체와 원시 타입(int, string..)의 근본적인 차이 중 하나는 객체는 '참조에 의해(by reference)' 저장되고 복사된다는 것입니다.

반면 원시값 (문자열, 숫자, 불린 값)은 값 그대로 저장 할당되고 복사됩니다.

 

let message= "Hello";
let phrase= message;

console.log(message); //Hello
console.log(phrase); //Hello

console.log의 결과값이 같은 것을 보아 두 변수에 각각 Hello라는 문자열이 저장되었음을 알 수 있습니다.

 

 

하지만 객체의 동작방식은

객체가 저장되어있는 메모리주소인 객체에 대한 참조값이 저장됩니다.

let user={name: "Jone"};
let admin=user;

admin.name='Pete';
alert(user.name); //Pete가 출력됨

각 변수에는 동일 객체에 대한 참조값이 저장됨을 알 수 있다.

 

 

참조에 의한 비교

let a = {};
let b = a; // 참조에 의한 복사

alert( a == b ); // true, 
alert( a === b ); // true

두 변수는 같은 객체를 참조합니다.

하지만 독립된 두 객체는 비교시 false를 반환합니다

let a = {};
let b = {}; // 독립된 두 객체

alert( a == b ); // false
alert( a === b ); // false

 

 

 

객체 복사, 병합과 

객체를 복사하는 방법

let student={
	name: "Lee",
	age: 24
};

let clone={};

//빈 객체에 user 프로퍼티 전부를 빈 객체에 복사해서 넣는다.
for (let key in user) {
  clone[key] = student[key];
}

clone.name="Kim";

alert(user.name); //Lee
alert(clone.name); //Kim

clone은 완전히 독립적인 복제본입니다.

 

Object.assign

Object.assign(dest, [src1, src2, ...])

Object.assign(목표로하는 객체, 복사하고자하는 객체1, 복사하고자하는 객체2, ...);

 

EX)

let user = { name: "John" };

let permissions1 = { canView: true };
let permissions2 = { canEdit: true };

// permissions1과 permissions2의 프로퍼티를 user로 복사합니다.
Object.assign(user, permissions1, permissions2);

// now user = { name: "John", canView: true, canEdit: true

 

중첩 객체는 객체안에 또 객체가 들어있는 구조로

중첩 객체 복사는 프로퍼티만를 복사하는 것만으로는 복사 불가능 

깊은복사 (deep cloning) 방식을 사용해야한다.

 

이는 javascript 라이브러리 lodash의 메서드인 _.cloneDeep(obj)를 사용하면 알고리즘 구현없이 가능하다.

 

 

참고자료: https://ko.javascript.info/object-copy  

'Front-End > Javascript' 카테고리의 다른 글

JSON  (0) 2022.03.17
RxJS  (0) 2021.12.29
Comments