[Deep Dive] 함수와 일급 객체

link717·2022년 7월 10일
0

Deep Dive

목록 보기
12/28
post-thumbnail

🌼 18.1 일급 객체

다음과 같은 조건을 만족하는 객체를 일급 객체라 한다. 함수가 일급 객체라는 것은 함수를 객체와 동일하게 사용할 수 있다는 의미다. 객체는 값이므로 함수는 값과 동일하게 취급할 수 있다. 일급 객체로서 함수가 가지는 가장 큰 특징은 일반 객체와 같이 함수의 매개변수에 전달할 수 있으며, 함수의 반환값으로 사용할 수도 있다는 것이다. 이는 함수형 프로그래밍을 가능케 하는 자바스크립트의 장점 중 하나다.

함수는 객체이지만 일반 객체와는 차이가 있다. 일반 객체는 호출할 수 없지만 함수 객체는 호출할 수 있다. 그리고 함수 객체는 일반 객체에는 없는 함수 고유의 프로퍼티를 소유한다.

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

    🌼 18.2 함수 객체의 프로퍼티

    브라우저 콘솔에서 console.dir 메서드를 사용하면 함수 객체의 내부를 들여다 볼 수 있다. arguments, caller, length 등의 프로퍼티는 모두 함수 객체의 데이터 프로퍼티다.

function square(number) {
  return number * number;
}

console.log(Object.getOwnPropertyDescriptors(square));
// 모든 프로퍼티의 어트리뷰트를 확인할 수 있는 메서드
  • arguments: arguments 객체는 함수 호출 시 전달된 인수들의 정보를 담고 있는 순회 가능한 유사 배열 객체이며, 함수 내부에서 지역 변수처럼 사용된다. 즉, 함수 외부에서는 참조할 수 없다. 자바 스크립트는 함수의 매개변수와 인수의 개수가 일치하는지 확인하지 않는다. 따라서 함수 호출시 매개변수 개수만큼 인수를 전달하지 않아도 에러가 발생하지 않는다. 함수의 매개변수는 유사 배열 객체로 배열 메서드를 직접 사용할 수 없다. 이러한 번거로움을 해결하기 위해서 ES6에서는 Rest 파라미터를 도입했다.
function sum(...args) {
  return args.reduce((pre, cur) => pre + cur, 0);
} 

console.log(sum(1, 2, 3)) // 6
  • caller: 함수 자신을 호출한 함수를 가리킨다.

  • length: 함수를 정의할 때 선언한 매개변수의 개수를 가리킨다.

  • name: 함수의 이름을 나타낸다.

출처: 모던 자바스크립트 Deep Dive-이웅모

profile
Turtle Never stop

0개의 댓글