상세 컨텐츠

본문 제목

객체

Javascript

by loeybho 2023. 9. 27. 09:18

본문

객체란?

다양한 타입의 값(원시 값 또는 객체)을 하나의 단위로 구성한 복합적인 자료구조(data structure)

원시값은 변경 불가능한 값(immutable value)이지만, 객체는 변경가능한 값(mutable value)이다.

var person = {

name: ‘Lee’, ⇒ property

age(key): 20(value), ⇒ property

increase: function(){

this.num++;

}

};

자바스크립트의 함수는 일급 객체이므로 값으로 취급할 수 있다.

값으로 취급된다는 것은 변수에 할당할 수 있고, 함수의 인자로 전달 가능, 함수의 리턴값으로 사용할 수 있음을 의미한다.

상태와 동작을 하나의 단위로 구조화 할 수 있어 유용하다.

객체를 생성하는 방법

  1. 객체 리터럴
    객체 리터럴의 중괄호는 코드 블록을 의미하지 않는다. 객체 리터럴은 값으로 평가되는 표현식이다. 따라서 객체 리터럴의 닫는 중괄호 뒤에는 세미콜론을 붙인다.
    1. 프로퍼티 접근
      1. 마침표 표기법(.)
      2. 대괄호 표기법 […]

원시 값과 객체의 비교

원시값을 변수에 할당하면 변수(확보된 메모리 공간)에는 실제 값이 저장된다. 이에 비해 객체를 변수에 할당하면 변수(확보된 메모리 공간)에는 참조 값이 저장된다.

값에 의한 전달(pass by value)

원시 값을 갖는 변수를 다른 변수에 할당하면 원본의 원시값이 복사되어 전달된다.

var score = 80;
var copy = score;

console.log(score, copy);
console.log(score === copy);
// score와 copy는 숫자 값 80을 갖는다는 점에서는 동일하지만, score와 copy의 값 80은
// 다른 메모리 공간에 저장된 별개의 값이다.

참조에 의한 전달(pass by reference)

객체를 가리키는 변수를 다른 변수에 할당하면 원본의 참조 값이 복사되어 전달된다.

원시값

한번 생성된 원시 값은 읽기 전용(read only)으로 변경할 수 없다.

변수: 하나의 값을 저장하기 위해 확보한 메모리 공간 자체, 메모리 공간을 식별하기 위해 붙인 이름.

값: 변수에 저장된 데이터

변경 불가능 하다는 것은 변수가 아니라 값에 대한 진술이다.

원시값은 변경 불가능하다는 말은 원시 값 자체를 변경할 수 없다는 것이지 변수값을 변경할 수 없다는 것이 아니다. 변수는 언제든지 재할당을 통해 변수 값을 교체할 수 있다. 그렇기 때문에 변수라고 부른다.

const 로 선언한 변수에 할당된 원시값은 변경할 수 없다.

하지만, const 로 선언한 변수에 할당된 객체는 변경할 수 있다.

원시값을 할당한 변수에 새로운 원시값을 재할당하면, 메모리 공간에 저장되어 있는 재할당 이전의 원시값을 변경하는 것이 아니라 새로운 메모리 공간을 확보하고 재할당한 원시값을 저장한 후, 변수는 새롭게 재할당한 원시 값을 가리킨다. 이때 변수가 참조하던 메모리 공간의 주소가 바뀐다.

문자열은 유사 배열 객체이면서 이터러블이므로 배열과 유사하게 각 문자에 접근할 수 있다.

유사 배열 객체란?

마치 배열처럼 인덱스로 프로퍼티 값에 접근할 수 있고, length 프로퍼티를 갖는 객체를 말한다. 문자열은 마치 배열처럼 인덱스를 통해 각 문자에 접근할 수 있으며, length 프로퍼티를 갖기 때문에 유사 배열 객체이고 for문으로 순회할 수도 있다.

객체

변수는 객체를 가리킨다, 참조하고 있다 라고 이야기한다.

변수에 저장되어 있는 참조값으로 실제 객체에 접근한다.

객체는 변경 가능한 값이다. 재할당없이 프로퍼티를 동적으로 추가할 수 있고, 프로퍼티 값을 갱신할 수도 있으며 프로퍼티 자체를 삭제할 수도 있다.

객체는 변경 가능한 값이기에 메모리에 저장된 객체를 직접 수정할 수 있다.

얕은 복사와 깊은 복사

얕은 복사(shallow copy)

한단계까지만 복사하는 것을 의미

깊은 복사(deep copy)

객체에 중첩되어있는 객체까지 모두 복사하는 것을 의미

var a = 1;
var b = 1;
console.log(a, b, a === b); // 1, 1, true

var c = { name: "byeol" };
var d = { name: "byeol" };
console.log(c, d, c === d); // 1, 1, false

스크린샷 2024-03-07 오후 8.08.45.png

concat()

기존의 배열을 수정하는 게 아닌, 새로운 배열으로 반환하는 것.

참조에 의한 전달

객체를 가리키는 변수(원본)를 다른 변수(사본)에 할당하면 원본의 참조 값이 복사되어 전달된다.

원본과 사본은 저장된 메모리 주소는 다르지만 동일한 참조 값을 갖는다. 이것은 두개의 식별자가 하나의 객체를 공유한다는 것을 의미한다.

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

'Javascript' 카테고리의 다른 글

콜백 지옥(callback)  (0) 2024.02.20
Promise  (0) 2024.02.19
비동기 통신  (0) 2024.02.19
함수  (0) 2023.09.25
자바스크립트 - 웹과 자바스크립트  (0) 2023.09.22

관련글 더보기