• 북마크
  • 추가메뉴
어디로 앱에서 쉽고 간편하게!
애플 중고 거래 전문 플랫폼
오늘 하루 보지 않기
KMUG 케이머그

소프트웨어

[App 개발] Cocoa Design Patterns (5)

본문

Commands
GOF의 패턴에 익숙하신 분들은 아마 타겟/액션이 마치 커맨드 패턴의 구현이라고 생각될 것입니다. 그러나 커맨드 패턴같은 것이 타겟/액션과 같은 구현이 이용된다 하더라도 Objective-C에서는 그것이 필요가 없습니다. 커맨드 패턴은 정적인 객체 지향 언어에 결여되어 있는 동적인 요소들을 만들어내기 위하여 더 많이 사용됩니다. 정적인 언어에서는 한 번도 본 적이 없는 객체의 메세지 전달은 일반적으로는 불가능합니다. 이것을 구현하기 위해서는 여러분은 invoke와 같은 가상 메쏘드를 구현하고 있는 커맨드라고 하는 추상적 슈퍼클래스를 만들어야 합니다. 그리고 전달하고자 하는 모든 메쏘드들을 위한 서브클래스를 만들어 줍니다. 마지막으로, 전달자는 커맨드 서브클래스의 어떤 인스턴스를 가지고 메세지를 전달하기 위하여 그 객체에 있는 invoke를 호출합니다. 이렇게 함으로써 전달자 클래스가 컴파일된 상태에서 보내어지는 메세지가 어떤 것인지는 몰라도 전달자 객체가 다른 객체에게 메세지를 전달할 수 있습니다.

왜냐하면 Objective-C는 아주 동적인 언어이기 때문에 어떤 메세지를 전달하기 위하여 위의 모든 과정을 거쳐야 할 필요가 없습니다. 그 대신 전달하는 객체에게 셀렉터가 전달되어 어떠한 메세지를 전달할 것인지를 결정하게 됩니다. 그러면 전달자는 -performSelector: 메쏘드나 필요한 경우 -performSelector:withObject와 같은 변형 메쏘드를 메세지를 발생시키기 위하여 사용합니다.

셀렉터는 전달될 메세지를 결정할 뿐 메세지를 수신하지는 않습니다. 어떤 경우에는 필요하기도 하지만 언제나 그렇지는 않습니다. 만약 여러분이 메세지와 수신기를 한 객체 안에 갖기를 원한다면 NSInvocation을 사용할 수 있습니다. NSInvocation은 메세지, 수신기, 그리고 메세지에 필요한 인수들을 포함하고 있습니다. NSInvocation 클래스가 코코아에서 GOF의 Command 패턴과 가장 가까운 클래스입니다.


Delegates
새로 코코아 개발자가 되신 분들이 하는 가장 초보적인 실수는 불필요한 코코아 객체의 서브클래스를 만드는 것입니다. 일반적으로 객체의 동작을 바꾸려고 하는 목적으로 서브클래스를 만듭니다. 다른 대부분 객체지향 응용 프로그램 프레임웍에서는 서브클래스가 클래스의 동작을 변경시키는 유일한 방법입니다. 그러나 코코아에서는 서브클래스 기법을 대신하여 위임(delegation)이라는 개념을 도입했습니다. GOF 패턴 중에서는 위임 개념을 정확히 설명하는 것은 없습니다. 위임이라는 것은 옵저버와 GOF 의 Chain of Responsibility 패턴의 혼합이라고 할 수 있습니다.

위임은 프레임웍 개발자가 설계시 선택해야 할 일을 잠시 미루어둘 수 있는 한 가지 방법입니다. 오로지 한 가지 방법으로 모든 것을 다 처리하는 대신 많은 코코아 클래스들은 특정한 상황에서 다른 객체에게 어떤 작업을 할 수 있도록 만들 수 있습니다.

예를 들어, 사용자가 윈도우 타이틀 바에 있는 닫기 버튼을 눌렀을 때의 기본적인 행동은 윈도우를 단는 일입니다. 그러나 만일 윈도우에 변경된 문서가 있어서 응용 프로그램이 윈도우를 닫기 전에 변경된 사항을 저장해야 할지를 사용자에게 묻는 기능을 만들어야 한다면 어떻게 할까요? 코코아에서는 윈도우는 다른 객체에게 "지금 닫을 건데, 괜찮냐?"고 물어보게 됩니다. 객체는 아마 화면에 문서를 저장할 것인지 윈도우 닫기를 취소할 것인지를 선택하는 상자가 열려서 사용자의 의향을 묻고 난 다음 yes나 no로 대답하게 될 것입니다. 윈도우의 동작을 변경하기 위해서 서브클래스를 만들어야 할 필요는 없습니다. 그 대신 응용 프로그램이나 컨텍스트 고유의 방법으로 질문에 대답할 수 있도록 만들어진 다른 객체가 제공됩니다.

