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
- ① 의 경우 다른 메모리에 저장된 별개의 객체임
- ② 의 경우 원시값이기때문에 프로퍼티의 값과 타입만 비교
'공부공부 > JS 딥다이브' 카테고리의 다른 글
[js 딥다이브] 13장 스코프 (0) | 2023.10.19 |
---|---|
[js 딥다이브] 12장 함수 (1) | 2023.10.19 |
[js 딥다이브] 10장 객체 리터럴 (0) | 2023.10.16 |
[js 딥다이브] 09장 타입변환과 단축평가 (0) | 2023.10.16 |
[js 딥다이브] 08장 제어문 (0) | 2023.10.16 |