데이터 타입의 종류

기본형 타입(Primitive Type) 참조형 타입(Reference Type)

숫자(Number)
문자열(String)
불리언(Boolean)
null
undefined
심볼(Symbol)

객체(Object)
배열(Array)
함수(Function)
날짜(Date)
정규표현식(RegExp)
Map
WeakMap
Set
WeakSet

 

 

기본형 타입(Primitive Type)

기본형 타입의 종류에는 숫자, 문자열, 불리언, null, undefined, symbol이 있습니다.

일반적으로 기본형은 '할당이나 연산시 데이터가 복제'된다고 알려져있습니다.

 

 

기본형 타입의 메모리 저장 방식

*메모리 할당영역, 주솟값에 대한것은 이해를 돕기위한 개략적인 이미지들이 등장합니다.

 

메모리 할당 시 두 영역을 사용한다고 생각하면 쉽습니다.

  • 식별자가 할당되는 변수 영역

  • 데이터 값이 담기는 데이터 영역

변수 영역에는 식별자와 데이터 영역의 주솟값으로 이루어져있습니다.

데이터 영역에는 데이터가 담겨있습니다.

 

 

예시1) 변수 선언

var name = '홍길동';

개략적이미지 - 기본형타입 예시1. 변수선언

변수 영역(1002)에 식별자(변수명)를 name으로 할당합니다.

데이터 영역(5000)에 문자열 '홍길동' 데이터를 할당합니다.

식별자 name의 변수 영역에 데이터 영역의 주솟값을 값에 연결해줍니다.

 

사용자가 식별자 name을 호출했을때,

해당 변수 영역 값에 연결된 주솟값(5000)에 담긴 데이터가 반환됩니다.

 

 

예시2) 데이터 재할당

var name = '홍길동';
name = '고길동';

개략적이미지 - 기본형타입 예시2. 데이터 재할당

새로운 데이터이므로 비어있는 데이터 영역(5001)에 문자열 '고길동'을 할당합니다.

식별자 name에 변수 영역에 해당하는 데이터 영역의 주솟값(@5000 -> @5001)으로 변경해줍니다.

 

 

예시3) 변수에 변수를 대입

var name = '홍길동';
var name2 = name;

개략적이미지 - 기본형타입 예시3. 변수에 변수를 대입1

비어있는 변수 영역(1003)에 식별자 name2를 할당하고

name2의 데이터 주소에 name의 주솟값(5000)을 가져와 할당합니다.

name2의 데이터가 변경되는 부분을 이어서보겠습니다.

var name = '홍길동';
var name2 = name;
name2 = '고길동';

개략적이미지 - 기본형타입 예시3. 변수에 변수를 대입2

새로운 문자열 '고길동'을 비어있는 데이터 영역(5001)에 할당하고 식별자 name2의 주솟값을 변경해줍니다.

 

 

?????!

여기서 궁금한 점이 등장합니다.

데이터 영역에 문자열 '홍길동'을 넣었다가 문자열 '고길동'으로 변경했을때,

해당 영역의 데이터를 수정하지 않고 오ㅐ? 새로운 메모리 영역을 사용하는가?

이것을 이해하기위해서는 불변성을 이해해야합니다.

 

 

불변성(Immutability)

단순히 정의만을 말하자면 '변하지 않는 성질'이라고 할 수 있습니다.

하지만 불변성이 해당하는 부분이 어디인지를 확실히 이해해야합니다.

불변성은 변수와 상수의 개념으로 말하는 것이 아닙니다.

 

변수와 상수변수 영역 메모리에 데이터 할당 후 재할당이 되는지에 대한 여부로 구분되는 것이며

불변성데이터 영역의 메모리에 대한 것 입니다.

 

예시로 간단히 보겠습니다.

var name = '홍길동';
name = '고길동';

 

변수

개략적이미지 - 불변성 예시1. 변수

식별자 name의 변수 영역에 값이 문자열 '홍길동'에서 '고길동'으로 재할당이 되었으므로

해당 데이터 영역 주솟값으로 변경해줍니다. 

(5000 -> 5001)

변수는 이처럼 데이터 영역의 주솟값 재할당이 가능합니다. (재할당)

 

상수

개략적이미지 - 불변성 예시2. 상수

상수는 데이터 주솟값 재할당이 안되므로

식별자 name의 변수 영역에 데이터 값 변경이 불가능합니다.

 

불변성

개략적이미지 - 불변성 예시3. 불변성1

불변성은 식별자 변수 영역에 해당하는 데이터 값의 재할당이 기준이아니고