이 결정에 참여하게 되는 다른 객체가 바로 대리인(delegate)입니다. 객체로부터 대리인에게 전달되는 메세지들이 대리인 메세지입니다. 대리인에게 메세지를 보내는 객체에는 적당한 용어가 없기 때문에 이 책에서는 이러한 객체를 구별하기 위하여 위임자(delegator)라는 이름으로 쓰겠습니다. 일반적으로 위임자 클래스의 문서와 헤더에는 대리인에게 전달될 수 있는 메세지들에 대해서 기술되어 있습니다.

NSApplication, NSWindow, NSTableView, NSToolBar와 같은 대부분의 복잡한 응용 프로그램 킷 클래스들 은 모두 위임자입니다.

대리인에게 전달되는 어떤 메세지들은 대리인으로부터의 회신이 필요하지 않고 어떤 이벤트가 실행되기 전후에 어떤 작업을 대리인으로 하여금 수행하도록 합니다. 예를 들어, 대리인은 윈도우가 화면에 놓여지기 바로 직전이나 직후에 메세지를 받을 수 있습니다. 이렇게 해서 대리인은 적당한 시간에 특별한 초기화나 다른 작업을 수행할 수 있는 기회를 가지게 됩니다.

대리인은 모든 대리인 메세지를 구현해야 할 필요는 없습니다. 단지 필요한 메세지만을 구현하면 됩니다. 위임자는 특정 메세지를 보내기 전에 대리인이 메세지에 반응하는지를 항상 확인해야 합니다. 그 메세지에 대리인이 반응하지 않으면 보내지 않으면 됩니다.

Note
메세지를 보내기 전에 대리인이 메세지에 반응하는지를 검사하는 것은 자칫 비효율적으로 보일 것입니다. 그러나 코코아의 실제 구현은 꽤 영리하게 되어 있습니다. 대리인이 설정되었을 때 코코아는 대리인이 처리할 수 있는 메세지를 확인하고 대리인 메세지를 보낼 때 사용하기 위하여 캐시에 저장하게 됩니다.

대리인의 한 가지 제한사항은 어떤 특정한 대리인 메세지들만이 위임자에게 알려져 있다는 사실입니다. 만약 위임자를 만드는 사람이 여러분이 받거나 전달하고자 하는 어떤 메세지에 대하여 대리인 메세지가 보내어지지 않는다면 대리인은 동작하지 않을 것입니다. 그런 경우에는 객체의 서브클래스만이 유일한 해결방법일 것입니다. 다행스럽게도 코코아에서 서브클래스가 필요한 경우는 많지 않습니다. 이미 존재하고 있는 대리자 메세지는 여러분이 원하는 거의 대부분의 기능을 포함할 수 있을 만큼 풍부하게 제공되어 있습니다.

대리인의 또 다른 제한점은 객체는 일반적으로 단 하나의 대리인만을 가진다는 점입니다. 거기에는 다른 방법이 없습니다. 예를 들어, NSApplication 인스턴스는 여러 개의 대리인을 가져야 합니다. 만약 하나의 위임자로부터 여러 개의 대리인들이 메세지를 받게 하려면 대리인이 메세지를 다른 대리인에게 전달하도록 만들어 줍니다.

"윈도우를 닫을까요?" 같은 응답이 필요한 메세지의 경우 그 메세지를 다른 객체로 포워딩하는 것이 유일한 방법입니다. 한편 다른 대리인들이 이벤트에 대한 통지만을 요구할 경우에는 Notification 패턴이 다중 대리인 문제를 해결하는 방법으로 사용될 수 있습니다.
0 0
로그인 후 추천 또는 비추천하실 수 있습니다.
포인트 228,692
가입일 :
2003-02-18 14:12:30
서명 :
미입력
자기소개 :
미입력

최신글이 없습니다.

최신글이 없습니다.

댓글목록 0

등록된 댓글이 없습니다.
전체 121 건 - 3 페이지
2004.01
25

[App 개발] CoreGraphics의 풀스크린 화면 만들기

