공부공부/JS 딥다이브

[js 딥다이브] 11장 원시값과 객체의 비교

고생쨩 2023. 10. 19. 10:35
728x90
  • 원시 값은 변경 불가능한 값
  • 객체는 변경 가능한 값
  • 원시 값을 변수에 할당하면 변수에는 실제 값이 저장됨. 객체를 변수에 할당하면 변수에는 참조값이 할당됨.
  • 값에 의한 전달 : 원시 값을 갖는 변수를 다른 변수에 할당하면 원시 값이 복사되어 전달됨.
  • 참조에 의한 전달 : 객체를 가르키는 변수를 다른 변수에 할당하면 참조 값이 복사되어 전달됨.

11.1 원시값

11.1.1 변경 불가능한 값

  • 원시값이 변경 불가능한 건 변수가 아니라 값이 변경 불가능하단 의미임. (메모리에 위치한 값)
  • 변수는 언제든지 재할당을 통해 변수 값을 교체할 수 있음(다른 메모리에 저장 / 4장 참고)
  • 상수는 재할당이 금지된 변수 (단 한번만 할당이 허용됨)

11.1.2 문자열과 불변성

  • 문자열은 0개 이상의 문자로 이루어진 집합을 말함
  • 1개의 문자는 2바이트의 메모리 공간에 저장됨. (숫자의 경우 8 바이트)
  • 문자열은 유사 배열, 생성된 문자열은 변경불가능한 값
var str = 'string';
// 문자열은 유사 배열이므로 배열과 유사하게 인덱스를 사용해 각 문자에 접근할 수 있다.
console.log(str[0]); // s
// 원시 값인 문자열이 객체처럼 동작한다.
console.log(str.length); // 6
console.log(str.toUpperCase()); // STRING
str[0] = 'S';
console.log(str); // string
  • str[0] = 'S'; 처럼 이미 생성된 문자열의 일부를 변경해도 반영되지 않음. 원시값이기 떄문

11.1.3 값에 의한 전달

  • 값에 의한 전달 : 원시값을 복사하여 전달.
  • 같은 값이지만 다른 메모리 공간에 저장된 별개의 값임
var score = 80;

var copy = score;

console.log(score, copy); // 80, 80
console.log(score === copy); // true

11.2 객체

11.2.1 변경 가능한 값

  • 객체(참조) 타입의 값, 즉 객체는 변경 가능한 값
// 할당이 이뤄지는 시점에 객체 리터럴이 해석되고, 그 결과 객체가 생성됨
var person = {
 name: 'Girl'
}

// person 변수에 저장되어 있는 값으로 실제 객체에 접근
console.log(person); // { name: 'Girl' }
  • 객체 생성시 실제 값을 별도 메모리에 저장하고 식별자는 실제 값으로 연결되는 참조값을 저장함.
  • 객체는 변경 가능한 값이므로 프로퍼티값을 추가, 갱신, 삭제가 가능하다.
  • 프로퍼티 값을 변경 시 객체를 할당한 변수의 참조값은 변경되지 않음
  • 해당 특성으로 여러개의 식별자가 하나의 객체를 공유할 수 있음.

얕은 복사와 깊은 복사
기존에 정리한 내용 참조 -> https://girldevstudy.tistory.com/9

11.2.2 참조에 의한 전달

  • 참조에 의한 전달 : 객체를 가르키는 변수를 다른 변수에 할당하면 원본의 참조 값이 복사되어 전달됨.
  • 두개의 식별자가 하나의 객체를 공유하는 것을 의미

결론

  • 값에 의한 전달참조에 의한 전달은 식별자가 기억하는 메모리 공간에 저장되어 있는 값을 복사해서 전달하는 면에서 동일함.
  • 다만 식별자가 기억하는 메모리 공간에 저장되어 있는 값이 참조값이냐 원시값이냐의 차이

퀴즈

var person1 = {
 name: 'Lee'
};

var person2 = {
 name: 'Lee'
};

console.log(person1 === person2); // ① false
console.log(person1.name === person2.name); // ② true
  • ① 의 경우 다른 메모리에 저장된 별개의 객체임
  • ② 의 경우 원시값이기때문에 프로퍼티의 값과 타입만 비교

이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다.