Skip to content

Latest commit

ย 

History

History
874 lines (501 loc) ยท 31.8 KB

File metadata and controls

874 lines (501 loc) ยท 31.8 KB

์‹ค์ „ ๋””์ž์ธ ํŒจํ„ด


๋””์ž์ธ ํŒจํ„ด์˜ ์ •์˜

๐Ÿ’ก ํŒจํ„ด(Pattern)์€ ํŠน์ • ์ปจํ…์ŠคํŠธ ๋‚ด์—์„œ ์ฃผ์–ด์ง„ ๋ฌธ์ œ์˜ ํ•ด๊ฒฐ์ฑ…์ด๋‹ค.


์ปจํ…์ŠคํŠธ(context)

  • ํŒจํ„ด์ด ์ ์šฉ๋˜๋Š” ์ƒํ™ฉ
  • ๋ฐ˜๋ณต์ ์œผ๋กœ ์ผ์–ด๋‚  ์ˆ˜ ์žˆ๋Š” ์ƒํ™ฉ์ด์–ด์•ผ๋งŒ ํ•œ๋‹ค.
  • e.g., ๊ฐ์ฒด๋“ค์˜ ์ปฌ๋ ‰์…˜์ด ์ฃผ์–ด์ ธ ์žˆ๋‹ค.

๋ฌธ์ œ(problem)

  • ์ปจํ…์ŠคํŠธ ๋‚ด์—์„œ ์ด๋ค„์•ผ ํ•˜๋Š” ๋ชฉํ‘œ
  • ์ปจํ…์ŠคํŠธ ๋‚ด์˜ ์ œ์•ฝ์กฐ๊ฑด๋„ ํฌํ•จ๋œ๋‹ค.
  • e.g., ์ปฌ๋ ‰์…˜์˜ ๊ตฌํ˜„์„ ๋“œ๋Ÿฌ๋‚ด์ง€ ์•Š์œผ๋ฉด์„œ ๊ทธ ์•ˆ์— ์žˆ๋Š” ๊ฐ ๊ฐ์ฒด๋ฅผ ๋Œ€์ƒ์œผ๋กœ ์ˆœํ™˜ ์ž‘์—…์„ ํ•  ์ˆ˜ ์žˆ์–ด์•ผ ํ•œ๋‹ค.

ํ•ด๊ฒฐ์ฑ…(solution)

  • ์ œ์•ฝ์กฐ๊ฑด ์†์—์„œ ๋ˆ„๊ฐ€ ์ ์šฉํ•ด๋„ ๋ชฉํ‘œ๋ฅผ ์ด๋ฃฐ ์ˆ˜ ์žˆ๋Š” ์ผ๋ฐ˜์ ์ธ ๋””์ž์ธ
  • e.g., ๋ฐ˜๋ณต ์ž‘์—…์„ ๋ณ„๋„์˜ ํด๋ž˜์Šค๋กœ ์บก์Аํ™”ํ•œ๋‹ค.

์–ด๋–ค ์ปจํ…์ŠคํŠธ ๋‚ด์—์„œ
์ผ๋ จ์˜ ์ œ์•ฝ์กฐ๊ฑด์— ์˜ํ•ด ์˜ํ–ฅ์„ ๋ฐ›๋Š” ๋ฌธ์ œ๊ฐ€ ๋ฐœ์ƒํ–ˆ๋‹ค๋ฉด,
๊ทธ ์ œ์•ฝ์กฐ๊ฑด ๋‚ด์—์„œ ๋ชฉ์  ๋‹ฌ์„ฑ์„ ์œ„ํ•œ ํ•ด๊ฒฐ์ฑ…์ด ๋˜๋Š” ๋””์ž์ธ์„ ์ ์šฉํ•˜๋ฉด ๋œ๋‹ค.



ํฌ์Šค(force)

๋””์ž์ธ ํŒจํ„ด์˜ ์ •์˜์— ๋”ฐ๋ฅด๋ฉด, ๋ฌธ์ œ๋Š” ๋ชฉ์ ๊ณผ ์ผ๋ จ์˜ ์ œ์•ฝ์กฐ๊ฑด์œผ๋กœ ๊ตฌ์„ฑ๋œ๋‹ค.

์–ด๋–ค ์ด๋“ค์€ ์ด๋ฅผ ํ•ฉ์ณ์„œ ํฌ์Šค(force)๋ผ๊ณ  ๋ถ€๋ฅด๊ธฐ๋„ ํ•œ๋‹ค.


์ฆ‰, ํŒจํ„ด์˜ ์ •์˜์—์„œ ํฌ์Šค๋ž€ ํ•ด๊ฒฐ์ฑ…์„ ํ˜•์„ฑํ•˜๊ณ  ์ œ์–ดํ•˜๋Š” ๊ฒƒ์ด๋‹ค.



The notion of force generalizes the kinds of criteria that software engineers use to justify designs and implementations.

For example, in the classic study of algorithms in computer science, the main force to be resolved is efficiency (time complexity).


However, patterns deal with the larger, harder-to-measure, and conflicting sets of goals and constraints encountered in the development of every artifact you ever create.

For example, correctness, resources, structure, construction, usage.

(๋” ์ž์„ธํ•œ ๋‚ด์šฉ์€ ํ•ด๋‹น ๋งํฌ๋ฅผ ์ฐธ๊ณ ํ•˜๊ธธ ๋ฐ”๋ž€๋‹ค.)



ํ•ด๊ฒฐ์ฑ…์ด ํฌ์Šค์˜ ์–‘๋ฉด ์‚ฌ์ด์—์„œ ์ ์ ˆํ•˜๊ฒŒ ๊ท ํ˜•์„ ์ด๋ฃฐ ์ˆ˜ ์žˆ์–ด์•ผ ๋น„๋กœ์†Œ ์ œ๋Œ€๋กœ ๋œ ํŒจํ„ด์ด ๋งŒ๋“ค์–ด์ง„๋‹ค.

  • ํฌ์Šค์˜ ๋ฐ์€ ์ธก๋ฉด - ๋ชฉํ‘œ
  • ํฌ์Šค์˜ ์–ด๋‘์šด ์ธก๋ฉด - ์ œ์•ฝ์กฐ๊ฑด



ํŒจํ„ด ์นดํƒˆ๋กœ๊ทธ

๊ตฌ์„ฑ

ํŒจํ„ด ์นดํƒˆ๋กœ๊ทธ์—์„œ๋Š” ํŒจํ„ด๋“ค์ด ๋‹ค์Œ๊ณผ ๊ฐ™์ด ๊ธฐ์ˆ ๋œ๋‹ค.


ํŒจํ„ด ์นดํƒˆ๋กœ๊ทธ

  • ์šฉ๋„, Intent
  • ๋™๊ธฐ, Motivation
  • ์ ์šฉ ๋Œ€์ƒ(ํ™œ์šฉ์„ฑ), Applicability
  • ๊ตฌ์กฐ, Structure
  • ๊ตฌ์„ฑ ์š”์†Œ, Participant
  • ํ˜‘๋ ฅ ๋ฐฉ๋ฒ•, Collaborations : ๊ฐ ๊ตฌ์„ฑ ์š”์†Œ๊ฐ€ ํŒจํ„ด ๋‚ด์—์„œ ์–ด๋–ค ์‹์œผ๋กœ ์„œ๋กœ ๋„์›€์„ ์ฃผ๋Š”์ง€์— ๋Œ€ํ•œ ์„ค๋ช…
  • ๊ฒฐ๊ณผ, Consequences
  • ๊ตฌํ˜„, Implementation
  • ์ƒ˜ํ”Œ ์ฝ”๋“œ, Sample Code
  • ์ž˜ ์•Œ๋ ค์ง„ ์‚ฌ์šฉ ์˜ˆ, Known uses
  • ๊ด€๋ จ ํŒจํ„ด, Related Patterns : ์ด ํŒจํ„ด๊ณผ ๋ฐ€์ ‘ํ•˜๊ฒŒ ๊ด€๋ จ๋œ ๋‹ค๋ฅธ ํŒจํ„ด๋“ค๊ณผ ์ด๋“ค์˜ ์ค‘์š”ํ•œ ์ฐจ์ด์  ๋“ฑ

ํŒจํ„ด ์นดํƒˆ๋กœ๊ทธ์— ๋Œ€ํ•ด ์ฐพ์•„๋ณด๋‹ค๊ฐ€ ํŒจํ„ด๋“ค์ด ์ž˜ ์ •๋ฆฌ๋˜์–ด ์žˆ๋Š” ์ข‹์€ ์‚ฌ์ดํŠธ๋ฅผ ์ฐพ์•„์„œ ์•„๋ž˜์— ๊ณต์œ ํ•œ๋‹ค.
(ํ•œ๊ตญ์–ด ๋ฒˆ์—ญ์ด ์กด์žฌํ•˜๋‚˜, ๋ถ€์ž์—ฐ์Šค๋Ÿฌ์šด ๋ถ€๋ถ„๋“ค์ด ์ค‘๊ฐ„์ค‘๊ฐ„ ์žˆ์œผ๋‹ˆ ์›๋ฌธ๊ณผ ๊ฐ™์ด ์ฝ๋Š” ๊ฒƒ์„ ์ถ”์ฒœํ•จ)

The Catalog of Design Patterns


ํ™œ์šฉ๋ฒ•

  1. ์šฐ์„  ๋ชจ๋“  ํŒจํ„ด์„ ์ตํžŒ ํ›„ ์—ฌ๋Ÿฌ ํŒจํ„ด ์‚ฌ์ด์˜ ๊ด€๊ณ„๋ฅผ ํŒŒ์•…ํ•œ๋‹ค.

  2. ์ ์šฉ ๋Œ€์ƒ ์„น์…˜๊ณผ ๊ฒฐ๊ณผ ์„น์…˜์„ ํ†ตํ•ด ์ ์ ˆํ•œ ํŒจํ„ด์ธ์ง€ ํŒ๋‹จ์„ ๋‚ด๋ฆฐ๋‹ค.

  3. ํŒจํ„ด์„ ๋””์ž์ธ์— ๋ฐ˜์˜ํ•˜๊ณ  ๊ตฌํ˜„ํ•  ๊ฒฝ์šฐ

    1. ๊ตฌ์กฐ ์„น์…˜์„ ๋ณด๊ณ  ํด๋ž˜์Šค ๋‹ค์ด์–ด๊ทธ๋žจ์„ ์‚ดํŽด๋ณธ๋‹ค.
    2. ๊ตฌ์„ฑ ์š”์†Œ ์„น์…˜์—์„œ ๊ฐ ํด๋ž˜์Šค์˜ ์—ญํ• ์„ ์ œ๋Œ€๋กœ ํŒŒ์•…ํ•˜๊ณ  ์žˆ๋Š”์ง€ ํ™•์ธํ•œ๋‹ค.
    3. ๊ตฌํ˜„/์ƒ˜ํ”Œ ์ฝ”๋“œ ์„น์…˜์—์„œ ๊ตฌํ˜„ ๊ธฐ๋ฒ•๊ณผ ์ฃผ์˜์‚ฌํ•ญ ๋“ฑ์„ ๊ณต๋ถ€ํ•œ๋‹ค.

