[Flutter]
[Flutter] Bloc Concurrency 라이브러리에 대해서 알아보자
민프야
2023. 10. 20. 15:55
이번 포스팅은 Flutter Bloc의 비동기 이벤트 처리방식에 도움을 주는 Bloc Concurrency 라이브러리에 대해서 알아보겠습니다.
소개
Bloc Concurrency
공식홈페이지 설명에 따르면
bloc_concurrency 패키지는 ember concurrency에서 영감을 받아 만들어진
사용자 정의 이벤트 변환기를 제공하는 Dart 패키지입니다.
이 패키지는 bloc 상태 관리 패키지와 함께 사용되도록 설계되었습니다.
bloc_concurrency는 bloc에서 이벤트를 처리하는 방식을 관리하는 데 도움이 되는 이벤트 변환기를 제공합니다.
ember concurrency에서 영감을 받았다고 하는데 ember concurrency는 무엇일까요?
ember concurrency는 쉽게 말해 비동기처리를 보다 쉽게 간결하게 만들어주는 라이브러리 입니다.
ember.js는 Angular, Vue.js, React와 같은 웹 프레임워크 인데,
웹에서 사용되는 기술을 Flutter Bloc에도 적용된 것이 bloc_concurrency입니다.
그럼 Bloc의 기본 비동기 이벤트 처리방식에 대해서 알아보겠습니다 .
포함된 이벤트 변환기
- concurrent - 이벤트를 동시에 처리할 수 있게 해줍니다.
- sequential - 이벤트를 받은 순서대로 차례대로 처리하도록 보장합니다.
- droppable - 이벤트가 처리되는 동안 추가된 이벤트를 무시합니다.
- restartable - 가장 최근의 이벤트만 처리하고 이전의 진행 중인 이벤트 핸들러를 취소합니다.
공식 홈페이지에 따르면 4가지의 이벤트 변환기 세트를 제공한다고 합니다.
상황을 만들어서 하나씩 설명해보겠습니다.
상황 : 이미지 생성 버튼을 마구 눌렀을 경우
- concurrent - 이벤트가 동시에 처리되어 처리가 되는 순서대로 이미지 생성이 될 것 입니다.
- sequential - 버튼을 누른 순서대로 차례대로 이미지가 생성될 것 입니다.
- droppable - 처음 이미지가 생성 동안 추가된 이미지 생성 이벤트는 무시합니다.
- restartable - 가장 마지막에 누른 이미지 생성 이벤트만 처리하고 이전의 진행 중인 이미지 생성 이벤트들은 취소합니다.
예시 코드는 아래와 같습니다.
import 'package:bloc/bloc.dart';
import 'package:bloc_concurrency/bloc_concurrency.dart';
sealed class CounterEvent {}
final class CounterIncrementPressed extends CounterEvent {}
class CounterBloc extends Bloc<CounterEvent, int> {
CounterBloc() : super(0) {
on<CounterIncrementPressed>(
(event, emit) async {
await Future.delayed(Duration(seconds: 1));
emit(state + 1);
},
/// Specify a custom event transformer from `package:bloc_concurrency`
/// in this case events will be processed sequentially.
transformer: sequential(),
);
}
}
참고링크