일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 슬기로운 온라인 게임
- 목적 중심 리더십
- 프래그먼트
- 자취필수템
- 리얼하다
- 캐치마인드
- 한달독서
- 어떻게 나답게 살 것인가
- 함수형 프로그래밍
- 브런치작가되기
- 목적중심리더십
- 커스텀린트
- 안드로이드
- 북한살둘레길
- 아비투스
- 면접
- T자형인재
- 테트리스
- 좌식테이블
- 소프시스
- 베드트레이
- 베드테이블
- 1일1커밋
- 지지않는다는말
- 한달브런치북만들기
- 재택근무
- 끝말잇기
- 한단어의힘
- 소프시스 밤부 좌식 엑슬 테이블
- 한달어스
- Today
- Total
정상에서 IT를 외치다
[NaverTechConcert] 네이버 테크 콘서트: 안드로이드 - 2일차 본문
안녕하세요. 블랙진입니다.
어제 다녀온 네이버 테크 콘서트 1일차에 이은 2일차 포스팅입니다.
(캡처된 사진과 발표자 내용은 모두 2018.11.02 기준 http://techcon.naver.com/ 에서 가져왔습니다.)
내용
목차
1. 안드로이드 앱의 구조 2. 함수형과 객체형: 함수형과 객체형 개발 어떻게 적용할 것이가? 3. GUI 기반 구조: Activity 구조,Fragment 구조, View 기반의 구조의 장단점은 무엇인가? 어떤 구조를 택할 것인가? 4. 데이터 모델: 데이터 모델이 필요한가? MVC, MVP, MVVM 이 정말 필요한가? 5. 프로세스 와 쓰레드 어떤 모델로 가져갈 것인가? : Service, AsyncTask, Thread, JobManager, WorkManager, Coroutine ,Loader 너무 많은데 무엇이 정답인가? 멀티 프로세스 모델 어떻게 설계할 것인가? 6. 통계와 설정: 어떤 정보를 모으고 최적할 것인가?
안드로이드 플랫폼을 바라보는 관점이 엄청 깊다는 것을 이번 발표를 통해 알 수 있었습니다. 네이버 앱의 처음부터 지금까지를 개발해 오신 분이라는 것을 다시 한번 실감할 수 있었고 많은 것을 얻을 수 있었습니다.
저번 포스팅에서 네이버 테크 콘서트 앱을 소개 했었습니다. 발표자 분께서 이 앱을 만드는데 배포까지 10시간(개발 7시간)이 걸렸다고 했습니다:)
네이버 앱을 개발하면서 앱의 크기가 커지면서 JAVA 를 사용하는것에 대해 근본적인 문제에 대해 고민한 경험을 발표해 주셨습니다.
Problem of Java
1. 상속과 오버라이드
2. 객체 내에 모두 선언해야하는 딱딱함
3. Listener 표현이 코드를 복잡하게 함
상속안에 상속이들어가고 그 안에 계속 상속이 들어가다 보니 코드의 가독성이 떨어지고 복잡해 지는 문제가 발생합니다. 이에 JAVA8 등의 방법으로 해결하러 했지만 이번 구글의 Kotlin 발표를 듣고 Kotlin을 사용해 네이버 앱을 개편한 경험을 이야기 했습니다.
또한 안드로이드 개발을 하는데 있어 여러가지 질문을 던져 주었습니다.
Activity가 뭐죠? 왜 라이프사이클을 가지고 있는걸까요?
Activity 로만 앱을 만드는 것이 효율적인가요?
개발을 하는데 있어 라이브러리, 툴, 언어 등 모든 것을 사용하는데 있어 치열하게 고민했던 내용들을 이야기해주었습니다. 개발자라면 개발하는데 사용했던 모든 것에 그 만한 이유가 있어야 되는것을 많이 느꼈습니다. 그냥 '남들이 사용하니깐', '이게 더 좋다고 하니깐' 이 아닌 개발자 스스로 이유를 찾고 선택을 하고 팀원이 있다면 설득을 해야 된다는 것을 말입니다.
목차
1. 안드로이드 앱의 구조 2. 함수형과 객체형: 함수형과 객체형 개발 어떻게 적용할 것이가? 3. GUI 기반 구조: Activity 구조,Fragment 구조, View 기반의 구조의 장단점은 무엇인가? 어떤 구조를 택할 것인가? 4. 데이터 모델: 데이터 모델이 필요한가? MVC, MVP, MVVM 이 정말 필요한가? 5. 프로세스 와 쓰레드 어떤 모델로 가져갈 것인가? : Service, AsyncTask, Thread, JobManager, WorkManager, Coroutine ,Loader 너무 많은데 무엇이 정답인가? 멀티 프로세스 모델 어떻게 설계할 것인가? 6. 통계와 설정: 어떤 정보를 모으고 최적할 것인가?
MVVM의 효율적인 사용을 위해 현업에서 사용한 방법과 고민에 대해 잘 설명해 주었습니다. 또한 예제 샘플을 통해 발표하여 이해하기 쉽고 편하게 볼 수 있었습니다. 이번 발표에서 사용한 예제를 깃허브에 올려 주셨습니다.
발표 내용을 정리해 보았습니다.
What problem MVP?
- Prenenter code 가 1000Line을 넘어가 본 적
- 비슷한 화면에서 중복되어 생성되는 코드를 본 적
- 수많은 상태를 관리하다 머리가 아파 본 적
- View와 Prenenter의 보일러 플레이트 코드가 늘어나 피곤했던 적
코드량, 복잡성 up -> 유지보수성, 테스트용이성 down -> 다른 디자인 아키텍처를 고민하게 됨
What? MVVM
- Mode, View, ViewModel 로 수정되어 있는 패턴
- ViewModel은 View의 추상화 이다.
- View와 ViewModel은 n:m 의 관계이다.
HOW MVVM? - efficiently, testable
- Databinding, UserCase, Rx, LiveData 사용
- CleanArchitecture를 지향
- Koin을 사용하여 IOC(Insersion Of Control) 구현
- Spek을 사용하여 행동 주도 결과 테스트를 작성
Koin?
- 제어의 역전을 구현 할 수 있게 도와주는 Library
- Service Locator 방식으로 구현되어 있어 Dagger 보다 가볍고 사용하기 용이하다
- AAC 를 지원해준다.
- RunTime에서 에러를 확인 할 수 있다.
Spek을 이용한 테스트 코드 작성(순서)
- Feature
- Scenario
- Given
- When
- Then
Dagger2 vs Koin
- Heavy vs light
- Dependency Injection vs ServiceLocator
- Compile Time vs RunTime
내용
목차
1. 뭐하는 사람들인가 - UI / 인터렉션 / BX 디자이너의 일 - UX / 기획자의 일 2. 그들의 생각 - 디자이너 : 왜 1px을 옮겨달라고 할까 - 기획자 : UX적으로(??) 해결해달라구요?! 3. 어떻게 일하면 좋을까 - 상세 설계 공유방식에 대한 고민 - 커뮤니케이션 4. 혹시 디자인에 관심이 있으시다면 5. 내가 사랑했던 개발자들
"디자이너는 왜 1px을 옮겨 달라고 할까?"에 대한 디자이너의 생각이 가장 인상 깊었습니다. 저 1px이 무슨 차이이지? 꼭 옮겨야 되는 것인가? 이런 생각을 그동안 해왔지만 이번 발표를 통해 그만한 충분한 이유가 있다는 것을 알았습니다. 그 외에도 디자이너의 종류와 협업을 위한 방법에 대해 많은 정보를 전달해 주었습니다.
디자이너는 뭐하는 사람들인가?
- UI 디자이너 / 사용자 인터페이스 디자인하는 사람 / 스케치, 제플린, 포토샵
- 인터렉션 디자이너 / 화면간 트랜지션 또는 서비스UI에 필요한 애니메이션 / 에펙, 프리미어, 프레이머, 포토샵, 스케치
- BX 디자이너 / 인쇄작업, 로고, 브랜드 아이덴티티 및 전략 디자인 / 일러스트 ,포토샵, 인디자인..
- Graphic 디자이너 / 서비스에 필요한 아이콘 또는 일러스트와 같은 그래픽 요소를 그리는 사람 / 포토샵, 일러스트
- 깃허브 사용
- 커뮤니케이션 / 의견은 자유롭게!! 하지만 해결방법은 상대에세 맡겨주세요. ("이런 이런화면은 사용성이 좀 떨어질 것 같은데요" 등등..)
내용
목차
1. History of Android WebView 2. Summary of how browsers work 3. Rendering pipeline overview 4. How chromium makes a frame? 5. VSync aligned touch input & frame output
내용
목차
1. 코루틴 소개(서브루틴과 코루틴) 2. 코루틴을 통해 할 수 있는것? 3. 코틀린 코루틴에서 제공하는 주요 기능들 4. 실제 업무에 적용한 코루틴 소개 5. 코루틴 써보니? RxJava와 비교
내용
목차
1. UI Test Automation 2. Automation Library 3. Android Event Check 4. Resource Monitoring
이렇게 2일동안의 네이버 테크 콘서트를 모두 보고 왔습니다. 아직도 배워야 될게 너무나 많다는 것을 느꼈고 더 열심히 공부해서 더 높이 올라가고 싶어졌습니다.
안녕~! 네이버~!
[발표 자료 공유]
오늘 진행된 네이버 테크 콘서트의 DAY 2 에서 발표된 내용은 아래 링크에서 다시 보실 수 있습니다.
- 발표자료 : https://www.slideshare.net/NaverEngineering
- 라이브 영상 : https://tv.naver.com/naverd2
'컨퍼런스' 카테고리의 다른 글
[GDG] New Years Meetup (0) | 2019.01.22 |
---|---|
[개발자들의 축제] 2018 Devfest Seoul (0) | 2018.11.10 |
[NaverTechConcert] 네이버 테크 콘서트: 안드로이드 - 1일차 (0) | 2018.11.01 |
[Kotlin Korea] 코틀린 밋업~! (0) | 2018.06.26 |
[원티드 행사] 화성에서 온 개발자, 금성에서 온 디자이너 (0) | 2018.06.17 |