๋””์ž์ธ ํŒจํ„ด์„ ๊ณ ๋ฅด๋Š” ๋ฐฉ๋ฒ•

๋ฌธ์ œ์— ์ ํ•ฉํ•œ ๋””์ž์ธ ํŒจํ„ด์„ ์ฐพ์•„๋‚ด๋Š” ์—ฌ๋Ÿฌ๊ฐ€์ง€ ์ ‘๊ทผ ๋ฐฉ๋ฒ•์€ ๋‹ค์Œ๊ณผ ๊ฐ™๋‹ค.

  • ํŒจํ„ด์ด ์–ด๋–ป๊ฒŒ ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•˜๋Š”์ง€ ํŒŒ์•…ํ•œ๋‹ค.
  • ํŒจํ„ด์ด ์˜๋„ํ•˜๋Š” ๋ถ€๋ถ„์„ ๋ณธ๋‹ค.
  • ํŒจํ„ด๋“ค๊ฐ„์˜ ๊ด€๋ จ์„ฑ์„ ํŒŒ์•…ํ•œ๋‹ค.
  • ๋น„์Šทํ•œ ๋ชฉ์ ์˜ ํŒจํ„ด๋“ค์„ ๋ชจ์•„์„œ ๊ณต๋ถ€ํ•œ๋‹ค.
  • ์žฌ์„ค๊ณ„์˜ ์›์ธ์„ ํŒŒ์•…ํ•œ๋‹ค.
  • ์„ค๊ณ„์—์„œ ๊ฐ€๋ณ€์„ฑ์„ ๊ฐ€์ ธ์•ผ ํ•˜๋Š” ๋ถ€๋ถ„์ด ๋ฌด์—‡์ธ์ง€ ํŒŒ์•…ํ•œ๋‹ค.

๋””์ž์ธ ํŒจํ„ด์˜ ์ฐธ์กฐ ๊ด€๊ณ„๋„


์ฐธ์กฐ ๊ด€๊ณ„๋„

Abstract Factory ํŒจํ„ด์€ ์ข…์ข… Factory Method ํŒจํ„ด์ด๋‚˜ Prototype ํŒจํ„ด์„ ์ด์šฉํ•ด์„œ ๊ตฌํ˜„๋˜๋ฉฐ,
Singleton ํŒจํ„ด์„ ์ด์šฉํ•ด์„œ ํ•˜๋‚˜์˜ ๊ณต์œ ๋˜๋Š” ๊ฐ์ฒด๋ฅผ ๊ด€๋ฆฌํ•  ์ˆ˜ ์žˆ๋‹ค.


Builder ํŒจํ„ด์€ ๋ณต์žกํ•œ ๊ฐ์ฒด๋ฅผ ์ƒ์„ฑํ•œ๋‹ค๋Š” ์ ์—์„œ Abstract Factory ํŒจํ„ด๊ณผ ์œ ์‚ฌํ•˜๋‹ค.

๊ทธ๋Ÿฌ๋‚˜ Abstract Factory ํŒจํ„ด์ด ์ œํ’ˆ๊ตฐ(Product Family) ๋ณ„๋กœ ๊ฐ์ฒด๋ฅผ ์ƒ์„ฑํ•˜๋Š”๋ฐ ์ค‘์ ์„ ๋‘”๋‹ค๋ฉด
Builder ํŒจํ„ด์€ ๋‹จ๊ณ„์ ์œผ๋กœ ๊ฐ์ฒด๋ฅผ ์ƒ์„ฑํ•œ๋‹ค๋Š” ์ ์ด ์ปค๋‹ค๋ž€ ์ฐจ์ด์ ์ด๋‹ค.

๋˜ํ•œ Builder ํŒจํ„ด์˜ ๊ฒฝ์šฐ์—๋Š” ๋ช‡ ๋‹จ๊ณ„์˜ ์ž‘์—…์„ ๊ฑฐ์นœ ํ›„์—์•ผ ์ตœ์ข…์ ์œผ๋กœ ๊ฒฐ๊ณผ๋ฅผ ๋˜๋Œ๋ฆฌ๋Š”๋ฐ ๋ฐ˜ํ•ด,
Abstract Factory ํŒจํ„ด์˜ ๊ฒฝ์šฐ์—๋Š” ๊ณง๋ฐ”๋กœ ์ƒ์„ฑ๋œ ๊ฒฐ๊ณผ๋ฅผ ๋˜๋Œ๋ฆฐ๋‹ค.

Builder ํŒจํ„ด์— ์˜ํ•ด ์ƒ์„ฑ๋˜๋Š” ๊ฐ์ฒด๋Š” Composite ํŒจํ„ด์˜ ํ˜•ํƒœ์ผ ๋•Œ๊ฐ€ ๋งŽ๋‹ค.


Factory Method ํŒจํ„ด์€ Abstract Factory ํŒจํ„ด์„ ๊ตฌํ˜„ํ•  ๋•Œ ๋งŽ์ด ์‚ฌ์šฉ๋œ๋‹ค.

๋˜ํ•œ Factory Method ํŒจํ„ด์€ Template Method ํŒจํ„ด ๋‚ด์—์„œ ๋ถˆ๋ฆฌ์–ด์ง€๋Š” ๊ฒฝ์šฐ๊ฐ€ ๋งŽ๋‹ค.


Prototype ํŒจํ„ด์€ Abstract Factory ํŒจํ„ด๊ณผ ๊ฐ™์ด ์‚ฌ์šฉ๋˜๊ฑฐ๋‚˜ ๋Œ€์‹  ์‚ฌ์šฉ๋  ์ˆ˜๋„ ์žˆ๋‹ค.

๋˜ํ•œ Prototype ํŒจํ„ด์€ Composite ํŒจํ„ด์ด๋‚˜ Decorator ํŒจํ„ด์ด ๋งŽ์ด ์‚ฌ์šฉ๋˜๋Š” ๊ณณ์—์„œ ๊ฐ™์ด ์‚ฌ์šฉํ•˜๋ฉด ์œ ์šฉํ•  ๊ฒฝ์šฐ๊ฐ€ ๋งŽ๋‹ค.

Prototype ํŒจํ„ด๊ณผ Factory Method ํŒจํ„ด์„ ๋น„๊ตํ•ด๋ณด๋ฉด Prototype ํŒจํ„ด์€ ๊ฐ์ฒด ์ƒ์„ฑ์‹œ ๋ฐ˜๋“œ์‹œ ํ•˜์œ„ ํด๋ž˜์Šค๋ฅผ ํ•„์š”๋กœ ํ•˜์ง€ ์•Š๋Š” ๋Œ€์‹ ,
์ƒ์„ฑ๋œ ๊ฐ์ฒด๋ฅผ ์ดˆ๊ธฐํ™”์‹œํ‚ค๊ธฐ ์œ„ํ•œ ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ๋ณ„๋„๋กœ ํ•„์š”๋กœ ํ•  ๊ฒฝ์šฐ๊ฐ€ ๋งŽ๋‹ค.

๋ฐ˜๋ฉด Factory Method ํŒจํ„ด์€ ๊ฐ์ฒด ์ƒ์„ฑ์‹œ ํ•˜์œ„ ํด๋ž˜์Šค๋ฅผ ์ •์˜ํ•ด์„œ ์ƒ์„ฑํ•˜๋Š” ํ˜•ํƒœ๋ฅผ ์ทจํ•˜๊ฒŒ ๋œ๋‹ค.


Adapter ํŒจํ„ด์€ Bridge ํŒจํ„ด๊ณผ ์œ ์‚ฌํ•œ ๊ตฌ์กฐ๋ฅผ ๊ฐ€์ง„๋‹ค. ๊ทธ๋Ÿฌ๋‚˜ ๋‘ ํŒจํ„ด์˜ ์‚ฌ์šฉ ๋ชฉ์ ์€ ์™„์ „ํžˆ ๋‹ค๋ฅด๋‹ค.

์ฆ‰, Bridge ํŒจํ„ด์˜ ๊ฒฝ์šฐ์—๋Š” ์ธํ„ฐํŽ˜์ด์Šค์™€ ๊ตฌํ˜„์„ ๋ถ„๋ฆฌ์‹œ์ผœ์คŒ์œผ๋กœ์จ ์„œ๋กœ ๋…๋ฆฝ์ ์œผ๋กœ ๋ณ€๊ฒฝ์ด ๊ฐ€๋Šฅํ•˜๊ฒŒ ๋งŒ๋“ค๋ ค๋Š” ๋ชฉ์ ์ธ๋ฐ ๋ฐ˜ํ•ด
Adapter ํŒจํ„ด์€ ์ด๋ฏธ ์กด์žฌํ•˜๋Š” ๊ฐ์ฒด์˜ ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ๋‹ค๋ฅธ ํ˜•ํƒœ๋กœ ๋ณ€๊ฒฝ์‹œ์ผœ์ฃผ๋Š” ๊ฒƒ์ด ๋ชฉ์ ์ด๋‹ค.


Decorator ํŒจํ„ด์€ ์ธํ„ฐํŽ˜์ด์Šค์˜ ๋ณ€๊ฒฝ ์—†์ด ๊ฐ์ฒด์˜ ๊ธฐ๋Šฅ์„ ์ถ”๊ฐ€ํ•  ์ˆ˜ ์žˆ๋Š” ๋ฐฉ์‹์ด๋ฉฐ, ์ด๋Ÿฐ ์ธก๋ฉด์—์„œ Adapter ํŒจํ„ด๋ณด๋‹ค ์ข€ ๋” ์œ ์—ฐํ•˜๋‹ค.


Facade ํŒจํ„ด์€ ๊ธฐ์กด ํด๋ž˜์Šค์˜ ๊ธฐ๋Šฅ์„ ์ถ”์ƒํ™”์‹œํ‚จ๋‹ค๋Š” ์ ์—์„œ Mediator ํŒจํ„ด๊ณผ ์œ ์‚ฌํ•˜๋‹ค.