데이터 영역의 데이터가 변경이 가능한지에 대한 여부입니다.

즉 문자열 '홍길동'에서 '고길동'으로 변경되었을때, 데이터 영역의 데이터는 변경할 수 없습니다.

 

개략적이미지 - 불변성 예시3. 불변성2

불변성에 의해 비어있는 데이터 영역에 새로 문자열 '고길동'을 할당 한 후

식별자 name의 데이터 주솟값이 재할당됩니다.

 

위의 예시에서 알 수 있듯,

데이터 영역의 데이터는 한번 생성되었을 경우 수정이 안되며(불변성)

새로운 데이터일 경우 비어있는 데이터 영역에 새로 할당됩니다.

그리고 새로 할당된 데이터 영역의 주솟값을 변수 영역의 데이터 주솟값으로 재할당하는 것입니다.

즉, 데이터 영역의 변경이란 새로 만드는 동작에서만 이루어집니다.

 

불변성은 왜 필요한거지?라는 의문이 또 한번 머리에 스쳐지나갈 수 있습니다.

간단하게, 메모리 저장에 대한 이야기를 해보겠습니다.

메모리에 데이터를 저장하기 위해서는 메모리 공간을 선행으로 확보해야합니다.

불변성이 없다고 생각했을때,

처음 저장한 데이터의 크기보다 더 큰 데이터를 '재할당' 해야한다면 어떤일이 생길까요?

데이터 공간을 재확보해야하는 일이 생깁니다.

그리고 이 재확보작업을 하게되면 뒤에 저장된 메모리들의 공간이 뒤로 밀리는 현상이 생기고 

이 현상으로 인해 각각의 주솟값들을 식별자에 다시 연결해야하는 작업이 발생할 수 있습니다.

위와 같은 이유로 불변성은 효율적으로 데이터를 저장하기 위해 생겼습니다.

 

 

참조형 타입(Reference Type)

참조형 타입의 종류는 객체, 배열, 함수, 날짜, 정규표현식, Map, WeakMap, Set, WeakSet이 있다.

일반적으로 참조형은 '참조된다'고 알려져있습니다.

 

 

참조형 타입의 메모리 저장 방식

*메모리 할당영역, 주솟값에 대한것은 이해를 돕기위한 개략적인 이미지들이 등장합니다.

 

 

예시1) 변수 선언

var person = {
	name : '홍길동',
    age : 123
};

 

개략적이미지 - 참조형타입 예시1. 변수선언

기본형타입과 마찬가지로 변수 영역, 데이터 영역이 존재합니다.

식별자 person 변수 영역에 데이터 영역 주솟값을 연결해줍니다.

하지만 참조형타입은 영역이 하나 더 존재합니다.

'객체의 변수(프로퍼티) 영역'입니다.

 

데이터 영역 주솟값에 데이터가 바로 할당되는 것이 아니라 객체의 프로퍼티 영역의 주솟 값(7000~7001)이 연결됩니다.

그리고 해당 객체의 프로퍼티 영역에 데이터 영역의 주솟값을 연결해줍니다.(name-5002 / age-5003)

 

위에서 데이터 영역은 불변하다고 말했던 것처럼 참조형 데이터도 데이터 영역은 불변하다고 할 수 있습니다.

하지만  

기본형 타입은 불변성을 띄고 참조형 타입은 불변하지 않다(가변성)고들 말한다고 하는데,

그 이유를 짚어보겠습니다.

 

 

예시2) 참조형타입은 가변성을 띄는가

var person = {
	name : '홍길동',
    age : 123
};

person.name = '고길동';

개략적이미지 - 참조형타입 예시2. 참조형타입은 가변성을 띄는가

식별자 person의 변수 영역의 값과 데이터 영역(5000)의 값이 변경되지 않았습니다.

하지만 객체의 프로퍼티 영역의 데이터 주솟값이 변경된 것이 확인 되는데, 

이같은 부분을 보고 가변성을 띈다고 하는 것입니다.

 

간단히 말해..

person의 데이터 영역은 불변성을 띄지만,

person의 객체의 프로퍼티 영역은 가변성을 띈다고 할 수 있습니다.

 

 

예시3) 참조형 타입이 참조인이유

var person = {
	name : '홍길동'
};

var person2 = person;

개략적이미지 - 참조형타입 예시3. 참조형 타입이 참조인 이유1

식별자 person의 값을 person2에 대입하게되는 경우에 위와 같이 같은 데이터 영역의 주솟값을 가지게 됩니다.

이 부분은 기본형 타입과 참조형 타입 둘 다 동일합니다.

