시작 프로필 만들기

시작 프로필은 기준 프로필의 하위 집합입니다. 시작 프로필은 빌드 시스템에서 APK의 DEX 파일에서 코드 레이아웃을 개선하여 포함된 클래스와 메서드를 추가로 최적화하는 데 사용됩니다. 시작 프로필을 사용하면 앱 시작 속도가 기준 프로필만 사용할 때보다 최소 15% 빠릅니다.

그림 1. DEX 레이아웃 최적화로 인한 코드 위치 개선

요구사항

시작 프로필은 다음 도구와 함께 사용하는 것이 좋습니다.

  • Jetpack Macrobenchmark 1.2.0 이상
  • Android Gradle 플러그인 8.2 이상
  • Android 스튜디오 Iguana 이상

또한 앱에 다음 설정이 필요합니다.

  • R8이 사용 설정됩니다. 출시 빌드에는 isMinifyEnabled = true를 설정합니다.
  • DEX 레이아웃 최적화가 사용 설정되었습니다. 앱 모듈 빌드 파일의 baselineProfile {} 블록에서 dexLayoutOptimization = true를 설정합니다.

시작 프로필 만들기

Android 스튜디오는 기본 기준 프로필 생성기 템플릿을 사용할 때 기준 프로필과 함께 시작 프로필을 만듭니다.

시작 프로필을 만들고 생성하는 일반적인 단계는 기준 프로필 만들기 단계와 동일합니다.

시작 프로필을 만드는 기본 방법은 Android 스튜디오 내에서 기준 프로필 생성기 모듈 템플릿을 사용하는 것입니다. 여기에는 기본 시작 프로필을 형성하는 시작 상호작용이 포함됩니다. 더 중요한 사용자 여정 (CUJ)으로 이 시작 프로필을 보강하려면 includeInStartupProfiletrue로 설정된 rule 블록에 앱 시작 CUJ를 추가합니다. 간단한 앱에서는 앱의 MainActivity을 실행하는 것으로 충분할 수도 있습니다. 좀 더 복잡한 앱의 경우 홈 화면에서 앱을 시작하거나 딥 링크로 시작하는 등 가장 일반적인 진입점을 앱에 추가해 보세요.

다음 코드 스니펫은 홈 화면에서 앱을 시작하고 딥 링크로 실행하는 작업이 포함된 기준 프로필 생성기 (기본적으로 BaselineProfileGenerator.kt 파일)를 보여줍니다. 딥 링크는 앱의 홈 화면이 아닌 앱의 뉴스 피드로 직접 연결됩니다.

@RunWith(AndroidJUnit4::class)
@LargeTest
class BaselineProfileGenerator {

    @get:Rule
    val rule = BaselineProfileRule()

    @Test
    fun generate() {
        rule.collect(
            packageName = "com.example.app",
            includeInStartupProfile = true
        ) {
            // Launch directly into the NEWS_FEED.
            startActivityAndWait(Intent().apply {
                setPackage(packageName)
                setAction("com.example.app.NEWS_FEED")
            })
        }
    }
}

앱 구성의 기준 프로필 생성을 실행하고 src/<variant>/generated/baselineProfiles/startup-prof.txt에서 시작 프로필 규칙을 찾습니다.

시작 프로필 최적화 확인

DEX 레이아웃 최적화를 확인하려면 Android 스튜디오를 사용하여 APK를 열고 DEX 파일의 클래스를 확인합니다. 기본 classes.dex가 완전히 채워지지 않았는지 확인합니다. 앱이 단일 DEX 파일로 구성된 경우 시작 프로필을 사용 설정한 후 앱에 DEX 파일 두 개가 포함되어 있는지 확인할 수 있습니다.

시작 클래스가 단일 DEX 파일에 맞지 않으면 Android 스튜디오에서 경고를 표시합니다. 시작 클래스에서 비시작 메서드의 양이 포함된 진단 정보를 가져오려면 시작 프로필을 적용할 때 settings.gradle 파일을 다음과 같이 변경하여 R8 컴파일러를 버전 8.3.36-dev 이상으로 업데이트해야 합니다.

Kotlin

pluginManagement {
    buildscript {
        repositories {
            mavenCentral()
            maven {
                url = uri("https://storage.googleapis.com/r8-releases/raw")
            }
        }
        dependencies {
            classpath("com.android.tools:r8:8.3.6-dev")
        }
    }
}

Groovy

pluginManagement {
    buildscript {
        repositories {
            mavenCentral()
            maven {
                url uri('https://storage.googleapis.com/r8-releases/raw')
            }
        }
        dependencies {
            classpath 'com.android.tools:r8:8.3.6-dev"
        }
    }
}

Gradle로 빌드할 때 다음 명령어에서 assembleRelease 뒤에 --info를 추가해야 합니다.

./gradlew assembleRelease --info

그러면 진단 내용이 터미널에 출력됩니다.

앱이나 라이브러리가 디슈가링된 API를 참조하는 경우 이러한 클래스의 번들 호환성 구현은 항상 마지막 DEX 파일에 포함됩니다. 이 디슈가링된 마지막 DEX 파일은 DEX 레이아웃 최적화에 참여하지 않습니다.