๊ทธ๋Ÿฌ๋‚˜ Mediator ํŒจํ„ด์—์„œ๋Š” ๋‹ค๋ฅธ ๊ฐ์ฒด๋“ค์ด Mediator ๊ฐ์ฒด์˜ ์กด์žฌ๋ฅผ ์•Œ์•„์•ผ ํ•˜์ง€๋งŒ, Facade ํŒจํ„ด์—์„œ๋Š” ๊ทธ๋Ÿด ํ•„์š”๊ฐ€ ์—†๋‹ค๋Š” ๊ฒƒ์ด ๋‹ค๋ฅธ ์ ์ด๋‹ค.

์ฆ‰, Facade ํŒจํ„ด์—์„œ๋Š” ์„œ๋ธŒ ์‹œ์Šคํ…œ ๋‚ด์˜ ๊ฐ์ฒด๋“ค์ด Facade ๊ฐ์ฒด์˜ ์กด์žฌ๋ฅผ ์•Œ ํ•„์š”๊ฐ€ ์—†๋‹ค.

๋”๋ถˆ์–ด Mediator ํŒจํ„ด์—์„œ๋Š” ๊ฐ ๊ฐ์ฒด๋“ค์ด ์„œ๋กœ ์ง์ ‘์ ์ธ ํ†ต์‹ ์„ ํ•˜์ง€ ์•Š๋Š” ๊ฒƒ์ด ์›์น™์ด๋‚˜, Facade ํŒจํ„ด์—์„œ๋Š” ๊ทธ๋Ÿฐ ์ œ์•ฝ์ด ์—†๋‹ค.

ํ•œํŽธ Facade ๊ฐ์ฒด๋Š” ํ•˜๋‚˜๋งŒ ์กด์žฌํ•˜๋ฉด ๋  ๊ฒฝ์šฐ๊ฐ€ ๋งŽ์œผ๋ฏ€๋กœ, ์ฃผ๋กœ Singleton ํŒจํ„ด ํ˜•ํƒœ๋กœ ๊ตฌํ˜„๋  ๊ฒฝ์šฐ๊ฐ€ ๋งŽ๋‹ค.


Flyweight ํŒจํ„ด์€ Strategy, State, Interpreter ํŒจํ„ด์—์„œ ์•Œ๊ณ ๋ฆฌ์ฆ˜์ด๋‚˜ ์ƒํƒœ ์ •๋ณด Terminal Symbol๋“ค์„ ๊ฐ๊ฐ ๊ณต์œ ํ•˜๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋  ์ˆ˜ ์žˆ๋‹ค.


Decorator ํŒจํ„ด์€ ์ด๋ฏธ ์กด์žฌํ•˜๋Š” ๊ฐ์ฒด์—๊ฒŒ ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ์„ ๋ง์ž…ํžˆ๋Š” ์—ญํ• ์„ ํ•˜๋Š”๋ฐ ๋ฐ˜ํ•ด
Strategy ํŒจํ„ด์€ ๊ฐ์ฒด ๋‚ด๋ถ€์˜ ๊ตฌ์ฒด์ ์ธ ๋™์ž‘์ด๋‚˜ ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ์™ธ๋ถ€ ๊ฐ์ฒด์—๊ฒŒ ์œ„์ž„์‹œํ‚ค๋Š” ํ˜•ํƒœ๋‹ค.

๋”ฐ๋ผ์„œ Decorate ํŒจํ„ด์€ ๊ฐ์ฒด์˜ ๊ฒ‰์„ ๋ณ€๊ฒฝ์‹œ์ผœ์ฃผ๋Š” ์—ญํ• ์„ ํ•˜๊ณ , Strategy ํŒจํ„ด์€ ๊ฐ์ฒด์˜ ์†์„ ๋ณ€๊ฒฝ์‹œ์ผœ์ฃผ๋Š” ์—ญํ• ์„ ํ•œ๋‹ค๊ณ  ํ•  ์ˆ˜ ์žˆ๋‹ค.


Proxy ํŒจํ„ด์€ Client๊ฐ€ ํ˜ธ์ถœํ•˜๋Š” ์ธํ„ฐํŽ˜์ด์Šค์˜ ๋ณ€๊ฒฝ ์—†์ด ๋‹ค๋ฅธ ๊ฐ์ฒด์˜ ๊ธฐ๋Šฅ ์ˆ˜ํ–‰์„ ๋Œ€ํ–‰ํ•ด์ฃผ๋Š” ์—ญํ• ์„ ํ•œ๋‹ค.

๊ทธ๋Ÿฌ๋‚˜ Proxy ํŒจํ„ด์€ Adapter ํŒจํ„ด๊ณผ๋Š” ๋‹ฌ๋ฆฌ ์ธํ„ฐํŽ˜์ด์Šค์˜ ๋ณ€๊ฒฝ์ด ์ฃผ๋ชฉ์ ์ด ์•„๋‹ˆ๋‹ค.


Memento ํŒจํ„ด์€ Iterator ํŒจํ„ด์˜ ๋ฐ˜๋ณต ์ƒํƒœ๋ฅผ ์ €์žฅํ•˜๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋˜๊ฑฐ๋‚˜,
Command ํŒจํ„ด์—์„œ ๋ช…๋ น์ด ์ˆ˜ํ–‰๋˜๊ธฐ ์ด์ „ ์ƒํƒœ๋กœ ๋˜๋Œ๋ฆฌ๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋  ์ˆ˜ ์žˆ๋‹ค.


Observer ํŒจํ„ด์€ ๊ฐ์ฒด๋“ค๊ฐ„์˜ ์˜์กด ๊ด€๊ณ„๋ฅผ ๋ถ„์‚ฐ์‹œ์ผœ ๊ด€๋ฆฌํ•˜๋Š”๋ฐ ๋ฐ˜ํ•ด Mediator ํŒจํ„ด์€ ์ด๋“ค์„ ์ค‘์•™ ์ง‘์ค‘์ ์œผ๋กœ ๊ด€๋ฆฌํ•œ๋‹ค.

๋”ฐ๋ผ์„œ ๊ฐ์ฒด๋“ค๊ฐ„์˜ ๋ณต์žกํ•œ ์˜์กด ๊ด€๊ณ„๋ฅผ ํ•œ ๊ณณ์—์„œ ๊ด€๋ฆฌํ•˜๊ณ  ์‹ถ์„ ๋•Œ Mediator ํŒจํ„ด์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.


Template Method ํŒจํ„ด์—์„œ๋Š” ๋‚ด๋ถ€์˜ ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋‹จ๊ณ„๋ฅผ ์ •์˜ํ•  ๋•Œ Strategy ํŒจํ„ด์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์œผ๋ฉฐ,
๋Œ€๊ฐœ Factory Method ํŒจํ„ด์„ ์‚ฌ์šฉํ•ด์„œ ํ•„์š”ํ•œ ๊ฐ์ฒด๋ฅผ ์ƒ์„ฑํ•œ๋‹ค.



๋””์ž์ธ ํŒจํ„ด์˜ ๋ฒ”์ฃผ

๋Œ€๋ถ€๋ถ„์˜ ์นดํƒˆ๋กœ๊ทธ์—์„œ๋Š” ๋ช‡ ๊ฐ€์ง€ ๋ฒ”์ฃผ์— ๋งž์ถฐ์„œ ๋””์ž์ธ ํŒจํ„ด์„ ๋ถ„๋ฅ˜ํ•˜๊ณ  ์žˆ๋Š”๋ฐ,

๊ทธ์ค‘ ์ œ์ผ ์œ ๋ช…ํ•œ ๋ถ„๋ฅ˜ ๋ฐฉ๋ฒ•์€ ์ƒ์„ฑ, ํ–‰๋™, ๊ตฌ์กฐ๋ผ๋Š” 3๊ฐ€์ง€ ๋ฒ”์ฃผ๋กœ ์šฉ๋„์— ๋”ฐ๋ผ ๋‚˜๋ˆ„๋Š” ๊ฒƒ์ด๋‹ค.


  • ์•„๋ž˜์˜ ํŒจํ„ด ๋ชฉ๋ก๋“ค ์ค‘ Chapter 1 ~ 12์—์„œ ์„ค๋ช…๋˜์ง€ ์•Š์€ ํŒจํ„ด๋“ค์€ Chapter 13์—์„œ ์„ค๋ช…๋œ๋‹ค.
  • ํด๋ž˜์Šค ๋‹ค์ด์–ด๊ทธ๋žจ๋“ค๊ณผ ์˜๋ฌธ ์„ค๋ช…์€ GoF Design Patterns Card์—์„œ ๊ฐ€์ ธ์™”๋‹ค.


์ƒ์„ฑ ํŒจํ„ด(Creational Pattern)

๐Ÿ’ก ๊ฐ์ฒด ์ธ์Šคํ„ด์Šค๋ฅผ ์ƒ์„ฑํ•˜๋Š” ํŒจํ„ด

  • ํด๋ผ์ด์–ธํŠธ์™€ ๊ทธ ํด๋ผ์ด์–ธํŠธ๊ฐ€ ์ƒ์„ฑํ•ด์•ผ ํ•˜๋Š” ๊ฐ์ฒด ์ธ์Šคํ„ด์Šค ์‚ฌ์ด์˜ ์—ฐ๊ฒฐ์„ ๋Š์–ด์ค€๋‹ค.
  • ๊ธฐ์กด ์ฝ”๋“œ์˜ ์œ ์—ฐ์„ฑ๊ณผ ์žฌ์‚ฌ์šฉ์„ ์ฆ๊ฐ€์‹œํ‚ค๋Š” ๋‹ค์–‘ํ•œ ๊ฐ์ฒด ์ƒ์„ฑ ๋งค์ปค๋‹ˆ์ฆ˜๋“ค์„ ์ œ๊ณตํ•œ๋‹ค.

ํŒฉํ† ๋ฆฌ ๋ฉ”์„œ๋“œ(Factory Method) ํŒจํ„ด

์„œ๋ธŒํด๋ž˜์Šค์—์„œ ์ƒ์„ฑํ•  ๊ตฌ์ƒ ํด๋ž˜์Šค๋ฅผ ๊ฒฐ์ •ํ•œ๋‹ค.