두 타입의 차이는 데이터 영역, 객체의 프로퍼티 영역에서 확인할 수 있습니다.

아래와 같이 식별자 person2의 name 프로퍼티의 데이터를 수정하게 될 경우 생기는 변화에 대해 확인해보겠습니다. 

var person = {
	name : '홍길동'
};

var person2 = person;
person2.name = '고길동';

개략적이미지 - 참조형타입 예시3. 참조형 타입이 참조인 이유2

변수 영역의 주솟값이나 데이터 영역의 주솟값은 변경되지 않습니다.

name 프로퍼티만 변경된 것이므로 해당 객체의 프로퍼티 영역에서 데이터 주솟값을 변경합니다.

즉, 5002에서 5003으로 변경합니다.

이때 해당 객체의 프로퍼티 영역의 주솟값만 변경하므로 변수 영역, 데이터 영역을 참조하고 똑같이 참조하고 있던

person역시 영향을 받습니다.

var person = {
	name : '홍길동'
};

var person2 = person;
person2.name = '고길동';

console.log(person.name); // '고길동'

 

 

예시4) 객체끼리 참조하지 못하게 하려면

var person = {
	name : '홍길동',
    age : 123
};

var person2 = person;

person2 = {
	name : '홍길동'
    age : 300
};

개략적이미지 - 참조형타입 예시4. 객체끼리 참조하지 못하게 하려면

식별자 person의 객체를 person2에 대입하고나서 새로운 객체로 데이터 자체를 변경해버리면 불변성을 유지할 수 있습니다.

객체 자체를 재 선언해버리면 새로운 객체의 프로퍼티 영역이 생기게 되고 이때 연결된 기존 객체 프로퍼티 영역의 주솟값이 변경되어 버리므로 서로 참조하지 않습니다.

(객체의 프로퍼티영역이 각각 생김)

 

즉, 참조형 데이터가 가변성을 띈다라고 말할수 있는 부분은

참조형데이터 자체를 변경할 때가 아닌 내부 프로퍼티를 변경하는경우에만 성립됩니다.

(참조되는 객체의 불변성을 지키기위해 복사하여 사용하기도합니다.)

 

하지만 어떠한 데이터 타입이든 변수에 할당하기 위해서는 데이터를 직접 할당하는 것이 아닌 데이터 영역의 주솟값을 복사하기 때문에 자바스크립트의 모든 데이터 타입은 참조형 데이터일 수 밖에 없습니다. 

기본형도 결국 주솟값을 참조하는 형태입니다.

다만 기본형은 주솟값을 데이터 영역에서 한번 만 복사해오고 참조형은 객체의 프로퍼티 영역 한단계를 더 거치는 차이가 있습니다.

 


출처

 

'개념' 카테고리의 다른 글

클로저(Closure)  (0) 2021.01.01
this  (0) 2020.12.09
실행 컨텍스트(Execution context)  (0) 2020.12.09
undefined와 null  (0) 2020.12.09
변수(Variable)와 식별자(Identifier)  (1) 2020.12.08
Chrome 80 SameSite 속성 동작 변경  (0) 2020.06.26
[jQuery기초] 버전별 특성  (0) 2020.06.18
[jQuery기초] jQuery란?  (0) 2020.06.17

변수(Variable)와 식별자(Identifier)

 

들어가기 전에...

사람들은 변수(Variable)식별자(Identifier)를 혼용하는 경우가 많습니다.

"내가 혼용했었나?"라고 의문이 들면서 이해가가지 않을 수도 있습니다.

 

혼용을 하면서도 인지하지 못하는 경우가 많기 때문인데,

첫번째로는, 대화의 문맥에 따라 혼용하더라도 상대방이 어떠한 말을 하는지 유추할 수 있기 때문이고

두번째로는, 애초에 혼용해서 사용해왔기때문에 그 차이를 이해하지 못하고 같은 의미로 사용하기때문입니다.

 

"변수 name을 선언 안 한 것 같은데"

가 아닌,

"식별자 name을 선언 안 한 것 같은데"

가 정확한 문장이라면

 

읭? 이러실 수도 있습니다.

제가 읭? 이랬거든요.

 

 

변수(Variable)

변수라는 이름은 '변할 수 있는 수'라는 뜻으로 수학용어를 차용했다고합니다.

즉, 변경 가능한 데이터를 뜻하며 '데이터가 담길 수 있는 공간 또는 그릇'을 말합니다.

그리고 변수라는 이름을 수학용어에서 차용했다고해서 변수에 담기는 데이터가 '숫자'여야만 하는 것은 아닙니다.

 

 

