Skip to content

110 Under the Hood

Sebastian Faust edited this page Oct 14, 2019 · 18 revisions

Page Table of Contents

Introduction

Flutter [1] is a framework for cross-platform native development. That means that it promises Native app performance while still compiling apps for multiple platforms from a single codebase. The best way to understand how Flutter achieves this is to compare it to other mobile development approaches. This chapter will showcase how three of the most popular cross-platform approaches function and then compare those technics to the one Flutter uses. Lastly, I will highlight some of the unique feature that Flutters approach enables.

Full Native Approach

Native app rendering

Figure 1: Native app rendering [14]

The classic way to build a mobile app would be to write native code for each platform you want to support. I.E. One for IOS [15], one for Android [16] and so on. In this approach, your app will be written in a platform-specific language and render through platform-specific Widgets and a platform-specific engine. During the development, you have direct access to platform-specific services and sensors [14], [17], [18]. But you will have to build the same app multiple times, which multiplies your workload by however many platforms you want to support.

Embedded WebApp Approach

Embedded WebApp rendering

Figure 2: Embedded WebApp rendering [14]

Embedded WebApps where the first approach to cross-platform development. For this approach, you build your application with HTML, CSS, and JavaScript and then render it through a native WebView [14], [17]. The problem here is, that developers are limited to the web technology stack and that communication between the app and native services always has to run through a bridge [18].

Bridges

Bridges connect components with one another. These components can be built in the same or different programming languages [19].

Reactive View Approach

Reactive app rendering

Figure 3: Reactive app rendering [14]

Apps build with reactive frameworks (like React Native [20]) are mostly written in a platform-independent language like JavaScript [6]. The JavaScript code then sends information on how UI components should be displayed to the native environment. This communication always runs through a bridge. So we end up with native Widgets that are controller through JavaScript. The main problem here is that the communication through the bridge can be a bottleneck that can lead to performance issues [14], [17], [18], [21].

Flutter’s Approach

Flutter app rendering

Figure 4: Flutter app rendering [14]

Flutter’s approach is to move the entire rendering process into the app. The rendering runs through Flutter’s own engine and uses Flutter’s own Widgets. Flutter only needs a canvas to display the rendered frames on. Any user inputs on the canvas or system events happening on the device are forwarded to the Flutter app. This limits the bridging between app and native environment to frames and events which removes that potential bottleneck [14], [17], [18].

You might think that keeping an entire rendering engine inside an app would lead to huge APKs, but as of 2019, the compressed framework is only 4.3MB [22].

Flutter Framework Architecture

Figure 5: Flutter Framework Architecture [14]

🕐 TLDR Flutter uses its own engine instead of using the native one. The native environment only renders the finished frames.

Flutter Compiler

One additional advantage of Flutter is that it comes with two different compilers. A JIT-Compiler (Just in time) and an AOT-Compiler (Ahead of Time). The following table will showcase the advantage of each:

Compiler What is does When it’s used
Just in Time Only re-compiles files that have changed. Preserves App State [12] during rebuilds. Enables Hot Reload [23]. During Development
Ahead of Time Compiles all dependencies Ahead of time. The output app is faster. For Release

Table 1: Flutter’s 2 Compilers [17], [24]

Hot Reload

Hot Reload [23] is a feature that Web developers are already very familiar with. It essentially means, that changes in the code are displayed in the running application near instantaneously. Thanks to its JIT Complier, The Flutter Framework is also able to provide this feature.

Hot Reload

Figure 6: Hot Reload [23]

Next Chapter: Thinking Declaratively >

Back to Top