์ฆ‰, ๋ถ€๋ชจ ํด๋ž˜์Šค์—์„œ ๊ฐ์ฒด๋“ค์„ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ๋Š” ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์ œ๊ณตํ•˜์ง€๋งŒ ์ž์‹ ํด๋ž˜์Šค๋“ค์ด ์ƒ์„ฑ๋  ๊ฐ์ฒด๋“ค์˜ ์œ ํ˜•์„ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Define an interface for creating an object, but let subclasses decide which class to instantiate.

Lets a class defer instantiation to subclasses.


แ„‘แ…ขแ†จแ„แ…ฉแ„…แ…ต แ„†แ…ฆแ„‰แ…ฅแ„ƒแ…ณ แ„‘แ…ขํ„ด

์ถ”์ƒ ํŒฉํ† ๋ฆฌ(Abstract Factory) ํŒจํ„ด

ํด๋ผ์ด์–ธํŠธ์—์„œ ๊ตฌ์ƒ ํด๋ž˜์Šค๋ฅผ ์ง€์ •ํ•˜์ง€ ์•Š์œผ๋ฉด์„œ๋„ ๊ฐ์ฒด๊ตฐ(๊ด€๋ จ ๊ฐ์ฒด๋“ค์˜ ๋ชจ์Œ)์„ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•ด์ค€๋‹ค.

Provides an interface for creating families of related or dependent objects without specifying their concrete class.


แ„Žแ…ฎแ„‰แ…กแ†ผ แ„‘แ…ขแ†จแ„แ…ฉแ„…แ…ต แ„‘แ…ขแ„แ…ฅแ†ซ

๋นŒ๋”(Builder) ํŒจํ„ด

๋ณต์žกํ•œ ๊ฐ์ฒด๋“ค์„ ๋‹จ๊ณ„๋ณ„๋กœ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•ด์ค€๋‹ค.

์ด ํŒจํ„ด์„ ํ†ตํ•ด ๊ฐ™์€ ์ œ์ž‘ ์ฝ”๋“œ๋กœ ๊ฐ์ฒด์˜ ๋‹ค์–‘ํ•œ ์œ ํ˜•๋“ค๊ณผ ํ‘œํ˜„์„ ์ œ์ž‘ํ•  ์ˆ˜ ์žˆ๊ฒŒ ๋œ๋‹ค.

Separate the construction of a complex object from its representing so that the same construction process can create different representations.


แ„‡แ…ตแ†ฏแ„ƒแ…ฅ แ„‘แ…ขแ„แ…ฅแ†ซ

ํ”„๋กœํ† ํƒ€์ž…(Prototype) ํŒจํ„ด

์ฝ”๋“œ๋ฅผ ๊ทธ๋“ค์˜ ํด๋ž˜์Šค๋“ค์— ์˜์กด์‹œํ‚ค์ง€ ์•Š๊ณ  ๊ธฐ์กด ๊ฐ์ฒด๋“ค์„ ๋ณต์‚ฌํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Specify the kinds of objects to create using a prototypical instance, and create new objects by copying this prototype.


แ„‘แ…ณแ„…แ…ฉแ„แ…ฉแ„แ…กแ„‹แ…ตแ†ธ แ„‘แ…ขแ„แ…ฅแ†ซ

์‹ฑ๊ธ€ํ„ด(Singleton) ํŒจํ„ด

ํด๋ž˜์Šค์— ์ธ์Šคํ„ด์Šค๊ฐ€ ํ•˜๋‚˜๋งŒ ์žˆ๋„๋ก ํ•˜๋ฉด์„œ ์ด ์ธ์Šคํ„ด์Šค์— ๋Œ€ํ•œ ์ „์—ญ ์ ‘๊ทผ(์•ก์„ธ์Šค) ์ง€์ ์„ ์ œ๊ณตํ•œ๋‹ค.

Ensure a class only has one instance and provide a global point of access to it.


แ„‰แ…ตแ†ผแ„€แ…ณแ†ฏแ„แ…ฅแ†ซ แ„‘แ…ขแ„แ…ฅแ†ซ


ํ–‰๋™ ํŒจํ„ด(Behavioral Pattern)

๐Ÿ’ก ํด๋ž˜์Šค์™€ ๊ฐ์ฒด๋“ค์ด ์ƒํ˜ธ์ž‘์šฉํ•˜๋Š” ๋ฐฉ๋ฒ•๊ณผ ์—ญํ• ์„ ๋ถ„๋‹ดํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ๋‹ค๋ฃจ๋Š” ํŒจํ„ด

  • ์•Œ๊ณ ๋ฆฌ์ฆ˜๋“ค ๋ฐ ๊ฐ์ฒด ๊ฐ„์˜ ์ฑ…์ž„ ํ• ๋‹น๊ณผ ๊ด€๋ จ์ด ์žˆ๋‹ค.

์ฑ…์ž„ ์—ฐ์‡„(Chain of Responsibility) ํŒจํ„ด

ํ•ธ๋“ค๋Ÿฌ๋“ค์˜ ์ฒด์ธ(์‚ฌ์Šฌ)์„ ๋”ฐ๋ผ ์š”์ฒญ์„ ์ „๋‹ฌํ•  ์ˆ˜ ์žˆ๊ฒŒ ํ•ด์ค€๋‹ค.

๊ฐ ํ•ธ๋“ค๋Ÿฌ๋Š” ์š”์ฒญ์„ ๋ฐ›์œผ๋ฉด ์š”์ฒญ์„ ์ฒ˜๋ฆฌํ• ์ง€ ์•„๋‹ˆ๋ฉด ์ฒด์ธ์˜ ๋‹ค์Œ ํ•ธ๋“ค๋Ÿฌ๋กœ ์ „๋‹ฌํ• ์ง€๋ฅผ ๊ฒฐ์ •ํ•œ๋‹ค.

Avoid coupling the sender of a request to its receiver by giving more than one object a chance to handle the request.

Chain the receiving objects and pass the request along the chain until an object handles it.


แ„Žแ…ขแ†จแ„‹แ…ตแ†ท แ„‹แ…งแ†ซแ„‰แ…ซ แ„‘แ…ขํ„ด

์ปค๋งจ๋“œ(Command) ํŒจํ„ด

์š”์ฒญ์„ ์š”์ฒญ์— ๋Œ€ํ•œ ๋ชจ๋“  ์ •๋ณด๊ฐ€ ํฌํ•จ๋œ ๋…๋ฆฝ์‹คํ–‰ํ˜• ๊ฐ์ฒด๋กœ ๋ณ€ํ™˜ํ•œ๋‹ค.

์ด ๋ณ€ํ™˜์€ ๋‹ค์–‘ํ•œ ์š”์ฒญ๋“ค์ด ์žˆ๋Š” ๋ฉ”์„œ๋“œ๋“ค์„ ์ธ์ˆ˜ํ™” ํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•˜๋ฉฐ,
์š”์ฒญ์˜ ์‹คํ–‰์„ ์ง€์—ฐ ๋˜๋Š” ๋Œ€๊ธฐ์—ด์— ๋„ฃ์„ ์ˆ˜ ์žˆ๋„๋ก ํ•˜๊ณ , ๋˜ ์‹คํ–‰ ์ทจ์†Œํ•  ์ˆ˜ ์žˆ๋Š” ์ž‘์—…์„ ์ง€์›ํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Encapsulate a request as an object,
thereby letting you parameterize clients with different requests, queue or log requests, and support undoable operations.


์ปค๋งจ๋“œ แ„‘แ…ขํ„ด

์ธํ„ฐํ”„๋ฆฌํ„ฐ(Interpreter) ํŒจํ„ด

์–ด๋–ค ์–ธ์–ด์˜ ๋Œ€ํ•ด, ๊ทธ ์–ธ์–ด์˜ ๋ฌธ๋ฒ•์— ๋Œ€ํ•œ ํ‘œํ˜„์„ ์ •์˜ํ•˜๋ฉด์„œ ๊ทธ ํ‘œํ˜„์„ ์‚ฌ์šฉํ•˜์—ฌ ํ•ด๋‹น ์–ธ์–ด๋กœ ๊ธฐ์ˆ ๋œ ๋ฌธ์žฅ์„ ํ•ด์„ํ•˜๋Š” ํ•ด์„์ž๋ฅผ ํ•จ๊ป˜ ์ •์˜ํ•œ๋‹ค.

Given a language, define a representation for its grammar along with an interpreter that uses the representation to interpret sentences in the language.


แ„‹แ…ตแ†ซแ„แ…ฅแ„‘แ…ณแ„…แ…ตแ„แ…ฅ แ„‘แ…ขํ„ด

๋ฐ˜๋ณต์ž(Iterator) ํŒจํ„ด

์ปฌ๋ ‰์…˜์ด ์–ด๋–ค ์‹์œผ๋กœ ๊ตฌํ˜„๋˜์—ˆ๋Š”์ง€(๋ฆฌ์ŠคํŠธ, ์Šคํƒ, ํŠธ๋ฆฌ ๋“ฑ) ๋“œ๋Ÿฌ๋‚ด์ง€ ์•Š์œผ๋ฉด์„œ๋„
์ปฌ๋ ‰์…˜ ๋‚ด์— ์žˆ๋Š” ๋ชจ๋“  ๊ฐ์ฒด๋ฅผ ํ•˜๋‚˜์”ฉ ์ˆœํšŒํ•˜์—ฌ ๋ฐ˜๋ณต ์ž‘์—…์„ ์ฒ˜๋ฆฌํ•  ์ˆ˜ ์žˆ๊ฒŒ ํ•ด์ค€๋‹ค.

Provide a way to access the elements of an aggregate object sequentially without exposing its underlying representation.


แ„‡แ…กแ†ซแ„‡แ…ฉแ†จแ„Œแ…ก แ„‘แ…ขํ„ด

์ค‘์žฌ์ž(Mediator) ํŒจํ„ด

๊ฐ์ฒด ๊ฐ„์˜ ์ง์ ‘ ํ†ต์‹ ์„ ์ œํ•œํ•˜๊ณ  ์ค‘์žฌ์ž ๊ฐ์ฒด๋ฅผ ํ†ตํ•ด์„œ๋งŒ ํ˜‘๋ ฅํ•˜๋„๋ก ํ•œ๋‹ค.

๋”ฐ๋ผ์„œ ์ด ํŒจํ„ด์„ ํ†ตํ•ด ๊ฐ์ฒด ๊ฐ„์˜ ํ˜ผ๋ž€์Šค๋Ÿฌ์šด ์˜์กด ๊ด€๊ณ„๋“ค์„ ์ค„์ผ ์ˆ˜ ์žˆ๋‹ค.

