상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
궁금한 상식 보기
Fastlane 자동 배포의 툴체인 통합 방법은?
아스파라거스를 활용한 파스타 레시피는?
중고나라에서 너무 많은 문의가 오는 상품은 무엇인가요?
xargs를 사용하여 웹서버에서 로그 파일 청소하는 방법은?
갓김치가 발효되는 과정은 어떻게 되나요?
갓김치를 담글 때 사용하는 양식기는 어떤 것들이 있나요?
갓김치가 여름철에 특히 인기가 많은 이유는 무엇인가요?
갓김치와 궁합이 좋은 해산물은 어떤 것이 있나요?
일본 대형 마트의 고객 혜택 프로그램은 어떻게 운영되나요?
일본 대형 마트의 매장 내 레스토랑은 어떤 음식을 제공하나요?
HorizontalScrollView 안에 이미지를 로드하는 최적의 방법은 무엇인가요?
푸꾸옥에서 숙소를 예약할 때 주의할 점은 무엇인가요?
Previous
Next
수정하기 - 자바스크립트에서 고차 함수(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순위입니다.
수정하기
취소하기