박진철님께서 올리셨던 질문 중에 코코아에서 퀵드로우의 CopyBits대신 사용할 수 있는 방법으로서 아시는 분들은 다 아실만한 CGDirectDisplay 를 이용한 방법을 한 번 시도해 보았습니다. 프로그램은 심히 완성도가 떨어지는 관계로 감히…

2004.01
23

열람중 [App 개발] Cocoa Design Patterns (5)

Commands GOF의 패턴에 익숙하신 분들은 아마 타겟/액션이 마치 커맨드 패턴의 구현이라고 생각될 것입니다. 그러나 커맨드 패턴같은 것이 타겟/액션과 같은 구현이 이용된다 하더라도 Objective-C에서는 그것이 필요가 없습니다. 커맨드 패턴…

2004.01
22

[App 개발] Cocoa Design Patterns (4)

Enumeration 코코아의 모든 콜랙션 클래스는 계수기를 제공합니다. 이 패턴은 GOF의 반복기 패턴과 비슷합니다. 계수기는 객체의 집합을 훑어내고 각 객체에 어떤 일을 수행하는 방법을 제공합니다. 특정한 집합에 대하여 특수한 루프를 짜 주는 대…

2004.01
22

[App 개발] NeHe Lesson 16

이번 강의는 Chris Aliotta가 제작하였습니다. 당신의 OpenGL 프로그램에 안개를 넣고 싶으십니까 이번 강의에서 바로 그 방법을 보여드리려고 합니다. 저는 강의를 쓰는 것은 처음이고, OpenGL/C++ 프로그래밍은 근래에 시작한 것이…

2004.01
18

[App 개발] Cocoa Design Patterns (3)

평일은 바쁘니까 아무래도 주말에 열심히 진도를 나가는 것이 좋겠지요 번역이 많이 서툴러서 읽으시기에 불편하실지 모르겠습니다. 죄송합니다. ***** Class Clusters 클래스 클러스터는 복잡한 상속 구조를 숨기는 방법입니다. 기본적…

2004.01
18

[App 개발] NeHe Lesson 13

바로 뒤에 이어지는 두 개의 폰트 강의는 그냥 건너뛰려고 합니다. 윈도우 전용 코드 설명에 많은 부분이 할애되는 것도 그렇고, agl 함수 래퍼런스도 저에게 부족해서 (그리고 제 실력도 부족해서... 하하...) 일단은 이정도 선에서 폰트는 접도록 하…

2004.01
17

[App 개발] Cocoa Design Patterns (2)

Model-View-Controller 모델-뷰-컨트롤러, 줄여서 MVC 패턴은 패턴 이상의 구조물이라고 간주됩니다. 왜냐하면 이것은 응용 프로그램을 정리하는 기본적인 방법이며 모든 패턴들을 아우르는 상위의 구조적인 요소이기 때문입니다. 왜냐하면…

2004.01
17

[App 개발] Cocoa Design Patterns (1)

코코아를 배울 때, 코코아가 사용하는 용어 때문에 어려움을 겪으시는 분이 많으실 것입니다. 그 중에서도 코코아 설계에 응용된 디자인 패턴의 개념이 익숙하지 않아서 더 힘들게 느껴지시는 분들이 계실 줄 압니다. 제가 갖고 있는 책 Cocoa Progra…

2004.01
15

[App 개발] Nehe Lesson 12

이번 강의에서는 출력 리스트를 이용하는 법을 배우겠습니다. 단순히 리스트를 만들어 빠르게 하는 것 뿐만 아니라 간단한 GL 씬을 만들어야 할 때 몇 줄로 나누어 따로 사용할 수 있습니다. 예를 들어서 각 판을 두 개의 운석으로부터 시작하는 ast…

2004.01
13

[App 개발] NeHe Lesson 11

대충 소스를 돌아가게끔만 만들어서 캡춰해서 게재를 하다보니 혹시라도 소스코드상에 오류나 옛날 루틴의 찌꺼기등이 많이 끼어있을지도 모릅니다. ^^; 너그럽게 봐 주시고, 어쨌든 빨랑빨랑 진도를 나가는 방향으로 해 보겠습니다. 목표는 3D 게임 엔진 …

2004.01
10

[App 개발] NeHe Lesson 10

이 예제는 Lionel Brits가 만들었습니다. 여기서는 코드의 어떤 부분이 추가되었는지만 설명하고 있기 때문에 이 글에서 소개하는 코드만 가지고는 프로그램이 동작하지 않을 것입니다. 만약에 어떤 부분에 어떻게 코드가 첨가되었는지 알고 싶으시면 소스…

