作者:巫文杰
Gradle使用productFlavors打渠道包的痛
有很多同学可能会采用配置productFlavors来打渠道包,主要是它是原生支持,方便开发者输出不同定制版本的apk,举个例子:
android {
...
defaultConfig {
minSdkVersion 8
versionCode 10
}
productFlavors {
flavor1 {
packageName "com.example.flavor1"
versionCode 20
}
flavor2 {
packageName "com.example.flavor2"
minSdkVersion 14
}
}
}
这样就可以输出两个定制的apk,不同包名,版本号也不同。 但是,如果用它来打渠道包是一个非常低效的做法,因为它每一次都会走编译流程,你想一下如果每打一个渠道包就要走一下编译流程,100个渠道包那得多慢。
那如果你能忍受这么低效打渠道包的方式,那回到本文焦点,我先问个问题:“如果你要针对多渠道进行打补丁,你应该怎么做?”
你可能会回答,那就针对不同的渠道包进行打补丁。没错,这个确实