Define an object that encapsulates how a set of objects interact.

Promotes loose coupling by keeping objects from referring to each other explicitly and it lets you vary their interactions independently.


แ„Œแ…ฎแ†ผแ„Œแ…ขแ„Œแ…ก แ„‘แ…ขํ„ด

๋ฉ”๋ฉ˜ํ† (Memento) ํŒจํ„ด

๊ฐ์ฒด์˜ ๊ตฌํ˜„ ์„ธ๋ถ€ ์‚ฌํ•ญ์„ ๊ณต๊ฐœํ•˜์ง€ ์•Š์œผ๋ฉด์„œ ํ•ด๋‹น ๊ฐ์ฒด์˜ ์ด์ „ ์ƒํƒœ๋ฅผ ์ €์žฅํ•˜๊ณ  ๋ณต์›ํ•  ์ˆ˜ ์žˆ๊ฒŒ ํ•ด์ค€๋‹ค.

Without violating encapsulation, capture and externalize an object's internal state so that the object can be restored to this state later.


แ„‘แ…ขแ†จแ„แ…ฉแ„…แ…ต แ„†แ…ฆแ„‰แ…ฅแ„ƒแ…ณ แ„‘แ…ขํ„ด

์˜ต์ €๋ฒ„(Observer) ํŒจํ„ด

์—ฌ๋Ÿฌ ๊ฐ์ฒด์— ์ž์‹ ์ด ๊ด€์ฐฐ ์ค‘์ธ ๊ฐ์ฒด์— ๋ฐœ์ƒํ•˜๋Š” ๋ชจ๋“  ์ด๋ฒคํŠธ์— ๋Œ€ํ•˜์—ฌ ์•Œ๋ฆฌ๋Š” ๊ตฌ๋… ๋ฉ”์ปค๋‹ˆ์ฆ˜์„ ์ •์˜ํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Define a one-to-many dependency between objects
so that when one object changes state, all its dependents are notified and updated automatically.


แ„‹แ…ฉแ†ธแ„Œแ…ฅแ„‡แ…ฅ แ„‘แ…ขํ„ด

์ƒํƒœ(State) ํŒจํ„ด

์ƒํƒœ๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœ ํ•˜๋Š” ํ–‰๋™์„ ์บก์Аํ™”ํ•œ ๋‹ค์Œ ์œ„์ž„์œผ๋กœ ํ•„์š”ํ•œ ํ–‰๋™์„ ์„ ํƒํ•œ๋‹ค.

์ฆ‰, ๊ฐ์ฒด์˜ ๋‚ด๋ถ€ ์ƒํƒœ๊ฐ€ ๋ณ€๊ฒฝ๋  ๋•Œ ํ•ด๋‹น ๊ฐ์ฒด๊ฐ€ ๊ทธ์˜ ํ–‰๋™์„ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•˜๊ธฐ์—
๊ฐ์ฒด๊ฐ€ ํ–‰๋™์„ ๋ณ€๊ฒฝํ•  ๋•Œ ๊ฐ์ฒด๊ฐ€ ํด๋ž˜์Šค๋ฅผ ๋ณ€๊ฒฝํ•œ ๊ฒƒ์ฒ˜๋Ÿผ ๋ณด์ผ ์ˆ˜ ์žˆ๋‹ค.

Allow an object to alter its behavior when its internal state changes.

The object will appear to change its class.


แ„‰แ…กแ†ผแ„แ…ข แ„‘แ…ขํ„ด

์ „๋žต(Strategy) ํŒจํ„ด

๊ตํ™˜ ๊ฐ€๋Šฅํ•œ ํ–‰๋™์„ ์บก์Аํ™”ํ•˜๊ณ  ์œ„์ž„์œผ๋กœ ์–ด๋–ค ํ–‰๋™์„ ์‚ฌ์šฉํ• ์ง€ ๊ฒฐ์ •ํ•œ๋‹ค.

์ฆ‰, ์•Œ๊ณ ๋ฆฌ์ฆ˜๋“ค์˜ ํŒจ๋ฐ€๋ฆฌ๋ฅผ ์ •์˜ํ•˜๊ณ , ๊ฐ ํŒจ๋ฐ€๋ฆฌ๋ฅผ ๋ณ„๋„์˜ ํด๋ž˜์Šค์— ๋„ฃ์€ ํ›„ ๊ทธ๋“ค์˜ ๊ฐ์ฒด๋“ค์„ ์ƒํ˜ธ๊ตํ™˜ํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Define a family of algorithms, encapsulate each one, and make them interchangeable.

Lets the algorithm vary independently from clients that use it.


แ„Œแ…ฅแ†ซแ„…แ…ฃแ†จ แ„‘แ…ขํ„ด

ํ…œํ”Œ๋ฆฟ ๋ฉ”์„œ๋“œ(Template Method) ํŒจํ„ด

์„œ๋ธŒํด๋ž˜์Šค์—์„œ ์ƒ์„ฑํ•  ๊ตฌ์ƒ ํด๋ž˜์Šค๋ฅผ ๊ฒฐ์ •ํ•œ๋‹ค.

๋ถ€๋ชจ ํด๋ž˜์Šค์—์„œ ์•Œ๊ณ ๋ฆฌ์ฆ˜์˜ ๊ณจ๊ฒฉ์„ ์ •์˜ํ•˜์ง€๋งŒ,
ํ•ด๋‹น ์•Œ๊ณ ๋ฆฌ์ฆ˜์˜ ๊ตฌ์กฐ๋ฅผ ๋ณ€๊ฒฝํ•˜์ง€ ์•Š๊ณ  ์ž์‹ ํด๋ž˜์Šค๋“ค์ด ์•Œ๊ณ ๋ฆฌ์ฆ˜์˜ ํŠน์ • ๋‹จ๊ณ„๋“ค์„ ์˜ค๋ฒ„๋ผ์ด๋“œ(์žฌ์ •์˜)ํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Define the skeleton of an algorithm in an operation, deferring some steps to subclasses.

Lets subclasses redefine certain steps of an algorithm without changing the algorithm's structure.


แ„แ…ฆแ†ทแ„‘แ…ณแ†ฏแ„…แ…ตแ†บ แ„†แ…ฆแ„‰แ…ฅแ„ƒแ…ณ แ„‘แ…ขํ„ด

๋น„์ง€ํ„ฐ(Visitor) ํŒจํ„ด

์•Œ๊ณ ๋ฆฌ์ฆ˜๋“ค์„ ๊ทธ๋“ค์ด ์ž‘๋™ํ•˜๋Š” ๊ฐ์ฒด๋“ค๋กœ๋ถ€ํ„ฐ ๋ถ„๋ฆฌํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Represent an operation to be performed on the elements of an object structure.

Lets you define a new operation without changing the classes of the elements on which it operates.


แ„‘แ…ขแ†จแ„แ…ฉแ„…แ…ต แ„†แ…ฆแ„‰แ…ฅแ„ƒแ…ณ แ„‘แ…ขํ„ด


๊ตฌ์กฐ ํŒจํ„ด(Structural Pattern)

๐Ÿ’ก ํด๋ž˜์Šค์™€ ๊ฐ์ฒด๋“ค์˜ ๊ตฌ์กฐ๋ฅผ ์œ ์—ฐํ•˜๊ณ  ํšจ์œจ์ ์œผ๋กœ ์œ ์ง€ํ•˜๋ฉด์„œ ๋” ํฐ ๊ตฌ์กฐ๋กœ ๋งŒ๋“ค ์ˆ˜ ์žˆ๊ฒŒ ๊ตฌ์ƒ์„ ์‚ฌ์šฉํ•˜๋Š” ํŒจํ„ด

  • ํด๋ž˜์Šค์™€ ๊ฐ์ฒด๊ฐ€ ์ƒˆ๋กœ์šด ๊ตฌ์กฐ์™€ ๊ธฐ๋Šฅ์„ ๋งŒ๋“ค๋ ค๊ณ  ํด๋ž˜์Šค์™€ ๊ฐ์ฒด๋ฅผ ๊ตฌ์„ฑํ•˜๋Š” ๋ฐฉ๋ฒ•๋“ค์ด๋‹ค.

์–ด๋Œ‘ํ„ฐ(Adapter) ํŒจํ„ด

๊ฐ์ฒด๋ฅผ ๊ฐ์‹ธ์„œ ๋‹ค๋ฅธ ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์ œ๊ณตํ•˜๋Š” ๊ฒƒ์„ ํ†ตํ•ด ํ˜ธํ™˜๋˜์ง€ ์•Š๋Š” ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ๊ฐ€์ง„ ๊ฐ์ฒด๋“ค์ด ํ˜‘์—…ํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Convert the interface of a class into another interface clients expect.

Lets classes work together that couldn't otherwise because of incompatible interfaces.


แ„‹แ…ฅแ„ƒแ…ขแ†ธแ„แ…ฅ แ„‘แ…ขํ„ด

๋ธŒ๋ฆฌ์ง€(Bridge) ํŒจํ„ด

ํฐ ํด๋ž˜์Šค ๋˜๋Š” ๋ฐ€์ ‘ํ•˜๊ฒŒ ๊ด€๋ จ๋œ ํด๋ž˜์Šค๋“ค์˜ ์ง‘ํ•ฉ์„ ๋‘ ๊ฐœ์˜ ๊ฐœ๋ณ„ ๊ณ„์ธต๊ตฌ์กฐ(์ถ”์ƒํ™” ๋ฐ ๊ตฌํ˜„)๋กœ ๋‚˜๋ˆˆ ํ›„ ๊ฐ๊ฐ ๋…๋ฆฝ์ ์œผ๋กœ ๊ฐœ๋ฐœํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Decouple an abstraction from its implementation so that the two can vary independently.


แ„‡แ…ณแ„…แ…ตแ„Œแ…ต แ„‘แ…ขํ„ด

๋ณตํ•ฉ์ฒด(Composite) ํŒจํ„ด

๊ฐ์ฒด๋“ค์„ ํŠธ๋ฆฌ ๊ตฌ์กฐ๋“ค๋กœ ๊ตฌ์„ฑํ•œ ํ›„, ํด๋ผ์ด์–ธํŠธ์—์„œ ๊ฐ์ฒด ์ปฌ๋ ‰์…˜๊ณผ ๊ฐœ๋ณ„ ๊ฐ์ฒด๋ฅผ ๋˜‘๊ฐ™์ด ๋‹ค๋ฃฐ ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Compose objects into tree structures to represent part-whole hierarchies.

