코루틴 썸네일형 리스트형 [코루틴] select select 함수가장 먼저 완료되는 코루틴의 결과를 기다리는 함수 지연되는 값 선택suspend fun main(): Unit = coroutineScope { println(askMultipleForData())}val scope = CoroutineScope(SupervisorJob())suspend fun askMultipleForData(): String { val data1 = scope.async { requestData1() } val data2 = scope.async { requestData2() } return select { data1.onAwait { it } data2.onAwait { it } }}suspend fun requ.. 더보기 [코루틴] Channel (채널) Channel (채널)Channel은 송신자(SendChannel을 통해)와 수신자(ReceiveChannel을 통해) 간의 논블로킹 통신을 위한 기본 요소Channel은 Java의 BlockingQueue와 유사하지만 블로킹 연산 대신 일시 중단 연산을 사용하며 닫을 수 있다는 차이가 있다public interface Channel : SendChannel, ReceiveChannel { public companion object Factory { // 무제한 용량의 버퍼를 가진 채널. send가 중단되지 않음 public const val UNLIMITED: Int = Int.MAX_VALUE // 랑데부 채널(버퍼가 없는 채널 - 용량 0) .. 더보기 [코루틴] 코루틴의 동작 방식 코루틴 동작 방식코루틴은 일시 중단이 가능하고 필요한 시점에 다시 실행을 재개할 수 있는 기능을 가진다일시 중단과 재개를 위해 코루틴의 실행 정보 저장이 필요 Continuation Passing Style (CPS)continuation(이어서 실행해야 하는 작업)을 전달하는 스타일의 방식함수는 결과를 직접 반환하는 대신, 결과를 처리할 다음 단계(continuation)를 인자로 받고실행이 완료되면 continuation을 호출하여 다음 단계 시작// CPS 스타일fun CpsFunction(arg, (result) -> { /* next 작업 */ }) // 일반 함수fun generalFunction(arg) // compile 시 cps 스타일로 변경되는 suspendsuspend fun doS.. 더보기 [코루틴] 무제한 디스패처 (Unconfined Dispatcher) 무제한 디스패처 (Unconfined Dispatcher)코루틴을 실행시킨 스레드에서 즉시 실행하도록 만드는 디스패처호출된 스레드가 무엇인지 상관없어 실행 스레드가 제한되지 않아 무제한 디스패처fun main() = runBlocking { launch(Dispatchers.Unconfined) { println("launch 실행 스레드 : ${Thread.currentThread().name}") }}// 결과launch 실행 스레드 : main 특징코루틴을 생성한 스레드에서 즉시 실행fun main() = runBlocking(Dispatchers.IO) { println("runBlocking 실행 스레드 : ${Thread.currentThread().name}").. 더보기 [코루틴] CoroutineStart CoroutineStart코루틴의 실행 옵션 DEFAULT, ATOMIC, LAZY, UNDISPATCHEDpublic enum class CoroutineStart { // context에 따라 코루틴 실행을 즉시 예약 DEFAULT, // 필요할 경우 lazy하게 코루틴 시작 LAZY, // context에 따라 실행할 코루틴을 원자적으로 예약 // Default와 유사하지만 코루틴은 실행을 시작하기 전에 취소될 수 없다 ATOMIC, // 현재 스레드에서 첫 번째 중단 지점까지 코루틴을 즉시 실행 UNDISPATCHED; ...} 사용 방법코루틴 빌더 함수 인자로 전달public fun CoroutineScope.launch( con.. 더보기 [코루틴] 공유 상태를 사용하는 코루틴 공유 상태를 사용하는 코루틴과 문제점 가변 변수 사용 시 문제점상태를 공유하기 위해서 가변 변수 사용 문제Inconsistency (불일치)var count = 0fun main() = runBlocking { withContext(Dispatchers.Default) { repeat(10_000) { launch { count += 1 } } } println("count = ${count}")}// 결과// 1차 count = 8852// 2차 count = 8875// 3차 count = 8700 원인메모리 가시성 (Memory Visibility) 한 스레드에서 변경한 데이터를 다른 스레드에.. 더보기 [코루틴] 코루틴의 스레드 동작 코루틴은스레드 사용이 필요 없어지면 스레드 양보스레드를 양보하는 주체 CoroutineDispatcher는스레드에 코루틴을 할당 코루틴이 스레드를 양보하려면 스레드 양보 함수를 호출해야 한다그러지 않으면 완료될 때까지 스레드를 점유 코루틴에서 스레드를 양보하는 방법delayjoin, awaityield delay 일시 중단 함수fun main() = runBlocking { val startTime = System.currentTimeMillis() repeat(10) { repeatTime -> launch { // delay로 1초 동안 메인 스레드 사용하도록 양보 delay(1000L) // Thread.sleep(1.. 더보기 [코루틴] 코루틴(Coroutine)과 서브루틴(Subroutine) Routine (루틴)특정한 일을 하기 위한 일련의 명령(함수) Subroutine (서브루틴)함수 내에서 실행되는 다른 함수 루틴과 서브루틴fun main() = runBlocking { mainRoutine() // main의 서브루틴}fun mainRoutine() { mainSubRoutine1() // mainRoutine의 서브루틴 mainSubRoutine2() // mainRoutine의 서브루틴}fun mainSubRoutine1() { ... }fun mainSubRoutine2() { ... } 서브루틴 특징한 번 호출되면 끝까지 실행 서브루틴 실행 시 스레드가 사용되어 서브루틴 종료시까지 루틴은 다른 작업 X Coroutine (코루틴)함께(Co) 실행되는 루틴.. 더보기 이전 1 2 3 다음