정처기 감자
SW 설계디자인패턴

검색

검색어를 입력해 개념, 문제, 필기를 찾습니다.

커맨드 command 패턴 - 타입스크립트 예시

SW설계디자인패턴
읽는데 5분 소요
처음 쓰여진 날: 2025-09-01
마지막 수정일: 2025-09-01
조회수: —
선수학습(1개)
  • 정보처리기사 실기를 위한 디자인 패턴 암기 방법

요약

커맨드 command 패턴을 타입스크립트 코드와 함께 알아봅니다.

커맨드 (Command) 패턴 요약

패턴 종류핵심 키워드
커맨드 (Command)요청(request) 그 자체를 객체로 캡슐화
커맨드 패턴 감자
커맨드 패턴 감자

커맨드 (Command) 패턴

커맨드 패턴은 '요청(request)' 그 자체를 객체로 캡슐화하여, 요청을 보내는 객체(Invoker)와 요청을 실제로 처리하는 객체(Receiver)를 분리하는 패턴입니다.

가장 흔한 비유는 'TV 리모컨' 입니다. 리모컨(Invoker)의 버튼들은 각각 '전원 켜기', '볼륨 높이기' 같은 기능(Command)을 가지고 있습니다. 우리가 버튼을 누르면, 리모컨은 해당 기능이 담긴 신호를 TV(Receiver)에 보냅니다. 리모컨은 TV가 내부적으로 어떻게 동작하는지 전혀 모르며, 그저 정해진 신호를 보낼 뿐입니다. TV 또한 리모컨이 어떻게 생겼는지, 버튼이 몇 개인지 신경 쓰지 않고 들어온 신호를 처리하기만 하면 됩니다.

이처럼 커맨드 패턴은 '무엇을 할 것인가' 를 '누가, 어떻게 할 것인가' 로부터 분리하여 시스템의 유연성을 크게 높입니다.

기본 구조

  • Command: 모든 구체적인 커맨드 클래스들이 구현해야 하는 공통 인터페이스입니다. 보통 execute()라는 단일 메서드를 가집니다.
  • ConcreteCommand: Command 인터페이스를 구현하며, Receiver 객체에 대한 참조를 가집니다. execute()가 호출되면, Receiver의 특정 메서드를 호출하여 요청을 실행합니다.
  • Invoker: 사용자(클라이언트)의 요청을 받아 Command 객체를 실행하는 역할을 합니다. (예: 리모컨, 버튼) Invoker는 ConcreteCommand가 아닌 Command 인터페이스에만 의존하므로, 어떤 커맨드든 실행할 수 있습니다.
  • Receiver: 요청을 실제로 수행하는 객체입니다. 비즈니스 로직을 포함하고 있습니다. (예: TV, 전등)

예시: 스마트홈 리모컨 만들기

전등을 켜고 끄는 간단한 스마트홈 리모컨을 만든다고 가정해봅시다. 여기에 커맨드 패턴의 꽃이라 불리는 '실행 취소(Undo)' 기능까지 추가해 보겠습니다.

먼저, 요청을 실제로 처리할 Receiver인 Light 클래스를 정의합니다.

typescript
코드 하이라이팅 중…

다음으로 모든 커맨드가 따를 Command 인터페이스를 정의합니다. undo() 메서드를 추가하여 실행 취소 기능을 지원하도록 합니다.

typescript
코드 하이라이팅 중…

이제 구체적인 커맨드, LightOnCommand와 LightOffCommand를 만듭니다.

typescript
코드 하이라이팅 중…

마지막으로, 커맨드를 받아 실행하고, 실행 내역을 기록하여 Undo 기능을 처리할 Invoker인 RemoteControl 클래스를 만듭니다.

typescript
코드 하이라이팅 중…

RemoteControl은 Light 객체의 존재를 전혀 모릅니다. 그저 Command 인터페이스의 execute()와 undo() 메서드를 호출할 뿐입니다. 만약 오디오를 제어하는 기능을 추가하고 싶다면, Audio 클래스와 AudioOnCommand 등을 새로 만들어 리모컨에 설정하기만 하면 됩니다. 리모컨 코드는 변경할 필요가 없습니다.

커맨드 패턴 중요 키워드

  • 요청을 객체로 캡슐화합니다.
  • 요청자(Invoker)와 수신자(Receiver)를 분리하여 결합도를 낮춥니다.
  • 높은 재사용성: Invoker는 Command 인터페이스에만 의존하므로, 어떤 기능(Command)이든 실행할 수 있는 재사용 가능한 클래스가 됩니다. 예시의 RemoteControl은 Light뿐만 아니라 Audio, Heater 등 어떤 Receiver의 커맨드든 받아 실행할 수 있습니다.
  • 실행 취소(Undo/Redo) 기능을 구현하는 데 매우 유용합니다.
  • 작업 큐, 트랜잭션, 로깅 등 다양한 곳에 활용될 수 있습니다.
메가커피와 함께, 홈페이지 개선에 참여하세요! ☕
혹시 이용에 불편한 점이나 개선이 필요한 부분을 발견하셨나요? 댓글로 알려주시면 더 나은 감자가 될 수 있어요! 🥔 제보해주신 모든 분께 메가커피 기프티콘을 드립니다! (본인 이메일로 댓글 달아주셔야해요~)
후수학습(1개)
  • 디자인 패턴 정보처리기사 기출 문제 모음

추천 개념

Beta

관련 글

(41개)
제목태그업데이트시험
추상 팩토리 abstract factory 패턴 - 자바스크립트 예제
디자인패턴SW설계디자인패턴
2025-09-02-
빌더 builder 패턴 - 자바스크립트 예제
디자인패턴SW설계디자인패턴
2025-09-02-
팩토리 메서드 factory method 패턴 - 자바스크립트 예제
디자인패턴SW설계디자인패턴
2025-11-03-
정처기 감자정처기 감자

정보처리기사 합격
도와줄라고 하는 감자

실기 이론

  • 이론 공부법
  • DB
  • 네트워크/OS
  • SW 설계
  • SW 개발
  • 보안/신기술

시험 응시

  • 시험장 찾기
  • 원서 접수
  • 응시자격 서류

요약 PDF

  • 26년 1회 이론 압축
  • 초압축 25년 3회
  • 압축 25년 3회

기출문제

  • 전체 기출문제
  • 25년 3회
  • 25년 2회
  • 문제 포럼

감자 이용권

  • 이용권 구매

실기 이론

  • 이론 공부법
  • DB
  • 네트워크/OS
  • SW 설계
  • SW 개발
  • 보안/신기술

시험 응시

  • 시험장 찾기
  • 원서 접수
  • 응시자격 서류

요약 PDF

  • 26년 1회 이론 압축
  • 초압축 25년 3회
  • 압축 25년 3회

기출문제

  • 전체 기출문제
  • 25년 3회
  • 25년 2회
  • 문제 포럼

감자 이용권

  • 이용권 구매
© 2025 재현기획개발. All rights reserved.
  • 정처기 감자의 시작
  • 업데이트 로그
  • 개인정보 처리방침
  • 이용약관
상호명 : 재현기획개발 / 주소: 서울특별시 영등포구 영등포로 150, 지하1층 108호 L145 가라지(당산동1가, 생각공장 당산) / 대표: 김재현 / 전화: 010-8158-7127 / 통신판매업신고: 제2025-서울영등포-1569호 / 이메일: contact@edugamja.com / 사업자등록번호: 573-51-00999