Skip to content

Latest commit

 

History

History
128 lines (94 loc) · 3.86 KB

==,===.md

File metadata and controls

128 lines (94 loc) · 3.86 KB

==,===

==는 Equal Operator,
===는 Strict Equal Operator이다.

==와 ===의 차이점

  • =='와 '===' 연산자의 주된 차이점은, 예를 들어, 숫자를 숫자 리터럴과 비교하면, '=='는 그것을 허용하지만,
    '===' 두 변수의 형식은 동일하지 않은 경우, 값뿐만 아니라 두 변수의 유형도 확인하므로, 허용하지 않는 것이다.

  • 즉, '==='는 'false'으로 반환하고, '=='는 'true'로 반환다.

  • ==는 a == b 라고 할때, a와 b의 값이 같은지를 비교해서, 같으면 true, 다르면 false (값만 같으면 true)

  • ===는 Strict, 즉 엄격한 Equal Operator로써, "엄격하게" 같음을 비교할 때 사용하는 연산자이다.

  • ===는 a === b 라고 할때, 값과 값의 종류(Data Type)가 모두 같은지를 비교해서, 같으면 true, 다르면 false라고 한다.

 0값은 false와 동일하므로 -> true 출력

0 == false // true 
  피연산자의 유형이 다르기 때문에 ->false

0 === false // expected output: false 
console.log(typeof 0); 	// expected output: "number"
console.log(typeof false); // expected output: "boolean"
🔍 숫자와 문자열 비교
 자동 유형변화 비교

2 == "2" // expected output: true
  피연산자의 유형이 다르기 때문에 ->false

2 === "2" // expected output: false 
console.log(typeof 2);	// expected output: "number"
console.log(typeof "2");  // expected output: "string"

서로 호환되지 않는 두 변수를 비교하면 컴파일 오류* 를 일으키는 자바 평등 연산자(Java Equality 연산자)와 많이 비슷하다.

▷ 기본자료형(Primitive)

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

null과 undefined는 공통적으로 값이 없음을 뜻하지만, 값의 종류(Data Type)가 다르기 때문에,
=== 연산자를 사용할 때 결과가 false라고 나온다.

console.log(null == undefined); // true 
console.log(null === undefined); // false 

기본적으로 1은 true, 0은 false로 나타낼 수 있지만 데이터 타입은 다르다.

console.log(true == 1); // true 
console.log(true === 1); // false 

'!=' 와 '!==' 비교연산자의 차이

 값이 다르지 않음으로 (자료형 비교 안함)

2 != "2" // expected output: false
  피연산자의 유형이 다른 것이 맞기 때문에 -> true

2 !== "2" // expected output: true 
console.log(typeof 2);	// expected output: "number"
console.log(typeof "2");  // expected output: "string"

숫자 0과 문자열 “0”, ""

console.log(0 == "0"); // true 
console.log(0 === "0"); // false 
console.log(0 == ""); // true 
console.log(0 === ""); // false 

NaN은 Not a Number라는 뜻으로, 숫자가 아닌 것을 의미하지만 그 값 자체끼리는 같지 않다.

console.log(NaN == NaN); // false 
console.log(NaN === NaN); // false 

▷ 객체형(Object type)

var a = [1,2,3]; 
var b = [1,2,3]; 
console.log(a == b); // false 
console.log(a === b); // false 

배열을 할당할때 각 변수는 각 메모리의 주소를 참조한다.
두 변수 a, b의 값과 데이터 타입이 같지만,
이와 상관없이 참조하는 메모리의 주소가 다르기 때문에 두 a, b는 같지 않다.

var a = [1,2,3]; 
var b = [1,2,3]; 
var c = b; 
console.log(b === c); // true 
console.log(b == c); // ture 

새로운 변수 c에 변수 b를 할당해주면 변수 c도 b가 참조하는 같은 메모리의 주소를 참조하게 되어 두 변수 c, b는 같다.
이때, c, b의 값과 데이터 타입이 같기 때문에, ==와 ===의 결과값이 동일하다.

객체도 마찬가지다.

var x = {}; 
var y = {}; 
var z = y; 
console.log(x == y) // false 
console.log(x === y) // false 
console.log(y === z) // true 
console.log(y == z) // true