Skip to content

IntelliJ IDEA를 사용하여 코루틴 디버그하기 – 튜토리얼

이 튜토리얼에서는 IntelliJ IDEA를 사용하여 Kotlin 코루틴을 생성하고 디버그하는 방법을 보여줍니다.

이 튜토리얼은 코루틴 개념에 대한 사전 지식이 있다고 가정합니다.

코루틴 생성하기

  1. IntelliJ IDEA에서 Kotlin 프로젝트를 엽니다. 프로젝트가 없다면 새로 생성하세요.

  2. Gradle 프로젝트에서 kotlinx.coroutines 라이브러리를 사용하려면 build.gradle(.kts)에 다음 의존성을 추가하세요.

    kotlin
    dependencies {
        implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:1.10.2")
    }
    groovy
    dependencies {
        implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.10.2'
    }

    다른 빌드 시스템의 경우 kotlinx.coroutines README의 지침을 참조하세요.

  3. src/main/kotlin에서 Main.kt 파일을 엽니다.

    src 디렉터리에는 Kotlin 소스 파일과 리소스가 포함되어 있습니다. Main.kt 파일에는 Hello World!를 출력할 샘플 코드가 포함되어 있습니다.

  4. main() 함수에서 코드를 변경하세요:

    • runBlocking() 블록을 사용하여 코루틴을 래핑합니다.
    • async() 함수를 사용하여 지연된 값 ab를 계산하는 코루틴을 생성합니다.
    • await() 함수를 사용하여 계산 결과를 기다립니다.
    • println() 함수를 사용하여 계산 상태와 곱셈 결과를 출력합니다.
    kotlin
    import kotlinx.coroutines.*
    
    fun main() = runBlocking<Unit> {
        val a = async {
            println("I'm computing part of the answer")
            6
        }
        val b = async {
            println("I'm computing another part of the answer")
            7
        }
        println("The answer is ${a.await() * b.await()}")
    }
  5. Build Project를 클릭하여 코드를 빌드하세요.

    애플리케이션 빌드

코루틴 디버그하기

  1. println() 함수 호출이 있는 줄에 중단점을 설정하세요.

    콘솔 애플리케이션 빌드

  2. 화면 상단의 실행 구성 옆에 있는 Debug를 클릭하여 디버그 모드에서 코드를 실행하세요.

    콘솔 애플리케이션 빌드

    Debug 도구 창이 나타납니다:

    • Frames 탭에는 호출 스택이 포함됩니다.
    • Variables 탭에는 현재 컨텍스트의 변수가 포함됩니다.
    • Coroutines 탭에는 실행 중이거나 일시 중단된 코루틴에 대한 정보가 포함됩니다. 세 개의 코루틴이 표시됩니다. 첫 번째 코루틴은 RUNNING 상태이고, 나머지 두 코루틴은 CREATED 상태입니다.

    코루틴 디버그

  3. Debug 도구 창에서 Resume Program을 클릭하여 디버거 세션을 재개하세요:

    코루틴 디버그

    이제 Coroutines 탭에 다음이 표시됩니다:

    • 첫 번째 코루틴은 SUSPENDED 상태입니다. 이는 값을 곱할 수 있도록 기다리고 있음을 의미합니다.
    • 두 번째 코루틴은 a 값을 계산하고 있으며 RUNNING 상태입니다.
    • 세 번째 코루틴은 CREATED 상태이며 b 값을 계산하고 있지 않습니다.
  4. Debug 도구 창에서 Resume Program을 클릭하여 디버거 세션을 재개하세요:

    콘솔 애플리케이션 빌드

    이제 Coroutines 탭에 다음이 표시됩니다:

    • 첫 번째 코루틴은 SUSPENDED 상태입니다. 이는 값을 곱할 수 있도록 기다리고 있음을 의미합니다.
    • 두 번째 코루틴은 값을 계산하고 사라졌습니다.
    • 세 번째 코루틴은 b 값을 계산하고 있으며 RUNNING 상태입니다.

IntelliJ IDEA 디버거를 사용하면 각 코루틴을 더 깊이 파고들어 코드를 디버그할 수 있습니다.

최적화로 제외된 변수

suspend 함수를 사용하면 디버거에서 변수 이름 옆에 "was optimized out" 텍스트가 표시될 수 있습니다:

변수 "a"가 최적화로 제외됨

이 텍스트는 변수의 수명이 단축되어 더 이상 존재하지 않음을 의미합니다. 변수 값을 볼 수 없기 때문에 최적화로 제외된 변수가 있는 코드를 디버그하기 어렵습니다. -Xdebug 컴파일러 옵션을 사용하여 이 동작을 비활성화할 수 있습니다.

이 플래그를 프로덕션 환경에서 절대 사용하지 마세요: -Xdebug메모리 누수를 유발할 수 있습니다.