일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- dart 언어
- c#
- C언어 포인터
- vim
- c# 추상 클래스
- Python
- Flutter
- Unity
- 깃
- 포인터
- docker
- git
- jupyter lab
- HTML
- C# delegate
- github
- 도커
- C++
- 구조체
- c언어
- c# winform
- Data Structure
- c# 윈폼
- jupyter
- gitlab
- 플러터
- Houdini
- Algorithm
- 다트 언어
- 유니티
- Today
- Total
nomad-programmer
[Flutter] 성능 개선을 위한 작은 실천 본문
Flutter 프레임워크를 사용해 앱을 만들 때, Widget 생성시 보통은 new 키워드를 생략하고 사용한다.
ex) Text('foo');
ex) new Text('foo');
생략해서 사용할 수 있을뿐이지 컴파일 시 컴파일러가 자동으로 new 키워드를 붙여준다. 이것은 컴파일 시간에 진행되는 것이라 문제될 것은 없다.
컴파일 시간에 되는 것이라면 문제 없겠지만 런타임에 그런것이라면 조금 신경을 써야하는 것이 좋다. statefulWidget의 setState() 메소드가 바로 그것이다. 이 메소드는 실행 시간에 UI 전체를 다시 그리는(build) 메소드다. 그래서 소소하게라도 관심을 갖고 코딩을해야 한다.
setState() 메소드를 통해 업데이트가 되어야하는 위젯은 업데이트가 되야겠지만... setState() 메소드는 그것뿐만 아니라 모든 화면의 Widget들을 다시 업데이트 시킨다. 즉, 화면 전체를 재렌더링하는 과정을 거친다. 때문에 변경될 필요가 없는 Widget들까지 다시 build가 되는 것은 비효율적이다.
다시 렌더링되는 것을 막을 수 있는 것이 있다. 그것은 바로 'const' 키워드이다. const를 사용해서 Widget 생성을 하게되면 앱이 다시 build 될 때 const가 붙은 것은 build 하지 않고 그대로 둔다.
몇 번의 setState() 메소드 호출이라면 상관 없겠지만 지속적으로 setState() 메소드가 호출되는 로직이라면 const를 적극적으로 사용하는 것이 소소하게나마 성능을 개선시킬 수 있는 방법이다.
티끌모아 태산이라고 작지만 그것이 모이면 실행 되는 앱을 버벅거리게 만들 수도...
api.flutter.dev/flutter/widgets/StatefulWidget-class.html#performance-considerations
'Programming > Flutter' 카테고리의 다른 글
[Flutter] StatefulWidget 클래스 사용 시점 (0) | 2020.10.18 |
---|---|
[Flutter] Reactive Programming (0) | 2020.10.17 |
[Programming/Flutter] AppBar에 Gradient Color 적용 (0) | 2020.10.13 |
[Programming/Flutter] Provider Pattern (0) | 2020.10.12 |
[Programming/Flutter] Provider 패턴으로 만든 StopWatch APP (0) | 2020.10.11 |