Lets clients treat individual objects and compositions of objects uniformly.


แ„‡แ…ฉแ†จแ„’แ…กแ†ธแ„Žแ…ฆ แ„‘แ…ขํ„ด

๋ฐ์ฝ”๋ ˆ์ดํ„ฐ(Decorator) ํŒจํ„ด

๊ฐ์ฒด๋ฅผ ํŠน์ˆ˜ ๋ž˜ํผ(wrapper) ๊ฐ์ฒด๋“ค๋กœ ๊ฐ์‹ธ์„œ ์ƒˆ๋กœ์šด ํ–‰๋™์„ ์ œ๊ณตํ•œ๋‹ค.

Attach additional responsibilities to an object dynamically.

Provide a flexible alternative to sub-classing for extending functionality.


แ„‘แ…ขแ†จแ„แ…ฉแ„…แ…ต แ„†แ…ฆแ„‰แ…ฅแ„ƒแ…ณ แ„‘แ…ขํ„ด

ํผ์‚ฌ๋“œ(Facade) ํŒจํ„ด

๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ, ํ”„๋ ˆ์ž„์›Œํฌ ๋˜๋Š” ๋‹ค๋ฅธ ์ผ๋ จ์˜ ํด๋ž˜์Šค๋“ค์— ๋Œ€ํ•œ ๋‹จ์ˆœํ™”๋œ ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์ œ๊ณตํ•œ๋‹ค.

Provide a unified interface to a set of interfaces in a subsystem.

Defines a high- level interface that makes the subsystem easier to use.


แ„‘แ…ฅแ„‰แ…กแ„ƒแ…ณ แ„‘แ…ขํ„ด

ํ”Œ๋ผ์ด์›จ์ดํŠธ(Flyweight) ํŒจํ„ด

๊ฐ ๊ฐ์ฒด์— ๋ชจ๋“  ๋ฐ์ดํ„ฐ๋ฅผ ์œ ์ง€ํ•˜๋Š” ๋Œ€์‹ ,
์—ฌ๋Ÿฌ ๊ฐ์ฒด๋“ค ๊ฐ„์— ์ƒํƒœ์˜ ๊ณตํ†ต ๋ถ€๋ถ„๋“ค์„ ๊ณต์œ ํ•˜์—ฌ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” RAM์— ๋” ๋งŽ์€ ๊ฐ์ฒด๋“ค์„ ํฌํ•จํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Use sharing to support large numbers of fine grained objects efficiently.


แ„‘แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„‹แ…ฐแ„‹แ…ตแ„แ…ณ แ„‘แ…ขํ„ด

ํ”„๋ก์‹œ(Proxy) ํŒจํ„ด

๊ฐ์ฒด๋ฅผ ๊ฐ์‹ธ์„œ ๊ทธ ๊ฐ์ฒด๋กœ์˜ ์ ‘๊ทผ์„ ์ œ์–ดํ•œ๋‹ค.

๋‹ค๋ฅธ ๊ฐ์ฒด์— ๋Œ€ํ•œ ๋Œ€์ฒด ๋˜๋Š” ์ž๋ฆฌํ‘œ์‹œ์ž๋ฅผ ์ œ๊ณตํ•  ์ˆ˜ ์žˆ์œผ๋ฉฐ,
ํด๋ผ์ด์–ธํŠธ์˜ ์š”์ฒญ์ด ์›๋ž˜ ๊ฐ์ฒด์— ์ „๋‹ฌ๋˜๊ธฐ ์ „ ๋˜๋Š” ํ›„์— ๋ฌด์–ธ๊ฐ€๋ฅผ ์ˆ˜ํ–‰ํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•œ๋‹ค.

Provide a surrogate or placeholder for another object to control access to it.


แ„‘แ…ณแ„…แ…ฉแ†จแ„‰แ…ต แ„‘แ…ขํ„ด




๋ฐ์ฝ”๋ ˆ์ดํ„ฐ ํŒจํ„ด์€ 3๊ฐ€์ง€ ๋ฒ”์ฃผ ์ค‘ ๊ตฌ์กฐ ํŒจํ„ด์— ๋“ค์–ด๊ฐ€ ์žˆ๋Š”๋ฐ,
์ด ํŒจํ„ด์€ ํ–‰๋™์„ ์ถ”๊ฐ€ํ•˜๋Š” ํŒจํ„ด์ด๊ธฐ ๋•Œ๋ฌธ์— ํ–‰๋™ ํŒจํ„ด์— ๋“ค์–ด๊ฐ€์•ผ ํ•œ๋‹ค๊ณ  ์ƒ๊ฐํ•˜๋Š” ๊ฒฝ์šฐ๊ฐ€ ๋งŽ๋‹ค.


  • ๊ตฌ์กฐ ํŒจํ„ด์€ ํด๋ž˜์Šค์™€ ๊ฐ์ฒด๊ฐ€ ์ƒˆ๋กœ์šด ๊ตฌ์กฐ์™€ ๊ธฐ๋Šฅ์„ ๋งŒ๋“ค๋ ค๊ณ  ํด๋ž˜์Šค์™€ ๊ฐ์ฒด๋ฅผ ๊ตฌ์„ฑํ•˜๋Š” ๋ฐฉ๋ฒ•์ด๋‹ค.
  • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ ํŒจํ„ด์€ ํ•œ ๊ฐ์ฒด๋ฅผ ๋‹ค๋ฅธ ๊ฐ์ฒด๋กœ ๊ฐ์‹ธ์„œ ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ์„ ์ œ๊ณตํ•ด ์ฃผ๋Š” ํŒจํ„ด์ด๋‹ค.

๋”ฐ๋ผ์„œ ํ–‰๋™ ํŒจํ„ด์˜ ์šฉ๋„์ธ ๊ฐ์ฒด ์‚ฌ์ด์˜ ํ†ต์‹ ๊ณผ ์ƒํ˜ธ์—ฐ๊ฒฐ๋ณด๋‹ค๋Š” ๊ฐ์ฒด๋“ค์„ ๋™์ ์œผ๋กœ ๊ตฌ์„ฑํ•ด์„œ ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ์„ ์–ป๋Š” ์ชฝ์— ์ดˆ์ ์„ ๋งž์ถฐ์•ผ ํ•œ๋‹ค.


๋ฐ์ฝ”๋ ˆ์ดํ„ฐ(๊ตฌ์กฐ ํŒจํ„ด)๊ณผ ํ”„๋ก์‹œ ํŒจํ„ด(ํ–‰๋™ ํŒจํ„ด)์ด ์ƒ๋‹นํžˆ ์œ ์‚ฌํ•˜๊ธฐ ๋•Œ๋ฌธ์— ๋ถ„๋ฅ˜ํ•˜๊ธฐ๊ฐ€ ๋”์šฑ ์–ด๋ ค์šด๋ฐ,
์ด ๋‘˜์€ ์šฉ๋„๊ฐ€ ๋‹ค๋ฅด๋‹ค๋Š” ๊ฒƒ์„ ๋ฐ˜๋“œ์‹œ ๊ธฐ์–ตํ•˜๊ธธ ๋ฐ”๋ž€๋‹ค.

  • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ ํŒจํ„ด : ํด๋ž˜์Šค์— ์ƒˆ๋กœ์šด ํ–‰๋™์„ ์ถ”๊ฐ€ํ•˜๋Š” ์šฉ๋„
  • ํ”„๋ก์‹œ ํŒจํ„ด : ์–ด๋–ค ํด๋ž˜์Šค๋กœ์˜ ์ ‘๊ทผ์„ ์ œ์–ดํ•˜๋Š” ์šฉ๋„



์ด๋ ‡๊ฒŒ ์ƒ์„ฑ, ๊ตฌ์กฐ, ํ–‰๋™์˜ 3๊ฐ€์ง€ ๋ฒ”์ฃผ๋กœ ๋‚˜๋ˆˆ ํ›„,
๋ถ„๋ฆฌ ํŒจํ„ด(Decoupling Pattern)๊ณผ ๊ฐ™์€ ์‹์œผ๋กœ ํ•˜์œ„ ๋ฒ”์ฃผ๋กœ ๋‹ค์‹œ ๋‚˜๋ˆ„๊ธฐ๋„ ํ•œ๋‹ค.

(When we say two pieces of code are โ€œdecoupledโ€, we mean a change in one usually doesnโ€™t require a change in the other.)





์œ„์™€๋Š” ๋ณ„๊ฐœ๋กœ, ํด๋ž˜์Šค๋ฅผ ๋‹ค๋ฃจ๋Š” ํŒจํ„ด์ธ์ง€, ๊ฐ์ฒด๋ฅผ ๋‹ค๋ฃจ๋Š” ํŒจํ„ด์ธ์ง€์— ๋”ฐ๋ผ ํŒจํ„ด์„ ๋ถ„๋ฅ˜ํ•˜๋Š” ๋ฐฉ๋ฒ•๋„ ์žˆ๋‹ค.


ํด๋ž˜์Šค ํŒจํ„ด(Class Pattern)

๐Ÿ’ก ํด๋ž˜์Šค ์‚ฌ์ด์˜ ๊ด€๊ณ„๊ฐ€ ์ƒ์†์œผ๋กœ ์–ด๋–ป๊ฒŒ ์ •์˜๋˜๋Š”์ง€๋ฅผ ๋‹ค๋ฃฌ๋‹ค.

ํด๋ž˜์Šค ์‚ฌ์ด์˜ ๊ด€๊ณ„๋Š” ๋Œ€๋ถ€๋ถ„ ์ปดํŒŒ์ผํ•  ๋•Œ ๊ฒฐ์ •๋œ๋‹ค.


  • ํŒฉํ† ๋ฆฌ ๋ฉ”์„œ๋“œ(Factory Method) ํŒจํ„ด
  • ์ธํ„ฐํ”„๋ฆฌํ„ฐ(Interpreter) ํŒจํ„ด
  • ํ…œํ”Œ๋ฆฟ ๋ฉ”์„œ๋“œ(Template Method) ํŒจํ„ด
  • ์–ด๋Œ‘ํ„ฐ(Adaptor) ํŒจํ„ด

๊ฐ์ฒด ํŒจํ„ด(Object Pattern)

