5分钟彻底理解Android 源集sourceSet

作者: 蚍蜉一生 | 来源:发表于2024-03-06 20:37 被阅读0次

    Android源集(SourceSet)是什么

         Android打包就是把源集(源代码、资源文件和依赖库等)转换成Apk的过程。这跟做菜的过程非常相似,源集等同于原材料集合,包括主菜、配菜、调料等,Apk就是成品菜,同样,类似于做菜,Android工程可以使用不同配置(做菜方法)把一个源集打包成多个Apk,也可以使用不同的源集来打包成不同Apk,这些Apk都叫渠道包。接下来我们就一起看看Android源集的是什么样子的:

    Android源集构成

         源集=主源集(下图中的main文件夹)+附加源集(下图中的so32、so64、so32Debug、soRelease、so64Debug、so64Release文件夹)

    图1-源集构成
    主源集main是必不可少的,Android工程会默认生成,但附加源集(例如so64)如何声明和添加呢

    1 声明

        当我们在一个模块的build.gradle中增加 buildTypes 或者 productFlavors 来配置不同的构建变体后,这就完成了声明,接下来就能为这些构建变体配置对应的源集,如果不配置就是默认Main源集,构建变体声明方式如下代码:

    android {
     buildTypes {
        release {
            debuggable false
        }
        debug {
            debuggable true
        }
    
    }
    
     flavorDimensions "so"
     productFlavors {
        so32 {
            dimension "so"
            ndk {
                abiFilters "armeabi-v7a"
            }
        }
        so64 {
            dimension "so"
            ndk {
                abiFilters "arm64-v8a"
            }
        }
    }
    

    上述代码声明了 release 和debug两个构建类型, so32 和so64两个产品风味,那么对应的构建变体就有四个:so32Debug、so32Release·、so64Debug、so64release,这四个构建变体源集有如下几种配置方案 :

    • 为so32Debug、so32Release·、so64Debug、so64release分别配置;
    • 只配置产品风味,比如配置了so64目录,那么so64Debug、so64release都会采用此目录下的配置;
    • 只配置构建类型,比如配置了debug目录,那么so32Debug、so64Debug就会采用此目录下的配置。

    2 配置方法

    ① 在src目录下新增你确定要配置的源集目录,比如so32Debug、so64、debug

    源集配置
    ②添加文件目录后,就可以在此文件目录下添加子文件夹和各种文件,添加的文件有两种:独特的(在main源集和其他附加源集都没有) 和冲突的(在main源集或者其他附加源集中有同样路径同样文件名的文件),对于独特的无需任何处理,打渠道包时候自然打进去;对于冲突的是区分源码和资源的:
    • 对于源码 比如Java目录下如果添加路径相同、类名相同的会出现编译不过的问题,这时候要进行重命名或者整体结构调整;
    • 对于资源,比如assert目录、resource目录、jni目录、lib目录,打渠道包的时候执行覆盖策略
      构建类型与产品风味的组合源集so64Debug > 产品风味源集so64 > 构建类型源集debug > 主源集

    注意:图1-源集构成 是配置了所有源集,实际中按照需求配置即可,比如只配置so64文件目录。

    小结

        渠道包由渠道源集加工而来,渠道源集=主源集+附加源集,附加源集中的源码不能有冲突,资源冲突打包时候执行覆盖策略。

    相关文章

      网友评论

        本文标题:5分钟彻底理解Android 源集sourceSet

        本文链接:https://www.haomeiwen.com/subject/hordzdtx.html