상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - 자바스크립트에서 고차 함수(Higher-Order Function)란 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
고차 함수(Higher-Order Function)는 함수형 프로그래밍에서 중요한 <a href='https://sangseek.com/sangseeks/개념/ko'>개념</a>으로, 다른 함수를 인자로 받거나 함수를 반환하는 함수를 의미합니다. <a href='https://sangseek.com/sangseeks/자바/ko'>자바</a>스크립트는 일급 객체로서 함수를 지원하기 때문에, 고차 함수를 쉽게 구현하고 사용할 수 있습니다. 고차 함수는 코드의 재사용성을 높이고, 더 간결하고 읽기 쉬운 코드를 작성하는 데 도움을 줍니다. 고차 함수의 특징 1. 함수를 인자로 받는 함수 : 고차 함수는 다른 함수를 매개변수로 받아들일 수 있습니다. 이를 통해 특정 동작을 수행하는 함수를 동적으로 생성할 수 있습니다. 2. 함수를 반환하는 함수 : 고차 함수는 내부에서 새로운 함수를 생성하여 반환할 수 있습니다. 이 경우, 반환된 함수는 외부에서 정의된 변수에 접근할 수 있는 클로저(Closure)가 됩니다. 3. 일급 객체 : 자바스크립트에서 함수는 일급 객체로 <a href='https://sangseek.com/sangseeks/취급/ko'>취급</a>되므로, 변수에 할당하거나, 다른 함수의 인자로 전달하거나, 반환값으로 사용할 수 있습니다. 고차 함수의 예시 1. 함수를 인자로 받는 고차 함수 ```javascript function greet(name) { return `Hello, ${name}!`; } function processUserInput(<a href='https://sangseek.com/sangseeks/callback/ko'>callback</a>) { const name = prompt("Enter your name:"); console.log(callback(name)); } processUserInput(greet); // 사용자가 입력한 이름으로 인사 ``` 위의 예시에서 `processUserInput` 함수는 다른 함수(`greet`)를 인자로 받아 사용자의 입력을 처리합니다. 이를 통해 `greet` 함수의 동작을 동적으로 변경할 수 있습니다. 2. 함수를 반환하는 고차 함수 ```javascript function makeCounter() { let count = 0; return function() { count += 1; return count; }; } const counter = makeCounter(); console.log(counter()); // 1 console.log(counter()); // 2 console.log(counter()); // 3 ``` 위의 예시에서 `makeCounter` 함수는 내부 상태를 유지하는 클로저를 반환합니다. `counter` 변수를 통해 호출할 때마다 카운트가 증가하는 기능을 제공합니다. 고차 함수의 활용 고차 함수는 다양한 상황에서 유용하게 사용됩니다. 몇 가지 예시를 살펴보겠습니다. 1. <a href='https://sangseek.com/sangseeks/배열 메서드/ko'>배열 메서드</a> : 자바스크립트의 배열 메서드인 `map`, `filter`, `reduce` 등은 모두 고차 함수입니다. 이 메서드들은 함수를 인자로 받아 배열의 각 요소에 대해 특정 작업을 수행합니다. ```javascript const numbers = [1, 2, 3, 4, 5]; const doubled = numbers.map(num => num * 2); // [2, 4, 6, 8, 10] const evenNumbers = numbers.filter(num => num % 2 === 0); // [2, 4] const sum = numbers.reduce((acc, num) => acc + num, 0); // 15 ``` 2. 커링(Currying) : 고차 함수를 사용하여 함수를 커링할 수 있습니다. 커링은 여러 개의 인자를 받는 함수를 단일 인자를 받는 함수들의 연속으로 변환하는 기법입니다. ```javascript function add(a) { return function(b) { return a + b; }; } const add5 = add(5); console.log(add5(3)); // 8 ``` 3. <a href='https://sangseek.com/sangseeks/함수 조합/ko'>함수 조합</a> : 여러 개의 함수를 조합하여 새로운 함수를 생성할 수 있습니다. 이를 통해 복잡한 로직을 간단하게 표현할 수 있습니다. ```javascript function compose(f, g) { return function(x) { return f(g(x)); }; } const double = x => x * 2; const square = x => x * x; const doubleThenSquare = compose(square, double); console.log(doubleThenSquare(5)); // 100 ``` 결론 고차 함수는 자바스크립트에서 매우 강력한 기능으로, 코드의 재사용성과 가독성을 높이는 데 기여합니다. 함수를 인자로 받거나 반환하는 기능을 통해 다양한 프로그래밍 패턴을 구현할 수 있으며, 특히 함수형 프로그래밍의 원칙을 따르는 데 유용합니다. 이러한 고차 함수의 개념을 이해하고 활용하는 것은 자바스크립트 개발자에게 필수적인 역량 중 하나입니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기