상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - 플러터에서 비동기 프로그래밍은 어떻게 처리하나요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
플러터(Flutter)에서 비동기 프로그래밍은 Dart 언어의 비동기 기능을 활용하여 처리됩니다. Dart는 비동기 프로그래밍을 지원하기 위해 `Future`, `async`, `<a href='https://sangseek.com/sangseeks/await/ko'>await</a>` 키워드를 제공합니다. 이러한 기능을 통해 비동기 작업을 쉽게 관리하고, UI가 블로킹되지 않도록 할 수 있습니다. 아래에서 플러터에서 비동기 프로그래밍을 처리하는 방법에 대해 자세히 설명하겠습니다. 1. Future `Future`는 비동기 작업의 결과를 나타내는 객체입니다. 비동기 작업이 완료되면 `Future`는 결과 값을 반환하거나 오류를 발생시킵니다. `Future`는 두 가지 상태를 가집니다: - 대기 중(pending) : 작업이 아직 완료되지 않은 상태 - 완료(completed) : 작업이 완료되어 결과를 반환하거나 오류가 발생한 상태 예제: ```dart Future<String> fetchData() async { // 비동기 작업을 시뮬레이션하기 위해 2초 대기 await Future.delayed(Duration(seconds: 2)); return '데이터 로드 완료'; } ``` 2. async와 await `async`와 `await` 키워드는 비동기 함수를 작성할 때 사용됩니다. `async` 키워드를 사용하여 함수를 비동기 함수로 선언하고, `await` 키워드를 사용하여 `Future`가 완료될 때까지 기다릴 수 있습니다. 이를 통해 비동기 코드를 동기 코드처럼 읽기 쉽게 작성할 수 있습니다. 예제: ```dart void main() async { print('데이터를 로드하는 중...'); String data = await fetchData(); print(data); } ``` 위의 예제에서 `fetchData()` 함수가 완료될 때까지 기다린 후, 결과를 출력합니다. 3. 비동기 작업 처리 비동기 작업을 처리할 때는 `try-catch` 블록을 사용하여 오류를 처리할 수 있습니다. 이는 네트워크 요청이나 파일 I/O와 같은 작업에서 발생할 수 있는 예외를 안전하게 처리하는 데 유용합니다. 예제: ```dart Future<String> fetchData() async { try { await Future.delayed(Duration(seconds: 2)); // 예외를 발생시킬 수 있는 코드 <a href='https://sangseek.com/sangseeks/throw/ko'>throw</a> Exception('데이터 로드 실패'); } catch (e) { return '오류 발생: $e'; } } void main() async { print('데이터를 로드하는 중...'); String data = await fetchData(); print(data); } ``` 4. Flutter에서 비동기 작업 사용하기 플러터에서는 비동기 작업을 UI와 결합하여 사용할 수 있습니다. 예를 들어, `FutureBuilder` 위젯을 사용하면 비동기 작업의 결과를 UI에 쉽게 반영할 수 있습니다. 예제: ```dart import 'package:flutter/material.dart'; void main() { runApp(MyApp()); } class MyApp extends <a href='https://sangseek.com/sangseeks/StatelessWidget/ko'>StatelessWidget</a> { @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar(title: Text('비동기 프로그래밍 예제')), body: FutureBuilder<String>( future: fetchData(), builder: (context, snapshot) { if (snapshot.connectionState == ConnectionState.waiting) { return Center(child: CircularProgressIndicator()); } else if (snapshot.hasError) { return Center(child: Text('오류: ${snapshot.error}')); } else { return Center(child: Text('결과: ${snapshot.data}')); } }, ), ), ); } Future<String> fetchData() async { await Future.delayed(Duration(seconds: 2)); return '데이터 로드 완료'; } } ``` 위의 예제에서 `FutureBuilder`는 `fetchData()` 함수의 결과를 기다리고, 그 상태에 따라 로딩 인디케이터, 오류 메시지 또는 결과를 표시합니다. 5. 결론 플러터에서 비동기 프로그래밍은 Dart의 `Future`, `async`, `await` 키워드를 통해 간편하게 처리할 수 있습니다. 이러한 기능을 활용하면 비동기 작업을 쉽게 관리하고, 사용자 경험을 향상시킬 수 있습니다. 비동기 프로그래밍을 적절히 활용하여 네트워크 요청, 데이터베이스 작업 등 다양한 비동기 작업을 효율적으로 처리할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기