2004.01
09

[App 개발] NeHe Lesson 9

9번 강좌까지 오신 여러분 수고가 많습니다. 본 코스는… 쿨럭~ ㅡㅡ; 지금까지의 공부를 통해서 OpenGL윈도우를 여는 것부터 시작해서 광원과 투명처리를 한 텍스쳐 물체를 회전시키는 것까지, OpenGL에 대하여 많은 이해가 있으셨을 것입니다. 이번…

2004.01
08

[App 개발] NeHe Lesson 8

투명 OpenGL의 많은 특수 효과들은 블렌딩 기능을 이용합니다. 블렌딩이란 기존에 그려져 있는 픽셀과 새로 그리는 픽셀의 색상을 섞는 일입니다. 어떻게 색상을 섞는가는 색상의 alpha값과 블렌딩 함수에 따라 달라집니다. alpha값이란 색상을…

2004.01
07

[App 개발] NeHe Lesson 7

원문이 윈도우 소스를 기준으로 서술되어 있어서 많은 부분이 바뀌어 있습니다. 특히 키보드 입력 부분은 제가 따로 첨부하는 소스를 참조하시는 것이 더 나을 것입니다. (사실 소스를 잘 만들진 못했습니다. 대충 돌아가게만... ^^;;;) 그래도 없는 것…

2004.01
06

[App 개발] Carbon과 Cocoa중에서 어떤 것을 선택할까?

저는 C/C++ 프로그래머입니다. 옛날 터보씨 시절부터 C를 썼기 때문에 사실 이것을 고치기가 쉽지 않습니다. 자바 프로그래밍은 밥먹고 사는 문제 때문에 프로젝트를 하면서 배우게 되었습니다. 처음에는 C++의 개념을 갖고 접근하는 바람에 많이 헤매었는…

2004.01
05

[App 개발] NeHe Lesson 6

텍스쳐 매핑을 배우면 여러가지 잇점이 있습니다. 만약 화면을 가로질러 날아가는 미사일을 표현한다고 합시다. 지금까지 배운 것을 토대로 하자면 미사일 전체를 형형색색의 다각형을 모아서 만들어야만 합니다. 텍스쳐 매핑을 사용한다면 진짜 미사일 사진 한 장…

2004.01
04

[App 개발] NeHe Lesson 5

오늘은 지난 시간의 프로그램을 확장하여 3차원 공간에 2차원 물체 대신 3차원 물체를 만들어 보도록 하겠습니다. 삼각형 의 왼쪽, 오른쪽, 뒤쪽 면을 덧붙이고, 사각형에는 왼쪽, 오른쪽, 뒷면, 밑면을 덧붙일 것입니다. 그리고 나면 삼각형은 피라밋 모…

2003.12
30

[App 개발] NeHe Lesson 4

지난시간에는 삼각형과 사각형에 색상을 입히는 것을 배웠습니다. 오늘은 이 도형들을 축을 기준으로 회전하도록 만들겠습니다. 지난 시간에 썼던 코드에 몇 가지만 추가하면 됩니다. 밑에는 전체 코드를 기록할 것이기 때문에 어떤 부분이 추가되었고 어떤 부분…

2003.12
28

[App 개발] NeHe Lesson 3

지난 시간에는 삼각형과 사각형을 화면에 출력하는 것을 배웠습니다. 오늘은 도형에 색상을 입하는 두 가지 방법에 대해서 배울 것입니다. Flat Coloring으로 사각형을 단색으로 칠할 것이고, Smooth Coloring으로 삼각형의 꼭지점에 각각 …

2003.12
27

[App 개발] NeHe Lesson 2

원래는 Lesson 1부터 해야 하는데, 이미 살펴보신 분은 아시겠습니다만, 윈도우 여는 방법 설명이 반 이상입니다. MUG 게시판에 디바이스 컨텍스트가 어쩌고 저쩌고 설명하고 있으면 짜증나시겠죠 ^^; 빠진 부분은 나중에 다루어질 것으로 믿고, Le…

2003.12
26

[App 개발] NeHe Tutorial 따라가기 (0)

OpenGL 사이트 중에서 꽤 명성이 있는 NeHe 프로젝트의 튜토리얼을 따라가 보려고 합니다. 저는 지금까지 Win32와 DirectX 프로그래밍을 주로 해 왔고, 따라서 매킨토시의 Xcode도 처음이고, OpenGL도 처음입니다. 저 혼자 공부하는…