반응형
Cocoa Design Pattern - Delegate 델리게이트 패턴
Delegate 패턴이란
- 객체 간의 커뮤니케이션을 돕는 디자인 패턴 중 하나이다.
- 주로 객체 A가 객체 B에게 어떤 이벤트나 작업이 발생했을 때, 객체 B가 이에 대한 처리를 하도록 위임하는 메커니즘을 제공한다.
- 이 패턴을 사용하면 두객체간 의존성을 느슨해지고 유연하게 만든다.
Delegate패턴의 주요 컴포넌트
- Delegate Protocol (A에 구현)
- 객체 A는 어떤 이벤트나 작업에 대한 처리를 위임받는 객체 B가 지켜야 할 규칙을 정의한다.
- Delegate Property (A에 구현)
- 객체 A는 객체 B가 자신의 delegate 역할을 수행할 수 있도록 대리자 프로퍼티를 생성한다.
- 대개 이 프로퍼티는 약한 참조(weak reference)로 선언되어 순환 참조 문제를 방지한다.
- 객체 B가 객체 A의 delegate를 self로 선언 : 이제
객체 A의 Delegate = 객체 B
가 된다.
- 객체 A는 객체 B가 자신의 delegate 역할을 수행할 수 있도록 대리자 프로퍼티를 생성한다.
- Delegate Methods
- 객체 B에서는 약속된 프로토콜 메소드를 구현한다.
- 객체 A는 원하는 순간에 delegate 프로퍼티에 할당된 객체 B의 프로토콜 메서드를 호출하여 B가 처리하도록 한다.
Delegate패턴 예시(1) : Class with ViewController
- ViewController에 구현한 Cless에 있어 ViewController가 대신 함수를 가지고 있는 경우이다.
- 해당 함수는 ViewController의 ViewDidLoad 안에서
MyClass()
객체의 함수를 시작하게 되어있다. - 만약 자동으로 하는 것이 아니라 터치를 통해 Class 내부에서 동작을 하게 할 거라면 발동조건을 아래처럼 ViewDidLoad에 넣지 않아도된다.
1. Delegate 프로토콜 만들기
프로토콜을 만드는 것은 이 프로토콜을 채택한다면 구현해야하는 필수 조건을 만드는 과정이다.
protocol MyDelegate {
func didReceiveData(data: String)
}
2. Delegate 프로토콜을 채택하는 클래스 만들기
class MyClass {
var delegate: MyDelegate?
func sendData() {
delegate?.didReceiveData(data: "Hello, World!")
}
}
3. Delegate 객체 만들기
class ViewController: UIViewController, MyDelegate {
let myObject = MyClass()
override func viewDidLoad() {
super.viewDidLoad()
myObject.delegate = self
myObject.sendData()
}
func didReceiveData(data: String) {
print(data)
}
}
여기까지만 해도되는데 아래처럼 연결하는 경우가 있다.
4. Delegate 객체와 MyClass 인스턴스 연결하기
let myObject = MyClass()
let myDelegateObject = MyDelegateObject()
myObject.delegate = myDelegateObject
myObject.sendData() // "Hello, World!" 출력
Delegate패턴 예시(2) : VC with VC
화면이동간 init 시점에 데이터를 보낼 수 있어 자주 사용하는 방법이다.
1. Delegate 프로토콜 만들기
프로토콜을 만드는 것은 이 프로토콜을 채택한다면 구현해야하는 필수 조건을 만드는 과정이다.
protocol MyDelegate {
func doSomething()
}
2. Delegate 프로토콜을 채택하는 A ViewController 만들기
class AViewController: UIViewController, MyDelegate {
func doSomething() {
print("AViewController에서 수행된 doSomething 함수")
}
}
3. A VC 와 B VC 를 연결하고 A VC 입장에서 delegate를 self로 지정해준다.
class AViewController: UIViewController, MyDelegate {
override func viewDidLoad() {
super.viewDidLoad()
let bViewController = BViewController()
bViewController.delegate = self
self.navigationController?.pushViewController(bViewController, animated: true)
}
func doSomething() {
print("AViewController에서 수행된 doSomething 함수")
}
}
4. Delegate를 위임할 B ViewController 구현하기
class BViewController: UIViewController {
var delegate: MyDelegate?
override func viewDidLoad() {
super.viewDidLoad()
delegate?.doSomething()
}
}
반응형
'모바일앱 > 알려줘_IOS' 카테고리의 다른 글
View뜯어보기 (1) (0) | 2022.03.15 |
---|---|
swift - Boolean (0) | 2022.02.10 |
swift - 튜플 (0) | 2022.02.08 |
Swift - 코멘트 처리하기 (0) | 2022.02.07 |
Xcode 세팅하기 (0) | 2022.02.06 |
알려줘_IOS 시리즈 서문 (0) | 2022.02.05 |