자바스크립트 용어 정리

GABMIN KIM·2022년 1월 22일
0

JavaScript

목록 보기
2/17
post-thumbnail

JavaScript 용어 정리

- 문(Statement) : 프로그램을 구성하는 기본 단위이자 최소 실행 단위. 문은 여러 토큰(token)으로 구성된다. 토큰은 문법적인 의미를 가지며, 문법적으로 더 이상 나눌 수 없는 코드의 기본 요소를 의미한다.


- 표현식(Expression) : 표현식은 값으로 평가될 수 있는 문(statement)이다. 즉, 표현식이 평가되면 새로운 값을 생성하거나 기존 값을 참조한다.


- 변수(Variable) : 하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름을 말한다.


- 변수 호이스팅(Variable hoisting) : 변수 선언문이 코드의 선두로 끌어 올려진 것처럼 동작하는 자바스크립트 고유의 특징을 변수 호이스팅이라 한다.


-가비지 콜랙터(Garbage Collector) : 애플리케이션이 할당한 메모리 공간을 주기적으로 검사하여 더 이상 사용되지 않는 메모리를 해제하는 기능을 말한다. 더 이상 사용되지 않는 메모리란 간단히 어떤 식별자도 참조하지 않는 메모리 공간을 의미한다. 자바스크립트는 가비지 콜렉터를 내장하고 있는 매니지드 언어로 메모리 누수를 방지한다.

- 메서드(Method) : 객체는 0개 이상의 프로퍼티로 구성된 집합이며, 프로퍼티는 키와 값으로 구성된다. 자바스크립트의 함수는 일급 객체이므로 값으로 취급할 수 있다. 따라서 프로퍼티 값이 함수일 경우, 일반 함수와 구분하기 위해 메서드(Method)라고 한다.


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

let str = "string";
console.log(str[0]); // s
console.log(str.length); // 6

- 인스턴스(Instance) : 생성자 함수에 의해 생성된 객체를 인스턴스라고 한다. 생성자 함수(Constructor)란 new연산자와 함께 호출하여 객체(인스턴스)를 생성하는 함수를 말한다.


- 일시적 사각지대 (Temporal Dead Zone;TDZ) : let, const 키워드로 선언한 변수는 "선언 단계"와 "초기화 단계"가 분리되어 진행된다. 런타임 이전에 자바스크립트 엔진에 의해 암묵적으로 선언 단계가 먼저 실행되지만 초기화 단계는 선언문에 도달했을 때 실행된다. 초기화 단계가 실행되기 이전에 변수에 접근하려고 하면 참조 에러가 발생하게 되는데, 스코프의 시작 지점부터 초기화 시작 지점까지 변수를 참조할 수 없는 구간을 일시적 사각지대(TDZ) 라고 한다.


- 리터럴 (Ilteral) : 사람이 이해할 수 있는 문자 또는 약속된 기호를 사용해 값을 생성하는 표기법.


- 스코프(Scrope) : 모든 식별자(변수 이름, 함수 이름, 클래스 이름 등)는 자신이 선언된 위치에 의해 다른 코드가 식별자 자신을 참조할 수 있는 유효 범위가 결정되는데 이를 스코프라고 한다. 즉, 스코프는 식별자가 유효한 범위를 말한다.


- 동적 스코프 : 함수를 어디서 호출했는지에 따라 함수의 상위 스코프를 결정하는 방식. 함수를 정의하는 시점에는 함수가 어디서 호출될지 알 수 없어 호출되는 시점에 동적으로 상위 스코프를 결정하여 동적 스코프라고 한다.


- 렉시컬 스코프(정적스코프) : 함수를 어디서 정의했는지에 따라 함수의 상위 스코프를 결정하는 방식. 함수 정의가 평가되는 시점에 상위 스코프가 정적으로 결정되기 때문에 정적 스코프라고 부른다. 자바스크립트는 렉시컬 스코프를 따른다.


- 콜백함수(CallBack Function) : 함수의 매개변수를 통해 다른 함수의 내부로 전달되는 함수이다.


- 고차함수(Higher-Order Function) : 매개변수를 통해 함수의 외부에서 콜백 함수를 전달받은 함수.


- 전역 객체(Global Object) : 코드가 실행되기 이전 단계에 자바스크립트 엔진에 의해 어떤 객체보다도 먼저 생성되는 특수한 객체.


- 바인딩(name binding) : 식별자와 값을 연결하는 과정을 의미한다. 예를 들어, 변수 선언은 변수 이름(식별자)과 확보된 메모리 공간의 주소를 바인딩 하는 것이다.


- 일급 객체 : 다음과 같은 4가지 조건을 모두 만족하는 것을 일급 객체라고 한다.

  1. 무명의 리터럴로 생성할 수 있다. 즉, 런타임에 생성이 가능하다.
  2. 변수나 자료구조(객체,배열 등)에 저장할 수 있다.
  3. 함수의 매개변수에 전달할 수 있다.
  4. 함수의 반환값으로 사용할 수 있다.

- 객체지향 프로그래밍 : 프로그램을 명령어 또는 함수의 목록으로 보는 전통적인 명령형 프로그래밍(Imperative Programming)의 절차지향적 관점에서 벗어나 여러 개의 독립적 단위, 즉 객체의 집합으로 프로그램을 표현하려는 프로그래밍 패러다임을 말한다.


