Combine에서 게시자와 구독자는 데이터 스트림을 구축하는 초석입니다. 이들은 함께 작동하여 애플리케이션에서 비동기 데이터 흐름을 효율적으로 처리합니다. 다음은 이들의 역할에 대한 세부 정보입니다.
발행자:
- 수도꼭지를 상상해보세요. 게시자는 수도꼭지에서 물이 뿜어져 나오는 것처럼 데이터 스트림의 소스 역할을 합니다 .
- 값 방출: 시간 경과에 따라 값(데이터 또는 이벤트)을 생성합니다. 이러한 값은 문자열, 정수 또는 사용자 정의 객체 와 같이 모든 유형일 수 있습니다 .
- 구독 모델: 퍼블리셔는 강제로 데이터를 공급하지 않습니다. 구독자는 퍼블리셔와 연결(구독)을 설정하여 방출된 요소를 수신해야 합니다.
- 수명 주기: 퍼블리셔의 수명 주기는 다음과 같습니다.
구독자:
- 컵을 생각해 보세요. 구독자는 게시자가 내보내는 데이터 스트림을 받는 컵과 같은 역할을 합니다.
- 데이터 소비: 구독자의 주요 목적은 게시자가 방출한 값을 소비하는 것입니다.
- 구현: 구독자는 수신된 요소와 완료 신호를 처리하기 위한 방법을 정의하는 Subscriber프로토콜을 구현합니다.
- 클로저: 일반적으로 구독자는 수신된 데이터를 처리 하고( ) 완료를 처리하는 것과 같은 메서드 내에서 클로저를 정의합니다 .sinkreceiveValuereceiveCompletion
비유: 물줄기
수도꼭지(발행자)에서 흐르는 물 흐름(데이터 흐름)을 상상해 보세요. 여러 개의 컵(구독자)을 흐름 아래에 두어 물(데이터)을 모을 수 있습니다. 각 컵은 목적에 따라 유입되는 물(데이터)을 독립적으로 처리할 수 있습니다.
Publisher-Subscriber 모델의 이점:
- 분리: 데이터 생성(게시자)과 데이터 소비(구독자)를 분리하여 모듈성과 재사용성을 촉진합니다.
- 유연성: 게시자는 다양한 데이터 소스를 처리할 수 있으며, 구독자는 다양한 방법으로 데이터를 처리할 수 있습니다.
- 오류 처리: 오류는 구독자가 적절히 처리할 수 있도록 스트림을 통해 전파될 수 있습니다.
- 동시성: Combine은 동시성 기능과 잘 통합되어 비동기 데이터 처리가 가능합니다.
예: 온도 센서
- 게시자: 온도 센서는 시간 경과에 따른 온도 판독값(값)을 내보내는 게시자로 모델링될 수 있습니다.
- 구독자: 온도를 표시하는 앱은 이러한 판독값을 수신하고 그에 따라 UI를 업데이트하는 구독자가 될 수 있습니다.
기본적으로 게시자와 구독자는 Combine에서 강력한 듀오를 형성하여 데이터 변경에 효과적으로 대응할 수 있는 반응형이고 효율적인 애플리케이션을 만들 수 있습니다.
Combine 예제:
이 예에서는 Combine에서 퍼블리셔와 구독자를 결합하여 센서 데이터를 처리하는 방법을 보여드리겠습니다. 온도 판독값을 내보내는 센서가 있는 시나리오를 생각해 보세요. 앱의 레이블에 이러한 판독값을 표시하려고 합니다.
1. 온도 센서 게시자 정의:
import Combine
// Create a publisher that emits temperature readings
let sensorPublisher = PassthroughSubject<Double, Never>()
다음은 구독 후 방출되는 값을 전달하는 일종의 퍼블리셔 입니다 . sensorPublisherPassthroughSubject
2. 온도를 표시하는 구독자 만들기:
// Define a subscriber that updates a label with the received temperature
let temperatureLabel = UILabel()
let temperatureSubscriber = Subscribers.Sink<Double, Never> { _ in
// handle completion
} receiveValue: { value in
temperatureLabel.text = "Current Temperature: \(value)°C"
}
구독자는 수신된 온도 값으로 업데이트하는 클로저를 정의합니다 .temperatureLabel
3. Publisher와 Subscriber 연결:
// Connect the publisher to the subscriber
sensorPublisher.sink(receiveCompletion: temperatureSubscriber.receiveCompletion, receiveValue: temperatureSubscriber.receiveValue)
이 선은 를 에 연결하여 데이터 sensorPublisher흐름 을 설정합니다.temperatureSubscriber
4. 센서 데이터 시뮬레이션:
// Simulate sensor data emission (replace with actual sensor data)
DispatchQueue.global().async {
for value in stride(from: 20.0, to: 30.0, by: 0.5) {
sensorPublisher.send(value)
Thread.sleep(forTimeInterval: 1) // Simulate time delay
}
sensorPublisher.send(completion: .finished) // Signal completion
}
이 코드는 지연과 함께 온도 값을 전송하고 완료 신호를 보내서 센서 데이터 방출을 시뮬레이션합니다.
코드 실행:
이 코드를 실행하면 시뮬레이션된 온도 판독값이 표시되기 시작 temperatureLabel하며, 게시자에서 새로운 값이 방출되면 업데이트됩니다.
키 포인트:
- 이 예제는 Combine에서 게시자와 구독자를 연결하는 기본 개념을 보여줍니다.
- 시뮬레이션된 데이터를 하드웨어의 실제 센서 데이터로 바꿀 수 있습니다.
- Combine은 보다 복잡한 데이터 처리 및 오류 처리를 위한 다양한 연산자와 메커니즘을 제공합니다.
이는 단순화된 예이며, 이를 확장하여 오류 처리, 사용자 상호작용, Combine 연산자를 사용한 보다 정교한 데이터 처리와 같은 실제 시나리오를 처리할 수 있습니다 .
'개발' 카테고리의 다른 글
Combine Publisher - Future (1) | 2024.07.08 |
---|---|
Combine Publisher - Just (0) | 2024.07.08 |
Combine Publishers (0) | 2024.07.08 |
Combine Publisher (0) | 2024.07.08 |
Combine을 사용한 이벤트 수신 및 처리 (0) | 2024.07.08 |