식별자(Identifier)

변수가 되는 어떤 데이터를 식별하는 데 사용하는 이름을 말합니다.

변수명입니다.

 

 

변수식별자 알아보기

자바스크립트에서는 var, let, const 키워드를 통해 변수를 선언할 수 있습니다.

예시에서는 var를 통해 선언하겠습니다.

var name = '홍길동';

문자열 '홍길동' 데이터 값이 변수에 할당됩니다.

이 변수의 식별자(변수의 명)는 name이라고 할당합니다.

 

메모리 할당 개략적 표현1
메모리 할당 개략적 표현2

 

 

두 개념을 정확히 이해하고 분리해서 사용한다고 해서 뭐 달라지는 것? 없습니다.

하지만 그렇다고 해서 변수와 식별자의 차이를 이해하지않고 사용하는것은 바람직하지 않습니다.

(알고보면 정말 간단하니 더더욱 말이죠)

 

모르고 혼용하던 날들을 반성하며,

앞으로는 알고 혼용하던지~ 말던지, 다짐하며 변수와 식별자 개념, 차이에 대해 공부해보았습니다.

 


지식 출처

코어 자바스크립트:핵심 개념과 동작 원리로 이해하는 자바스크립트 프로그래밍,(저자 정재남)

보안 강화를 위해 Chrome 80부터 SameSite의 기본 속성값이 None 에서 Lax로 변경되었습니다.

현재 Chrome 84 에서 코로나로 인해 기능을 롤백했지만 Chrome 84이후(안정적인 버전, 7/14일 이후) 다시 재개할 계획이라고 합니다.

해당 속성의 변화는 Chrome 80 이상의 웹 브라우저만 해당하며 이후 Firefox, Edge등의 브라우저도 동일하게 적용한다고 합니다.

<img>, <form>, <iframe>, <link>, <a> 등에서 영향이 있습니다.

Android의 chrome에는 적용하지 않으며 iOS의 chrome은 영향이 없습니다.

 

SameSite 3가지 속성

None 

쿠키 사용에 있어서 소스가 되는 주소를 검증하지 않습니다.

동일 사이트, 크로스 사이트에 모두 쿠키 전송이 가능합니다.

 

Strict

보안 정책으로 다른 도메인일 경우 전송을 차단합니다.

소스가 되는 주소의 도메인과 요청하는 도메인이 일치하는지를 확인하여 일치할 경우에만 쿠키가 전송됩니다.

예시

www.google.com → www.google.com (O)

www.google.com → www.naver.com (X)

 

Lax

Strict 설정의 일부를 예외로 두고 동일하게 동작합니다.

예시

<a href>
<link href>
<form method=get>

 

예시

기본 값이 Lax로 변경함에 따라 None으로 설정하지 않으면 Lax가 적용됩니다.

None 설정 시 Secure 키워드를 같이 적용해야합니다.

 

Javascript 설정 예시

document.cookie = "name=yoon";
document.cookie = "name=yoon; SameSite=Lax"; // 위와 같다

document.cookie = "name=yoon; SameSite=None; Secure"; // Secure 추가

서버 설정에서 한번에 모든 쿠키 속성을 변경할 수도 있습니다.

 

마무리

SameSite 속성은 사용자에게 불편을 줄 수 있지만 CSRF(사이트 간 요청 위조, Cross-site request forgery) 보안을 강화할 수 있습니다.

소셜 미디어 플랫폼, 타 회사의 사이트와 연동된 페이지가 있는 경우에는 Strict으로 할 경우 쿠키가 차단되므로 사용 시마다 인증해야되는 불편함이 생기기 때문에 쿠키를 사용할때에는 상황을 고려해서 사용해야합니다.

 

 


 

참고 및 정보 출처

 

 

 

참조링크

릴리즈 정보

업그레이드 가이드

 

호환성

Browser jQuery
IE 6~8 jQuery 1.x
IE 9+ jQuery 2.x
Android 4.x jQuery 3.x
Android 4.5+
Safari on IOS 7+
jQuery 3.x

 

 

구버전과 최신버전 혼용

jQuery Migrate Plugin

jQuery 하위 버전 호환성을 위해 제공하는 플러그인

<script src="http://code.jquery.com/jquery-1.9.0.js"></script>
<script src="https://code.jquery.com/jquery-migrate-3.3.0.min.js"></script>

v1.4.1 : jQuery 1.9 이하의 버전을 3.0 버전까지 지원

v3.3.0 : jQuery 1.x버전, 1.9 이상의 버전을 3.0 버전까지 지원

 

+ Recent posts