- 객체(Object) : 속성을 통해 여려 개의 값을 하나의 단위로 구성한 복합적인 자료구조. 상태 데이터(프로퍼티)와 동작(메서드)을 하나의 논리적인 단위로 묶은 복합적인 자료구조.


- 순수함수와 비순수함수 : 어떤 외부 상태에 의존하지 않고 변경하지도 않는 부수 효과가 없는 함수를 순수 함수라고 하고, 외부 상태에 의존하거나 외부 상태를 변경하는 부수 효과가 있는 함수를 비순수 함수라고 한다.


- 프로토타입 체인 : 자바스크립트는 객체의 프로퍼티(메서드 포함)에 접근하려고 할 때 해당 객체에 접근하려는 프로퍼티가 없다면 Prototype 내부 슬롯의 참조를 따라 자신의 부모 역할을 하는 프로토타입의 프로퍼티를 순차적으로 검색하는 것을 뜻한다. 프로토타입 체인은 자바스크립트가 객체지향 프로그래밍의 상속을 구현하는 메커니즘이다.


- 정적 프로퍼티/메서드 : 생성자 함수로 인스턴스를 생성하지 않아도 참조/호출할 수 있는 프로퍼티/메서드를 말한다.


- 래퍼 객체(Wrapper Object) : 자바스크립트에서 원시값을 객체처럼 사용하면 자바스크립트 엔진은 암묵적으로 연관된 객체를 생성하여 생성된 객체로 프로퍼티에 접근하거나 메서드를 호출하고 다시 원시값으로 되돌린다. 이처럼 문자열, 숫자, 불리언 값에 대해 객체처럼 접근하면 생성되는 임시 객체를 래퍼 객체라고 한다.


-오버라이딩(Overrriding) : 프로토타입이 소유한 프로퍼티를 프로토타입 프로퍼티, 인스턴스가 소유한 프로퍼티를 인스턴스 프로퍼티라고 하는데, 프로토타입 프로퍼티와 같은 이름의 프로퍼티를 인스턴스에 추가하면 프로토타입 체인을 따라 프로토타입 프로퍼티를 검색하여 프로토타입 프로퍼티를 덮어쓰는 것이 아니라 인스턴스 프로퍼티로 추가한다. 이처럼 상위 클라스가 가지고 있는 메서드를 하위 클래스가 재정의하여 사용하는 방식을 오버라이딩이라고 한다.


-프로퍼티 섀도잉(Property Shadowing) : 오버라이딩에 의해 프로퍼티가 가려지는 현상을 프로퍼티 섀도잉이라고 한다.


-실행 컨텍스트(Execution Context) : 실행 컨텍스트는 소스코드를 실행하는 데 필요한 환경을 제공하고 코드의 실행 결과를 실제로 관리하는 영역이다. 구체적으로 말하면, 실행 컨텍스트는 식별자(변수, 함수, 클래스 등의 이름)를 등록하고 관리하는 스코프와 코드 실행 순서관리를 구현한 내부 메커니즘으로, 모든 코드는 실행 컨텍스트를 통해 실행되고 관리된다.


-렉시컬 환경(Lexical Environment) : 렉시컬 환경은 식별자와 식별자에 바인딩된 값, 그리고 상위 스코프에 대한 참조를 기록하는 자료구조로 실행 컨텍스트를 구성하는 컴포넌트다. 실행 컨텍스트 스택이 코드의 실행 순서를 관리한다면 렉시컬 환경은 스코프와 식별자를 관리한다.


-클로저(Closure) : 외부 함수보다 중첩 함수가 더 오래 유지되는 경우 중첩 함수는 이미 생명 주기가 종료한 외부 함수의 변수를 참조할 수 있다. 이러한 중첩함수를 클로저라고 부른다. 클로저는 상태를 안전하게 변경하고 유지하기 위해 사용한다. 상태가 의도치 않게 변경되지 않도록 상태를 안전하게 은닉하고 특정함수에게만 상태 변경을 허용하기 위해 사용한다.


-캡슐화(encapsulation) : 객체의 상태를 나타내는 프로퍼티와 프로퍼티를 참조하고 조작할 수 있는 동작인 메서드를 하나로 묶는 것을 말한다. 캡슐화는 객체의 특정 프로퍼티나 메서드를 감출 목적으로 사용하기도 하는데 이를 정보 은닉이라 한다.


-파싱(Parsing) : 프로그래밍 언어의 문법에 맞게 작성된 텍스트 문서를 읽어 들여 실행하기 위해 텍스트 문서의 문자열을 토큰(token)으로 분해(어휘 분석)하고, 토큰에 문법적 의미와 구조를 반영하여 트리 구조의 자료구조인 파스 트리(parse tree/syntax tree)를 생성하는 일련의 과정.


-이터러블(Iterable) : 이터러블 프로토콜을 준수한 객체를 이터러블이라고 한다. 이터러블은 Symbol.iterator를 프로퍼티 키로 사용한 메서드를 직접 구현하거나 프로토타입 체인을 통해 상속받은 객체를 말한다.


-DOM(Document Object Model) : HTML 문서의 계층적 구조와 정보를 표현하며 이를 제어할 수 있는 API이다. 즉, 프로퍼티와 메서드를 제공하는 트리 자료구조이다.


profile
목표를 성취하는 개발자가 되겠습니다.

0개의 댓글