๐Ÿ’ก ๊ฐ์ฒด ์‚ฌ์ด์˜ ๊ด€๊ณ„๋ฅผ ๋‹ค๋ฃจ๋ฉฐ, ๊ฐ์ฒด ์‚ฌ์ด์˜ ๊ด€๊ณ„๋Š” ๋ณดํ†ต ๊ตฌ์„ฑ์œผ๋กœ ์ •์˜๋œ๋‹ค.

  • ์ผ๋ฐ˜์ ์œผ๋กœ ์‹คํ–‰ ์ค‘์— ๊ด€๊ณ„๊ฐ€ ๊ฒฐ์ •๋˜๊ธฐ ๋•Œ๋ฌธ์— ๋ณด๋‹ค ๋™์ ์ด๊ณ  ์œ ์—ฐํ•˜๋‹ค.

  • ์ถ”์ƒ ํŒฉํ† ๋ฆฌ(Abstract Factory) ํŒจํ„ด
  • ๋นŒ๋”(Builder) ํŒจํ„ด
  • ํ”„๋กœํ† ํƒ€์ž…(Prototype) ํŒจํ„ด
  • ์‹ฑ๊ธ€ํ„ด(Singleton) ํŒจํ„ด
  • ์ฑ…์ž„ ์—ฐ์‡„(Chain of Responsibility) ํŒจํ„ด
  • ์ปค๋งจ๋“œ(Command) ํŒจํ„ด
  • ๋ฐ˜๋ณต์ž(Iterator) ํŒจํ„ด
  • ์ค‘์žฌ์ž(Mediator) ํŒจํ„ด
  • ๋ฉ”๋ฉ˜ํ† (Memento) ํŒจํ„ด
  • ์˜ต์ €๋ฒ„(Observer) ํŒจํ„ด
  • ์ƒํƒœ(State) ํŒจํ„ด
  • ์ „๋žต(Strategy) ํŒจํ„ด
  • ๋น„์ง€ํ„ฐ(Visitor) ํŒจํ„ด
  • ๋ธŒ๋ฆฌ์ง€(Bridge) ํŒจํ„ด
  • ๋ณตํ•ฉ์ฒด(Composite) ํŒจํ„ด
  • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ(Decorator) ํŒจํ„ด
  • ํผ์‚ฌ๋“œ(Facade) ํŒจํ„ด
  • ํ”Œ๋ผ์ด์›จ์ดํŠธ(Flyweight) ํŒจํ„ด
  • ํ”„๋ก์‹œ(Proxy) ํŒจํ„ด



ํŒจํ„ด์œผ๋กœ ์ƒ๊ฐํ•˜๊ธฐ

ํŒจํ„ด์œผ๋กœ ์ƒ๊ฐํ•œ๋‹ค๋Š” ๊ฒƒ์€ ์–ด๋–ค ๋””์ž์ธ์„ ๋ดค์„ ๋•Œ ํŒจํ„ด ์ ์šฉ ์—ฌ๋ถ€๋ฅผ ๊ฒฐ์ •ํ•  ์ˆ˜ ์žˆ๋Š” ์•ˆ๋ชฉ์„ ๊ฐ€์กŒ๋‹ค๋Š” ๊ฒƒ์ด๋‹ค.


๋””์ž์ธ ํŒจํ„ด์€ ํ•„์š”ํ•  ๋•Œ๋งŒ ์จ์•ผ ํ•˜๋Š” ๋„๊ตฌ์— ๋ถˆ๊ณผํ•˜๋‹ค.

์–ด๋–ค ๋””์ž์ธ์ด๋“  ๋  ์ˆ˜ ์žˆ์œผ๋ฉด ๋‹จ์ˆœํ•˜๊ฒŒ ๋งŒ๋“ค์–ด์•ผ ํ•œ๋‹ค.


๋”ฐ๋ผ์„œ ๋””์ž์ธ ์›์น™๋“ค์„ ๋ฐ”ํƒ•์œผ๋กœ ์ œ ํ•  ์ผ์„ ์™„์ˆ˜ํ•  ์ˆ˜ ์žˆ๋Š” ๊ฐ€์žฅ ๊ฐ„๋‹จํ•œ ์ฝ”๋“œ๋ฅผ ๋งŒ๋“ค๋‹ค๊ฐ€,
ํŒจํ„ด์ด ๊ผญ ํ•„์š”ํ•œ ์ƒํ™ฉ(ํ™•์žฅ์„ฑ์ด ํ•„์š”ํ•œ ๊ฒฝ์šฐ)์ด ๋‹ฅ์ณค์„ ๋•Œ์—๋งŒ ๋””์ž์ธ ํŒจํ„ด์„ ์‚ฌ์šฉํ•˜์—ฌ ์กฐ๊ธˆ ๋ณต์žกํ•˜๊ฒŒ ๋งŒ๋“œ๋Š” ๊ฒƒ์ด ์ข‹๋‹ค.

์‹ค์งˆ์ ์ธ ํ™•์žฅ์„ฑ๋งŒ์„ ์ถ”๊ตฌํ•ด์•ผ ํ•œ๋‹ค.


๋˜ํ•œ, ๊ฐ์ฒด์ง€ํ–ฅ ์›์น™๋“ค์„ ์ข…ํ•ฉ์ ์œผ๋กœ ๊ณ ๋ คํ•˜์—ฌ ํŒจํ„ด์ด ํ•„์š”ํ•œ ์ƒํ™ฉ์ด ์™”์„ ๋•Œ ํŒจํ„ด์„ ํ•„์š”์— ๋”ฐ๋ผ ์ ์ ˆํžˆ ๋ณ€ํ˜•ํ•ด์„œ ์ ์šฉํ•  ์ˆ˜๋„ ์žˆ์–ด์•ผ ํ•œ๋‹ค.



๋‹ค์Œ์€ ํŒจํ„ด์œผ๋กœ ์ƒ๊ฐํ•˜๋Š” ๋ฐ ์žˆ์–ด์„œ ๋„์›€์ด ๋  ๋งŒํ•œ ๋‚ด์šฉ๋“ค์ด๋‹ค.


์ตœ๋Œ€ํ•œ ๋‹จ์ˆœํ•˜๊ฒŒ

๋””์ž์ธ์„ ํ•  ๋•Œ ๊ฐ€์žฅ ์ค‘์š”ํ•œ ์›์น™์€ ์ตœ๋Œ€ํ•œ ๋‹จ์ˆœํ•œ ๋ฐฉ๋ฒ•(KISS, Keep it Simple)์œผ๋กœ ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•˜๊ธฐ์ด๋‹ค.

โ€œ์ด ๋ฌธ์ œ์— ์–ด๋–ป๊ฒŒ ํŒจํ„ด์„ ์ ์šฉํ•  ์ˆ˜ ์žˆ์„๊นŒ?โ€๊ฐ€ ์•„๋‹Œ, โ€œ์–ด๋–ป๊ฒŒ ํ•˜๋ฉด ๋‹จ์ˆœํ•˜๊ฒŒ ํ•ด๊ฒฐํ•  ์ˆ˜ ์žˆ์„๊นŒ?โ€์— ์ดˆ์ ์„ ๋งž์ถฐ์•ผ ํ•œ๋‹ค.

๊ฐ€์žฅ ๋‹จ์ˆœํ•˜๊ณ  ์œ ์—ฐํ•œ ๋””์ž์ธ์„ ๋งŒ๋“ค ๋•Œ ํŒจํ„ด์ด ์žˆ์–ด์•ผ ํ•œ๋‹ค๋ฉด ๊ทธ๋•Œ ํŒจํ„ด์„ ์ ์šฉํ•˜๋ฉด ๋œ๋‹ค.


๋””์ž์ธ ํŒจํ„ด์€ ๋งŒ๋ณ‘ํ†ต์น˜์•ฝ์ด ์•„๋‹ˆ๋‹ค

ํŒจํ„ด์€ ๋ฐ˜๋ณต์ ์œผ๋กœ ๋ฐœ์ƒํ•˜๋Š” ๋ฌธ์ œ์˜ ์ผ๋ฐ˜์ ์ธ ํ•ด๊ฒฐ์ฑ…์ด๋ฉฐ, ์ˆ˜๋งŽ์€ ๊ฐœ๋ฐœ์ž๊ฐ€ ์˜ค๋žซ๋™์•ˆ ๊ฒ€์ฆํ•œ ํ•ด๊ฒฐ์ฑ…์ด๋‹ค.

ํ•˜์ง€๋งŒ ํŒจํ„ด์„ ์‚ฌ์šฉํ•  ๋•Œ๋Š” ๊ทธ ํŒจํ„ด์ด ์šฐ๋ฆฌ๊ฐ€ ์„ค๊ณ„ํ•œ ๋””์ž์ธ์— ๋ฏธ์น  ์˜ํ–ฅ๊ณผ ๊ฒฐ๊ณผ๋ฅผ ์ฃผ์˜ ๊นŠ๊ฒŒ ์ƒ๊ฐํ•ด๋ด์•ผ ํ•œ๋‹ค.


ํŒจํ„ด์ด ํ•„์š”ํ•  ๋•Œ

์–ด๋–ค ๊ฒฝ์šฐ์— ํŒจํ„ด์„ ์จ์•ผํ• ๊นŒ?

๋””์ž์ธ์„ ํ•  ๋•Œ, ์ง€๊ธˆ ๋””์ž์ธ์ƒ์˜ ๋ฌธ์ œ์— ์ ํ•ฉํ•˜๋‹ค๋Š” ํ™•์‹ ์ด ๋“ ๋‹ค๋ฉด ํŒจํ„ด์„ ๋„์ž…ํ•ด์•ผ ํ•œ๋‹ค.


โœ… ๊ฐ„๋‹จํ•œ ํ•ด๊ฒฐ์ฑ…๋งŒ์œผ๋กœ๋Š” ๋ถ€์กฑํ•˜๋‹ค๊ณ  ํ™•์‹ ์„ ๊ฐ€์ง€๋ฉด ํ•ด๊ฒฐํ•ด์•ผ ํ•  ๋ฌธ์ œ์™€ ์ œ์•ฝ์กฐ๊ฑด์„ ์ข…ํ•ฉ์ ์œผ๋กœ ๊ณ ๋ คํ•ด ๋ด์•ผ ํ•œ๋‹ค.

  1. ๋งŒ์•ฝ ์–ด๋–ค ํŒจํ„ด์„ ์จ์•ผ ํ• ์ง€ ์ž˜ ๋ชจ๋ฅด๊ฒ ๋‹ค๋ฉด ๋ฌธ์ œ ํ•ด๊ฒฐ์— ๋„์›€์ด ๋  ๋งŒํ•œ ํŒจํ„ด์ด ์žˆ๋Š”์ง€๋ฅผ ํ›‘์–ด๋ด์•ผ ํ•œ๋‹ค.

    ์ด๋•Œ ํŒจํ„ด ์นดํƒˆ๋กœ๊ทธ์˜ ์šฉ๋„์™€ ์ ์šฉ ๋Œ€์ƒ ์„น์…˜์„ ์‚ดํŽด๋ณด๋ฉด ์ข‹๋‹ค.

  2. ๊ดœ์ฐฎ์€ ํŒจํ„ด์„ ์ฐพ์•˜๋‹ค๋ฉด ํŒจํ„ด ์นดํƒˆ๋กœ๊ทธ์˜ ๊ฒฐ๊ณผ ์„น์…˜์„ ๋ณด๊ณ  ๋””์ž์ธ์˜ ๋‚˜๋จธ์ง€ ๋ถ€๋ถ„์— ๋ฏธ์น˜๋Š” ์˜ํ–ฅ์ด ์–ด๋А ์ •๋„์ธ์ง€ ํ™•์ธํ•ด ๋ณด์•„์•ผ ํ•œ๋‹ค.


