Files
2nd/10_Wiki/Topics/_Archive_Orphans/Flutter.md
T

4.8 KiB

category, tags, title, description, last_updated
category tags title description last_updated
Frontend
auto-wikified
technical-documentation
frontend
Flutter Flutter는 구글이 2017년에 출시한 오픈 소스 UI 소프트웨어 개발 키트로, 단일 코드베이스를 통해 모바일, 웹, 데스크톱 등 다양한 플랫폼의 애플리케이션을 구축할 수 있게 해주는 프레임워크이다 [1, 2]. 2026-05-04

Flutter

📌 Brief Summary

Flutter는 구글이 2017년에 출시한 오픈 소스 UI 소프트웨어 개발 키트로, 단일 코드베이스를 통해 모바일, 웹, 데스크톱 등 다양한 플랫폼의 애플리케이션을 구축할 수 있게 해주는 프레임워크이다 [1, 2]. Dart 프로그래밍 언어를 기반으로 하며, 호스트 운영체제의 네이티브 UI 컴포넌트를 호출하는 대신 프레임워크 자체 렌더링 엔진(Skia 또는 Impeller)을 사용하여 화면의 모든 픽셀을 직접 그리는 방식을 취한다 [3-6]. 이를 통해 개발자는 플랫폼에 구애받지 않고 '픽셀 퍼펙트(Pixel-perfect)'한 일관된 사용자 인터페이스와 높은 성능을 제공할 수 있다 [4, 7].

📖 Core Content

  • 자체 렌더링 엔진과 아키텍처 혁신: Flutter는 모든 UI를 위젯(Widget)으로 구성하며, 네이티브 구성 요소를 사용하지 않고 자체 그래픽 엔진을 통해 UI를 렌더링한다 [4, 5, 8]. 기존 Skia 엔진의 한계였던 셰이더 컴파일 지연(Jank) 문제를 해결하기 위해 Impeller 렌더링 엔진을 도입하였으며, 빌드 시점에 셰이더를 미리 컴파일함으로써 일관된 60fps 이상의 부드러운 성능을 보장한다 [9-11].
  • Dart 언어와 컴파일 최적화: Flutter는 Dart 언어를 사용하여 JIT(Just-in-Time) 및 AOT(Ahead-of-Time) 컴파일을 모두 지원한다 [5]. 개발 중에는 JIT를 통한 **'핫 리로드(Hot Reload)'**로 상태를 유지하면서 1초 이내에 빠른 피드백을 제공하고, 프로덕션에서는 AOT를 통해 네이티브 ARM 코드로 컴파일되어 빠른 시작 시간과 고성능을 자랑한다 [5, 12-14]. Dart 3의 도입으로 사운드 널 안정성(Sound null safety), 패턴 매칭, 레코드 등의 기능이 추가되어 코드베이스가 더욱 견고해졌다 [11].
  • 실전 상태 관리 패턴: 규모에 따라 다양한 아키텍처 패턴이 적용된다. 대규모 엔터프라이즈 프로젝트에서는 엄격한 관심사 분리를 요구하는 스트림(Stream) 기반의 이벤트 중심 상태 관리 방식인 'BLoC (Business Logic Component)' 패턴이 테스트 용이성 덕분에 선호된다 [15]. 중소규모 프로젝트에서는 유연한 의존성 주입을 돕는 **'Provider'**나, 이를 개선하여 MVVM 아키텍처와의 결합도가 높은 현대적 반응형 패턴인 **'Riverpod'**이 폭넓게 활용된다 [15].
  • AI 및 머신러닝 생태계 통합: 구글의 에코시스템과 긴밀하게 통합되어 있어, Firebase AI Logic을 통한 Gemini 모델 접근이나 기기 내 직접 추론을 위한 TensorFlow Lite를 Flutter 애플리케이션에 매끄럽게 적용할 수 있다 [16, 17].

⚖️ Trade-offs & Caveats

  • 플랫폼 네이티브 컴포넌트의 부재: Flutter는 실제 플랫폼 네이티브 UI 요소(예: iOS의 UIKit)를 사용하지 않고 이를 시각적으로 모방한다 [4, 18]. 이로 인해 새로운 OS 버전에서 UI 패러다임이 바뀔 경우 커뮤니티가 이를 복제할 때까지 기다려야 하며, 스크롤 물리 효과나 접근성(Accessibility) 의미 체계 등에서 네이티브 표준과 미묘한 차이가 발생할 수 있다 [4, 18-20].
  • 앱 용량 증가: Dart 런타임과 그래픽 렌더링 엔진(Impeller 등)을 애플리케이션 내에 자체적으로 포함하여 배포해야 하므로, React Native에 비해 기본적인 앱의 파일 크기(최소 8~12MB 수준)가 상대적으로 더 크며 기기 메모리 점유율도 약간 더 높다 [13, 21].
  • 학습 곡선과 인재 확보의 한계: 세계적으로 널리 쓰이는 JavaScript/TypeScript를 사용하는 React Native와 달리, 상대적으로 생태계가 작은 Dart 언어를 별도로 학습해야 한다 [22-24]. 이로 인해 전문 개발자 풀이 좁아 팀을 확장하거나 인재를 채용하는 데 더 많은 시간과 비용(프리미엄 인건비, 교육 비용 등)이 소요될 수 있다 [22, 24, 25].
  • 서드파티 라이브러리 및 3D 제약: 모바일 생태계에서 특정 네이티브 모듈이나 서드파티 라이브러리 지원이 JavaScript 생태계보다 성숙하지 않을 수 있어 일부 기능을 처음부터 직접 개발해야 할 수 있다 [26]. 또한 고도의 3D 애니메이션이나 컴포넌트 렌더링에 있어서는 React Native나 완전한 네이티브 환경에 비해 지원이 부족하다 [27].

Last updated: 2026-05-03