Categories: 정보처리기사

정보처리기사 기출 핵심 [41] 함수형 프로그래밍 패러다임 완전 정복

함수형 프로그래밍이란?

함수형 프로그래밍(Functional Programming)은 순수 함수와 불변 데이터를 중심으로 프로그램을 구성하는 패러다임입니다. 정보처리기사 시험에서는 순수 함수, 불변성, 고차 함수, 함수 합성, 모나드가 핵심 출제 범위입니다.

핵심 개념

  • 순수 함수(Pure Function): 동일 입력에 항상 동일 출력. 부작용(Side Effect) 없음. 참조 투명성(Referential Transparency) 보장
  • 불변성(Immutability): 데이터 생성 후 변경 불가. 새로운 값을 생성. 동시성 문제 해결
  • 일급 함수(First-class Function): 함수를 값처럼 취급. 변수에 할당, 인자로 전달, 반환값으로 사용
  • 고차 함수(Higher-order Function): 함수를 인자로 받거나 함수를 반환하는 함수. map, filter, reduce

함수 합성과 커링

  • 함수 합성(Function Composition): 여러 함수를 연결. f(g(x)) = (f o g)(x). 왼쪽에서 오른쪽 합성은 pipe()
  • 커링(Currying): 다인수 함수를 단인수 함수의 체인으로 변환. add(1)(2) 형태
  • 부분 적용(Partial Application): 함수의 일부 인자를 미리 고정해 새 함수 생성
  • 클로저(Closure): 외부 변수를 캡처하는 함수. 상태를 함수로 캡슐화

모나드(Monad)

부작용을 순수 함수형 방식으로 처리하는 추상화입니다.

  • Maybe Monad: null/undefined 처리. 값이 있으면 계속 처리, 없으면 건너뜀
  • Either Monad: 성공(Right) 또는 실패(Left). 에러 처리를 타입으로 표현
  • Promise: JavaScript의 비동기 모나드. then/catch 체이닝
  • 세 가지 법칙: 좌동일원, 우동일원, 결합법칙

함수형 언어와 언어별 지원

  • 하스켈(Haskell): 순수 함수형 언어. 강한 타입 시스템, 지연 평가(Lazy Evaluation)
  • 스칼라(Scala): JVM 기반 함수형 + OOP 혼합
  • JavaScript/TypeScript: 고차 함수, 클로저, 불변성 라이브러리(Immutable.js, Ramda)
  • Python: map/filter/reduce, functools, lambda

정보처리기사 기출 핵심 정리

  • 순수 함수 = 동일 입력 → 동일 출력 + 부작용 없음
  • 고차 함수 = 함수를 인자로 받거나 반환. map/filter/reduce
  • 커링 = 다인수 함수를 단인수 함수 체인으로 변환
  • 모나드 = 부작용 처리 추상화. Maybe(null처리), Either(에러처리)
  • 참조 투명성 = 함수 호출을 결과값으로 교체 가능

zerg96

Recent Posts

네트워크관리사 기출 핵심 [55] 클라우드 네트워크 보안과 VPC 설계 완전 정복

클라우드 VPC 보안이란? Virtual Private Cloud(VPC)는 퍼블릭 클라우드 내 격리된 가상 네트워크 환경입니다. 네트워크관리사 시험에서는…

12시간 ago

네트워크관리사 기출 핵심 [54] 네트워크 성능 측정과 벤치마킹 완전 정복

네트워크 성능 측정이란? 네트워크 성능 측정은 SLA 준수 확인, 병목 구간 발견, 용량 계획의 기반입니다.…

12시간 ago

네트워크관리사 기출 핵심 [53] 네트워크 가상화 심화와 오버레이 네트워크 완전 정복

네트워크 가상화와 오버레이 네트워크란? 오버레이 네트워크는 물리 네트워크 위에 논리적 네트워크를 구성해 가상 머신·컨테이너 간…

12시간 ago

네트워크관리사 기출 핵심 [52] 인터넷 교환 지점과 CDN 아키텍처 완전 정복

인터넷 교환 지점(IXP)이란? 인터넷 교환 지점(IXP)은 서로 다른 네트워크(AS)가 트래픽을 교환하는 물리적 인프라입니다. 네트워크관리사 시험에서는…

12시간 ago

네트워크관리사 기출 핵심 [51] 네트워크 슬라이싱과 5G 코어 아키텍처 완전 정복

5G 코어와 네트워크 슬라이싱이란? 5G 코어 네트워크는 클라우드 네이티브 아키텍처로 완전히 재설계되었습니다. 네트워크관리사 시험에서는 5G…

12시간 ago

정보처리기사 기출 핵심 [55] 플랫폼 엔지니어링과 IDP 구축 완전 정복

플랫폼 엔지니어링이란? 플랫폼 엔지니어링은 개발팀에게 셀프 서비스 인프라와 도구를 제공하는 규율입니다. 내부 개발자 플랫폼(IDP)을 통해…

12시간 ago