Frontend/Javascript

Javascript - 데이터 타입

취업하고싶다! 2025. 1. 2. 20:21

 

 

원시타입과 객체타입

원시타입

  • 숫자타입(number): 숫자. 정수와 실수 구분없이 하나의 숫자타입만 존재
  • 문자열타입(string): 문자열
  • 불리언타입(boolean): 논리적 참, 거짓
  • undefined타입: var키워드로 선언된 변수에 암묵적으로 할당되는 값
  • null타입: 값이 없다는 것을 의도적으로 명시할 때 사용하는 값
  • 심벌타입(symbol): ES6에서 추가된 7번째 타입(다른 값과 중복되지 않는 유일무이한 값)

객체타입: 원시타입을 제외한 모든 것

 

 

Symbol타입

  • 주로 이름이 충돌할 위험이 없는 객체의 유일한 프로퍼티 키를 만들기 위해 사용
  • 심벌은 Symbol 함수를 호출해 생성한다.
    • 이 때 생성된 심벌 값은 외부에 노출되지 않는다.
    • 또한, 다른 값과 절대 중복되지 않는 유일무이한 값
var key = Symbol('key');
console.log(typeof key);  // symbol

// 객체 생성
var obj = {};

// 이름이 충돌할 위험이 없는 유일무이한 값인 심벌을 "프로퍼티 키"로 사용
obj[key] = 'value';
console.log(obj[key]);  // value

 

 

데이터 타입이 필요한 이유

1️⃣ 값을 저장할 때 확보해야 하는 "메모리 공간의 크기"를 결정하기 위해서
2️⃣ 값을 참조할 때 한 번에 읽어 들여야 할 "메모리 공간의 크기"를 결정하기 위해서
3️⃣ 메모리에서 읽어 들인 "2진수를 어떻게 해석"할지 결정하기 위해서

 

 

동적 타이핑

자바스크립트 변수는 선언이 아닌 할당에 의해 타입이 결정(= 타입 추론(type inference))된다. 그리고 재할당에 의해 변수의 타입은 언제든지 동적으로 변할 수 있다. 이러한 특징을 동적 타이핑(dynamic typing) 이라고 한다.

  • 이 관점에서, 변수는 타입을 가질까 ? 라는 질문
    • 기본적으로 변수 자체는 타입을 갖지 않는다.
    • 하지만, 값은 타입을 갖는다.
    • 따라서, 현재 변수에 할당되어 있는 값에 의해 변수의 타입이 동적으로 결정된다고 표현하는 것이 적절하다. 변수는 단지 값에 묶여있는 값에 대한 별명이기 때문
  • 자바스크립트는 정적 타입 언어 와 다르게 타입을 선언하지 않는다.
    • 다만 var, const, let 키워드를 사용해 변수를 선언할 뿐
    • 실질적인 값의 타입은 런타임(runtime)시 할당되는 값에 의해 결정된다.

 

동적 타이핑 언어 단점

동적 타입 언어는 유연성(flexibility) 은 높지만 신뢰성(reliability) 은 떨어진다.

  • 개발자의 의도와는 상관없이 자바스크립트 엔진에 의해 암묵적으로 타입이 자동으로 변환되기도 한다.
  • 복잡한 프로그램에서는 변화하는 변수 값을 추적하기 어려울 수 있다.
  • 값의 변경에 의해 타입도 언제든지 변경될 수 있다. → 동적 타입 언어의 변수는 값을 확인하기 전에는 타입을 확신할 수 없다.