โœ… ๊ฐ„๋‹จํ•œ ํ•ด๊ฒฐ์ฑ…์œผ๋กœ ๋ฌธ์ œ๊ฐ€ ํ•ด๊ฒฐ๋˜๋Š” ๋ฐ๋„ ์‹œ์Šคํ…œ์˜ ์–ด๋–ค ๋ถ€๋ถ„์ด ๋ณ€๊ฒฝ๋  ๊ฑฐ๋ผ๊ณ  ์˜ˆ์ธก๋˜๋Š” ์ƒํ™ฉ์—๋Š” ๋””์ž์ธ ํŒจํ„ด์„ ์ ์šฉํ•ด์•ผ ํ•œ๋‹ค.

  • ๋””์ž์ธ์—์„œ ๋ณ€๊ฒฝ๋  ์ˆ˜ ์žˆ๋Š” ๋ถ€๋ถ„์ด ์žˆ๋‹ค๋ฉด(๋ฐœ์ƒ ๊ฐ€๋Šฅ์„ฑ์ด ๋†’์€ ์‹ค์งˆ์ ์ธ ๋ณ€๊ฒฝ) ํŒจํ„ด์„ ์ ์šฉํ•  ์—ฌ์ง€๊ฐ€ ์žˆ๋‹ค.

  • ํ•˜์ง€๋งŒ ๋ฐœ์ƒ ๊ฐ€๋Šฅ์„ฑ์ด ๊ทธ๋ฆฌ ๋†’์ง€ ์•Š์€ ๊ฐ€์ƒ์ ์ธ ๋ณ€๊ฒฝ์— ๋Œ€๋น„ํ•ด์„œ ํŒจํ„ด์„ ์ ์šฉํ•˜๋Š” ์ผ์€ ๋ฐ”๋žŒ์งํ•˜์ง€ ์•Š๋‹ค.


๋ฆฌํŒฉํ„ฐ๋ง๊ณผ ํŒจํ„ด

๋ฆฌํŒฉํ„ฐ๋ง์˜ ๋ชฉ์ ์€ ํ–‰๋™ ๋ณ€๊ฒฝ์ด ์•„๋‹ˆ๋ผ ๊ตฌ์กฐ ๊ฐœ์„ ์— ์žˆ๋‹ค.

๋”ฐ๋ผ์„œ ๋ฆฌํŒฉํ„ฐ๋ง์€ ํŒจํ„ด์„ ์‚ฌ์šฉํ•˜๋ฉด ๊ตฌ์กฐ๊ฐ€ ๋” ๊ฐœ์„ ๋  ์ˆ˜ ์žˆ์„์ง€ ๊ฒ€ํ† ํ•ด๋ณผ ์ˆ˜ ์žˆ๋Š” ์•„์ฃผ ์ข‹์€ ๊ธฐํšŒ์ด๋‹ค.


๊ผญ ํ•„์š”ํ•˜์ง€ ์•Š์€ ํŒจํ„ด์€ ๋นผ์ž

์‹œ์Šคํ…œ์ด ์ ์  ๋ณต์žกํ•ด์ง€๋ฉด์„œ ์ฒ˜์Œ์— ๊ธฐ๋Œ€ํ–ˆ๋˜ ์œ ์—ฐ์„ฑ์ด ์ „ํ˜€ ๋ฐœํœ˜๋˜์ง€ ๋ชปํ•œ๋‹ค๋ฉด ํŒจํ„ด์„ ๊ณผ๊ฐํ•˜๊ฒŒ ์ œ๊ฑฐํ•ด ๋ฒ„๋ฆฌ๋Š” ๊ฒƒ์ด ๋‚ซ๋‹ค.

์ฆ‰, ํŒจํ„ด๋ณด๋‹ค ๊ฐ„๋‹จํ•œ ํ•ด๊ฒฐ์ฑ…์ด ๋” ๋‚˜์„ ๊ฒƒ ๊ฐ™๋‹ค ์‹ถ์„ ๋•Œ ํŒจํ„ด์„ ์ œ๊ฑฐํ•˜๋ฉด ๋œ๋‹ค.


๊ผญ ํ•„์š”ํ•˜์ง€ ์•Š์€ ํŒจํ„ด์„ ๋ฏธ๋ฆฌ ์ ์šฉํ•  ํ•„์š”๋Š” ์—†๋‹ค

์ง€๊ธˆ ๋‹น์žฅ ๋ณ€ํ™”์— ๋Œ€์ฒ˜ํ•˜๋Š” ๋””์ž์ธ์„ ๋งŒ๋“ค์–ด์•ผ ํ•œ๋‹ค๋ฉด ํŒจํ„ด์„ ์ ์šฉํ•ด์„œ ๊ทธ ๋ณ€ํ™”์— ์ ์‘ํ•ด์•ผ ํ•˜์ง€๋งŒ,
๊ผญ ํ•„์š”ํ•˜์ง€ ์•Š์€๋ฐ๋„ ๊ดœํžˆ ํŒจํ„ด์„ ์ถ”๊ฐ€ํ•˜๋Š” ์ผ์€ ํ”ผํ•ด์•ผ ํ•œ๋‹ค.

ํŒจํ„ด์„ ์“ฐ๋‹ค ๋ณด๋ฉด ์‹œ์Šคํ…œ์ด ๋” ๋ณต์žกํ•ด์ง€๋Š” ๊ฒฝํ–ฅ์ด ์žˆ์œผ๋ฉฐ, ๋‚˜์ค‘์— ๊ทธ ํŒจํ„ด์„ ์‚ฌ์šฉํ•˜์ง€ ์•Š์„ ์ˆ˜๋„ ์žˆ๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค.



๐Ÿ’ก ํ•ญ์ƒ ๊ฐ€์žฅ ๊ฐ„๋‹จํ•œ ํ•ด๊ฒฐ์ฑ…์œผ๋กœ ๋ชฉ์ ์„ ๋‹ฌ์„ฑํ•  ์ˆ˜ ์žˆ๋„๋ก ํ•˜๊ณ , ๋ฐ˜๋“œ์‹œ ํ•„์š”ํ•  ๋•Œ๋งŒ ๋””์ž์ธ ํŒจํ„ด์„ ์ ์šฉํ•ด์•ผ ํ•œ๋‹ค.



์•ˆํ‹ฐ ํŒจํ„ด(Anti-Pattern)

๐Ÿ’ก ์•ˆํ‹ฐ ํŒจํ„ด์€ ์–ด๋–ค ๋ฌธ์ œ์˜ ๋‚˜์œ ํ•ด๊ฒฐ์ฑ…์— ์ด๋ฅด๋Š” ๊ธธ์„ ์•Œ๋ ค์ค€๋‹ค.


  • ์ผ์ƒ์ ์ธ ๋ฌธ์ œ์˜ ์ž์ฃผ ๋ฐ˜๋ณต๋˜๋Š” ๋‚˜์œ ํ•ด๊ฒฐ์ฑ…์„ ๋ฌธ์„œ๋กœ ๋งŒ๋“ค๋ฉด ๋‹ค๋ฅธ ๊ฐœ๋ฐœ์ž๋“ค์ด ๋˜‘๊ฐ™์€ ์‹ค์ˆ˜๋ฅผ ํ•˜์ง€ ์•Š๋„๋ก ๋ฐฉ์ง€ํ•  ์ˆ˜ ์žˆ๋‹ค.

  • ์š”์†Œ

    • ์–ด๋–ค ์ด์œ ๋กœ ๋‚˜์œ ํ•ด๊ฒฐ์ฑ…์— ์œ ํ˜น๋˜๋Š”๊ฐ€
    • ์žฅ๊ธฐ์ ์ธ ๊ด€์ ์—์„œ ๊ทธ ํ•ด๊ฒฐ์น™์ด ๋‚˜์œ ์ด์œ 
    • ์ข‹์€ ํ•ด๊ฒฐ์ฑ…์„ ๋งŒ๋“ค ๋•Œ ์ ์šฉํ•  ์ˆ˜ ์žˆ๋Š” ๋‹ค๋ฅธ ํŒจํ„ด์— ๋Œ€ํ•œ ์ œ์•ˆ
  • ์ข…๋ฅ˜

    • ๊ฐœ๋ฐœ ์•ˆํ‹ฐ ํŒจํ„ด
    • ๊ฐ์ฒด์ง€ํ–ฅ ์•ˆํ‹ฐ ํŒจํ„ด
    • ์กฐ์ง ์•ˆํ‹ฐ ํŒจํ„ด
    • ํŠน์ • ์˜์—ญ ์•ˆํ‹ฐ ํŒจํ„ด

ํ•ด๋‹น ์‚ฌ์ดํŠธ์—์„œ ๋‹ค์–‘ํ•œ ์•ˆํ‹ฐ ํŒจํ„ด์„ ์ฐพ์•„๋ณผ ์ˆ˜ ์žˆ๋‹ค.





๋””์ž์ธ ํŒจํ„ด ๊ด€๋ จ ์ž๋ฃŒ

ํฌํ‹€๋žœ๋“œ ํŒจํ„ด ๋ ˆํฌ์ง€ํ† ๋ฆฌ(The Portland Patterns Repository)

ํŒจํ„ด๊ณผ ๊ฐ์ฒด์ง€ํ–ฅ ์‹œ์Šคํ…œ์— ๊ด€๋ จ๋œ ๋ชจ๋“  ๊ฒƒ์„ ๋‹ด์€ ์œ„ํ‚ค์ด๋‹ค.