ํฐ์คํ ๋ฆฌ ๋ทฐ
Android Interview ์ง๋ฌธ ๋ชจ์ - ์ค์ ๋ก ๋ฉด์ ์ ๋์จ ์ง๋ฌธ๋ค ์ ๋ฆฌ
pyorolong 2022. 7. 9. 16:51์ค์ ๋ก ๋ฉด์ ๊ณผ์ ์์ ๋ฐ์๋ ์ง๋ฌธ๋ค์ ์ ๋ฆฌํด๋ณด๋ ค๊ณ ํ๋ค.
์ด์ค์์๋ ๋๋ตํ์ง ๋ชปํ๋ ๊ฒ๋ค๋ ์๋๋ฐ, ์ด๋ ๊ฒ ์ ๋ฆฌํ๋ฉฐ ๊ณต๋ถํ๋ฉฐ ๋ณด์ํ ์ ์๊ฒ ๋ค.
Computer Sience
ArrayList์ LinkedList์ ์ฐจ์ด๋ฅผ ์ค๋ช ํ๊ณ ๊ฐ ์๋ฃ๊ตฌ์กฐ์ ์ฅ๋จ์ ์ ๋ฐ๋ฅธ ์ ์ ํ ์ฌ์ฉ ์์๋?
์๋ฃ๊ตฌ์กฐ: Linked List ๋ ArrayList
2014๋ ๋ชจ๋๋ค ์ด๋ค ๋ชฉ์ ๊ณผ ๊ณํ์ ๊ฐ๊ณ ์ด๊ณ ๊ณ์ ์ง์? ์ ๋ ์ฌ ํํด “Go to the Base”๋ฅผ ๋ชฉํ๋ก ์ฌ๋ฌ ๊ณํ์ ์ธ์ ๋๋ฐ์. ๊ทธ ์ค ํ๋๊ฐ ๊ณผ๊ฑฐ 5๋ ๋์ ์ ๋ฅผ ๋ ๋์ ๋ณด๊ณ ๋ถ์กฑํ๋ ๊ธฐ๋ณธ ์ง์์ ํ
www.nextree.co.kr
- ArrayList : ๋ฐ์ดํฐ๋ค์ด ์์๋๋ก ์ญ ๋์ด์ ๋ฐฐ์ด์ ํ์์ผ๋ก ์ฌ์ด์ฆ๊ฐ ๊ณ ์ ๋์ด ์๋ค
- LinkedList : ๋ฐ์ดํฐ๋ค์ด ์๋ฃ์ ์ฃผ์๊ฐ์ผ๋ก ์๋ก ์ฐ๊ฒฐ๋์ด ์๋ ํ์
LinkedList๋ ์์น์ ๊ด๊ณ ์์ด ๊ธฐ์กด์ ๋ฐ์ดํฐ์ ์ญ์ , ์ฝ์ ์ด ๋น ๋ฅด๊ฒ ๊ฐ๋ฅํ ๋ฐ๋ฉด ArrayList๋ O(N)๋งํผ์ ์๋๊ฐ ์์๋จ
๋น๋ฒํ ๋ฐ์ดํฐ์ ์ฝ์ /์ญ์ ๊ฐ ๋ฐ์ํ ๊ฒฝ์ฐ Linked ๋ฆฌ์คํธ๊ฐ ํจ์ฌ ๋ ์ข์ง๋ง ํน์ ์๋ฃ์ ํ์ํ๊ธฐ ์ํด์๋ ํจ์ฌ ๋ง์ ์๊ฐ์ด ์์๋๋ค.
HashTable์ ๋ฌด์์ธ๊ฐ?
(Key, Value)๋ก ๋ฐ์ดํฐ๋ฅผ ์ ์ฅํ๋ ์๋ฃ๊ตฌ์กฐ ์ค ํ๋. ๋น ๋ฅธ ๊ฒ์ ์๋๋ฅผ ์ ๊ณตํ๋ค. ํ๊ท ์๊ฐ ๋ณต์ก๋๋ O(1)์ด๋ค.
HashTable๊ณผ HashMap์ ์ฐจ์ด?
๋๊ธฐํ ์ง์ ์ฌ๋ถ์ ์ฐจ์ด. ๋ณ๋ ฌ ์ฒ๋ฆฌ๋ฅผ ํตํด ์์์ ๋๊ธฐํ๋ฅผ ๊ณ ๋ คํด์ผ ํ๋ ์ํฉ์ด๋ผ๋ฉด HashTable (put ํจ์์ synchronized), ๋ณ๋ ฌ์ฒ๋ฆฌ๋ฅผ ํ์ง ์๊ฑฐ๋ ๋๊ธฐํ๋ฅผ ๊ณ ๋ คํ์ง ์๋ ์ํฉ์ด๋ผ๋ฉด HashMap.
Process Thread์์ critical section๊ณผ race condition์ ๋ํด ์ค๋ช ํด๋ผ
- Critical section(์๊ณ์์ญ) : ๋ณ๋ ฌํ๋ก๊ทธ๋๋ฐ์์ 2๊ฐ ์ด์์ thread๊ฐ ํ๋์ ์์์ ์ ๊ทผํ๋ ๋ช ๋ น๋ฌธ, ํน์ ์ฝ๋์ ์ผ๋ถ
- Race condition : 2๊ฐ ์ด์์ ํ๋ก์ธ์ค๊ฐ ๋ณํ์ ์ผ๋ก(concurrently) ์ฝ๊ฑฐ๋ ์ฐ๋ ๋์์ ํ ๋ ์๋ก ๊ฒฝ์ํ๋ ์ํฉ
์ด๋ฌํ ๋ฌธ์ ๋ฅผ ํด๊ฒฐํ๊ธฐ ์ํด์๋ synchronized(๋๊ธฐํ)์ฒ๋ฆฌ๋ฅผ ํด์ผํ๋ค. ์๊ณ์์ญ์์ ์คํ๋๋ ์ค๋ ๋๋ lock์ ํ๋ํ๊ฒ๋๋๋ฐ, ์ด lock์ ์ค์ง ํ๋์ thread๋ง ๊ฐ์ ์ ์๋ค.
Semaphore, Mutex์ ๋ํด ์ค๋ช ํด๋ผ
๊ฒฝ์ํ๋ก์ธ์ค๊ฐ ์ง๋ฉดํ๋ Mutual exclusion, deadlock, starvation์ ์ํ๋ฅผ ์๋ฐฉํ ์ ์๋ ๋ฐฉ๋ฒ๋ค.
- Semaphore : ๊ณต์ ๋ ์์์ ๋ฐ์ดํฐ๋ฅผ ์ฌ๋ฌ ํ๋ก์ธ์ค๊ฐ ์ ๊ทผํ๋ ๊ฒ์ ๋ง๋ ๊ฒ
- Mutex : ์ฌ๋ฌ ์ค๋ ๋๋ค์ critical section์ ๋ํ ์ ๊ทผ์ด ๊ฒน์น์ง ์๋๋ก 1๊ฐ์ ์ค๋ ๋๋ง ์ ๊ทผํ ์ ์๋๋ก ํ๋ ๊ฒ
Semaphore์ Mutex์์ ์ฐจ์ด๋ก๋ Semaphore๋ 1๊ฐ์ ์ค๋ ๋๋ง ๋ค์ด๊ฐ๊ฒ ํ ์๋ ์๊ณ , ์ฌ๋ฌ๊ฐ์ ์ค๋ ๋๊ฐ ์ ๊ทผ ํ ์ ์๋ ๋ฐ๋ฉด Mutext๋ 1๊ฐ์ ์ค๋ ๋๋ง ์ ๊ทผ ํ ์ ์๋ค.
๋ฎคํ ์ค(Mutex)์ ์ธ๋งํฌ์ด(Semaphore)์ ์ฐจ์ด
์ด ๊ธ์ Medium์ ๊ฐ์๋ ๊ธ์ ๋๋ค. Medium์์ ๋ณด์๋ฉด ์ข ๋ ์ ์พํ ํ๊ฒฝ์์ ๊ธ์ ๋ณด์ค ์ ์์ต๋๋ค. ๋ฎคํ ์ค(Mutex)์ ์ธ๋งํฌ์ด(Semaphore)์ ์ฐจ์ด Toilet problem ๋์์ฑ ํ๋ก๊ทธ๋๋ฐ์ ๊ฐ์ฅ ํฐ ์์ ๋ ‘๊ณต
worthpreading.tistory.com
Concurrency๊ณผ Parallelism
- Concurrency(๋์์ฑ) : Interleaving(์๋ถํ ), ๋ค์์ task๋ฅผ ์กฐ๊ธ์ฉ ๋๋์ด ์คํ
-> 10๋ถ ์์ task 2๊ฐ ์ํ์ context switching ๋น์ฉ์ ์ ์ธํ๊ณ 20๋ถ ์์ - Parallelism(๋ณ๋ ฌ์ฑ) : Parallelizing(๋ณ๋ ฌ์ํ), ๋ค์์ task๊ฐ ๋์์ ์คํ
-> 10๋ถ ์์ task์ 12๋ถ ์์ task๋ฅผ ์ํ ์ 12๋ถ ์์ context switching ํ์ ์์)
Android
์๋๋ก์ด๋ 4๋ ์ปดํฌ๋ํธ์ ๋ํ ์ค๋ช
Activity LifeCycle
OS ๋ฒ์ ์ ๋ฐ๋ผ Braodcast๋ฅผ ์ฌ์ฉํ ์ ์๋ ๊ถํ์ด ์ถ์ ๋์๋๋ฐ ์ด๋ป๊ฒ ์ถ์๋์๋์ง, ์ด์ ๋ฐ๋ฅธ ๋์๋ฐฉ์์?
Doze๋ชจ๋์ ๋ํด ์ค๋ช ํ๊ณ ์ด์ ๋ฐ๋ฅธ ๋์๋ฐฉ์์?
PendingIntent๋ ๋ฌด์์ธ๊ฐ?
- Pending์ ์ฌ์ ์ ์๋ฏธ : ๋ณด๋ฅ, ์๋ฐ, ๊ณง ์์
- ๋ค๋ฅธ ํ๋ก์ธ์ค์๊ฒ ๊ถํ์ ํ๊ฐํ์ฌ ๋น์ฅ ์ํํ์ง ์๊ณ ํน์ ์์ ์ ์ํํ๋๋ก ํจ
OnNewIntent()๋ ๋ฌด์์ธ๊ฐ?
DI ๋ผ์ด๋ธ๋ฌ๋ฆฌ Koin๊ณผ Hilt์ ์ฐจ์ด์ ์?
Thread์ Coroutine์ ๊ฐ๊ฐ ๋ฌด์์ด๊ณ ์ด๋ค ์ฐจ์ด๊ฐ ์๋์ง?
Tread
- Task ๋จ์ : Thread
- Concurrency ๋ณด์ฅ ์๋จ : Context switching (blocking ํด๋น ๊ตฌ๋ฌธ์ด ๋๋ ๋ ๊น์ง ๋ค๋ฅธ Thread๋ฅผ blocking)
- ์์ฒด stack ๋ฉ๋ชจ๋ฆฌ ์์ญ์ ๊ฐ์
Coroutine
- Task ๋จ์ : Object
- Concurrency ๋ณด์ฅ ์๋จ : Suspend (non-blocking ํด๋น ๊ตฌ๋ฌธ์ด ๋๋ ๋ ๊น์ง awaits ํ์๋ค๊ฐ ๋๋๋ฉด ๋ค์ ์ด์ด ๋๊ฐ)
- task๋ง๋ค stack ์์ญ์ ๊ฐ์ง ์์๋ ๋จ
data class๋ ๋ฌด์์ธ๊ฐ?
Data ๋ณด๊ด ๋ชฉ์ ์ผ๋ก ๋ง๋ ํด๋์ค. getter(), setter(), toString(), hashCode(), equals(), copy() ๋ฑ์ ๋ฉ์๋๋ฅผ ๋ง๋ค์ง ์์๋ ๋์ด ๋ณด์ผ๋ฌํ๋ ์ดํธ ์ฝ๋๋ฅผ ์ค์ผ ์ ์๋ค.
sealed class๋ ๋ฌด์์ธ๊ฐ?
์์ ํด๋์ค๋ฅผ ์์ํ ํ์ ํด๋์ค ์ ์๋ฅผ ์ ํ ํ ์ ์๋ Enum ํด๋์ค์ ํ์ฅ ํํ. Enum ํด๋์ค์๋ ๋ค๋ฅด๊ฒ ์ธ์คํด์ค๋ฅผ ์ฌ๋ฌ ๊ฐ ์์ฑ ํ ์ ์๋ค.
suspend ํจ์๋ ๋ฌด์์ด๊ณ ์๋ ์๋ฆฌ
Coroutin Scope ๋ด์์๋ง ์ํ ํ ์ ์๋ ์ผ์์ค๋จ์ด ๊ฐ๋ฅํ ํจ์. ์ค๋ ๋๋ฅผ blockํ์ง ์๊ณ ํน์ ์์ ์ด suspend๋ ์ดํ resume ๋ ๋ ๊น์ง ๋ค๋ฅธ ์์ ์ ์ํํ ์ ์๋ค.
์๋ ์๋ฆฌ?
Collection์ map, filter์ ๊ฐ์ ์ฐ์ฐ๋ค์ด ์๋๋ฐ ์ผ๋ฐ ์ฐ์ฐ๊ณผ ์ํ์ค ์ฐ์ฐ์ ์ฐจ์ด
Livedata์ value, post value์ ์ฌ์ฉ์ ์ฐจ์ด์ ๋ด๋ถ ๊ตฌํ์ ์ฐจ์ด
setValue()
Main ์ค๋ ๋์์ LiveData ๊ฐ์ ๋ณ๊ฒฝ. ๋ฐฑ๊ทธ๋ผ์ด๋์์ ์ฌ์ฉํ ๊ฒฝ์ฐ ์ค๋ฅ๊ฐ ๋ฐ์ํ๋ค.
postValue()
Backgroud ์ค๋ ๋์์ LiveData ๊ฐ์ ๋ณ๊ฒฝ ํ ๋ ์ฌ์ฉ. backgroud ์ค๋ ๋์์ ๋์ํ๋ค๊ฐ main ์ค๋ ๋์ ๊ฐ์ post ํด์ฃผ๋ ๋ฐฉ์์ผ๋ก ์ฌ์ฉ. ์๋๋ postValue()์ ๋ด๋ถ ์ฝ๋์ด๋ค.
new Handler(Looper.mainLooper()).post(() -> setValue())
CleanArchitecture์ UseCase๋ ๋ฌด์์ธ๊ฐ?
Coroutine Dispatcher์ ์ข ๋ฅ์ ๊ฐ๊ฐ์ ๋ํ ์ค๋ช
flow๋?
Mutable ๋ณ์๋ฅผ Imutable ๋ณ์๋ก ๋ณํํ์ฌ ์ฌ์ฉํ๋ ์ด์
Activity์ ์๋ช ์ฃผ๊ธฐ์ Fragment์ ์๋ช ์ฃผ๊ธฐ์ ์ฐจ์ด
LifeCycleOwner๋ ๋ฌด์์ธ๊ฐ?
Pacelable๊ณผ Serializable์ ์ฐจ์ด
Android ์ด๋ฏธ์ง ์บ์ ๋ผ์ด๋ธ๋ฌ๋ฆฌ Lru์บ์ฌ์ ๋ํด ์ค๋ช ํด๋ผ
๋ช ์์ Intent์ ์์์ Intent์ ์ฐจ์ด
Jar๊ณผ AAR์ ์ฐจ์ด
Resํ์ผ์ ํฌํจ ์ฌ๋ถ์์ ์ฐจ์ด AAR์ ๋ฆฌ์์ค ํ์ผ๋ค๋ ํจ๊ป ๋ผ๋ฆฌ๋ธ๋ฌํ ๋จ
onSavedInstance ํธ์ถ ์์
Activity์์ Dialog๊ฐ ๋ณด์ฌ์ง ๋ LifeCycle ์ด๋ฒคํธ๊ฐ ํธ์ถ์ด ๋๋์ง?
Dalvik๊ณผ ART์ ์ฐจ์ด
Dalvik
- JIT(Just In Time) ์ปดํ์ผ ๋ฐฉ์: ์ฑ ๊ตฌ๋์ค ์ค์๊ฐ์ผ๋ก ์ปดํ์ผ -> ์ค์น์ ์๋๊ฐ ๋น ๋ฅด์ง๋ง ์คํ ์ ๋๋ฆผ
- Register based VM (JVM์ stack based)์ผ๋ก ์ฌ๋ฌ ๊ฐ VM ์ธ์คํด์ค๋ฅผ ์คํ ๊ฐ๋ฅ, ํ๋ก์ธ์ค ๋ ๋ฆฝ์ฑ
- .class ํ์ผ์ .dex๋ก ๋ณํ (VM์ .class๋ฅผ .jar๋ก ๋ณํ)
ART(Android Run TIme)
- AOT(Ahead Of Time) ์ปดํ์ผ ๋ฐฉ์ -> ์ค์น ์๋๊ฐ ๋๋ฆฌ์ง๋ง ์คํ ์ ๋น ๋ฆ
- ์ค์น ์ฉ๋์ด ๋ง์ด ํ์
- Nugat ๋ฒ์ ์ดํ์๋ AOT + JIT ์ปดํ์ผ๋ฌ๋ฅผ ํ์ฌํ์ฌ ์ ์ฐํ๊ฒ ์ ์ฉ
inner class๋ ์ static์ผ๋ก ์ ์ธ๋์ด์ผ ์ข์๊ฐ
Fragment parameter๋ฅผ onNewInstance๋ฅผ ํตํด ๋๊ฒจ์ค์ผ ํ๋ ์ด์
databinding๊ณผ viewBinding์ ์ฐจ์ด
์ compose๋ฅผ ์จ์ผํ๋
- Total
- Today
- Yesterday
- custom getter
- AAR
- android aar library
- The requested URL returned error
- android databinding
- GitHub
- viewmodel
- module-info is missing a super type
- Cannot create an instance
- databinding onclick not working
- com.android.build.api.transform.TransformException
- launchemode
- databinding onClick
- annotaion
- Please use a personal access token instead
- AndroidManifest
- android launch mode in manifest
- DexArchiveBuilderException
- decomplie
- aar import
- Make onClick event in Android databinding
- Effective Kotlin
- How to import android AAR file
- custom setter
- Support for password authentication was removed on August 13
- android aar
- Kotlin
- Hilt
- import aar
- android
์ผ | ์ | ํ | ์ | ๋ชฉ | ๊ธ | ํ |
---|---|---|---|---|---|---|
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 |