溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

今天我把APP的編譯速度縮短了近5倍

發布時間:2020-06-02 10:14:51 來源:網絡 閱讀:1529 作者:Android解析 欄目:移動開發

團隊使用kotlin挺長時間了,一直以來都不太滿意kotlin的編譯速度,但是也能忍受。最近開了一個新項目,有不少同事從java過來的,他們就實在是受不了,優化編譯速度就變得很重要了。

優化之前和之后的對比

在優化之前我們的一次完整編譯時間是2分21秒

今天我把APP的編譯速度縮短了近5倍

具體的耗時任務在Run Tasks中:

今天我把APP的編譯速度縮短了近5倍

可以看到具體的耗時任務如上,主要是kapt相關的編譯和編譯kotlin代碼,以及最后的transformClassedWithXXX。

優化之后的完整編譯時間31s

今天我把APP的編譯速度縮短了近5倍

優化之后的增量編譯時間15s

今天我把APP的編譯速度縮短了近5倍今天我把APP的編譯速度縮短了近5倍

看完這里大家是不是已經開始直呼,**,這樣也可以!別著急,下面就帶大家一起來搞一搞,好東西一定要分享不是嗎?

優化步驟

1.優化gradle配置:

在項目根目錄創建一個gradle.properties文件

//開啟gradle并行編譯,開啟daemon,調整jvm內存大小
org.gradle.daemon=true
org.gradle.configureondemand=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx4096m -XX:MaxPermSize=1024m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8

//開啟gradle緩存
org.gradle.caching=true
android.enableBuildCache=true

//開啟kotlin的增量和并行編譯
kotlin.incremental=true
kotlin.incremental.java=true
kotlin.incremental.js=true
kotlin.caching.enabled=true
kotlin.parallel.tasks.in.project=true //開啟kotlin并行編譯


//優化kapt
kapt.use.worker.api=true //并行運行kapt1.2.60版本以上支持
kapt.incremental.apt=true //增量編譯 kapt1.3.30版本以上支持
//kapt avoiding 如果用kapt依賴的內容沒有變化,會完全重用編譯內容,省掉最上圖中的:app:kaptGenerateStubsDebugKotlin的時間
kapt.include.compile.classpath=false

在上面的配置中,我們首先調整了gradle的配置,然后開啟了緩存和kotlin和kapt的增量編譯。

如果項目中使用了kapt請使用最新版本的kapt,當前寫該文章時kapt的最新版本為1.3.31

2.優化app的build.gradle

1.在項目的app目錄中的build.gradle文件中修改:

//如果有用到kapt添加如下配置
kapt {
useBuildCache = true
javacOptions {
option("-Xmaxerrs", 500)
}
}

//在Android代碼塊中添加如下配置:(可優化最上圖中transformClassDexBuilderForDebug的時間)
android {
dexOptions {
preDexLibraries true
maxProcessCount 8
}
}

2.其他不太重要的優化,好像對時間影響不算特別大

優化版本號的配置,如果是debug版本不要使用動態版本號

//原配置
defaultConfig {
...
minSdkVersion 19
targetSdkVersion 28
versionCode gitVersionCode
versionName currentName
...
}
//修改為
defaultConfig {
...
minSdkVersion 19
targetSdkVersion 28
versionCode 1
versionName "1.0.0"
...
}
applicationVariants.all { variant ->
...
if (variant.buildType.name == "release") {
versionName = currentName
versionCode = gitVersionCode
}
...
}

以前我們的配置上versionCode是使用的git的提交次數作為版本號的,在本地debug狀態的時候其實最好是寫死版本號,如果版本號變化會導致需要重新生成Manifest文件以及完整的編譯應用,導致InstantRun無法使用(PS其實我們一直沒用InstantRun)。所以修改為寫死版本號,然后在applicationVariants中判斷如果是release才使用正常的版本號。然后還有一個就是使用依賴版本的時候,盡量不要使用+號的版本依賴,使用固定版本號速度會更快。

希望大家省下的編譯時間,能夠好好陪陪家人。?如果覺得不錯的朋友也請幫我點個關注,你的喜歡是我最大的動力~

?

今天我把APP的編譯速度縮短了近5倍


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女