应用场景
通常情况下我们的apps
发布后也就是release
模式下log
是不显示的,debug
模式下是显示log
的,但是在特殊情况下我们测试release
包的时候需要log
的时候,就无法使用BuildConfig.DEBUG
来达到要求,因为在release
模式下自动设置为false
,debug
模式下是true
,这个时候我们需要自定义可控制的log
开关。
Android Studio
对应的BuildConfig.java
位置
在Studio
中生成的目录: /app/build/generated/source/buildConfig/
文件下的产品目录里面,找到想要的包名下会自动生成BuildConfig.java
文件。我们可以看看下release
模式下该文件的内容:
1 2 3 4 5 6 7 8 9 10 11 |
/** * Automatically generated file. DO NOT MODIFY */ public final class BuildConfig { public static final boolean DEBUG = Boolean.parseBoolean("true"); public static final String APPLICATION_ID = "com.pushcenter"; public static final String BUILD_TYPE = "debug"; public static final String FLAVOR = ""; public static final int VERSION_CODE = 2100300305; public static final String VERSION_NAME = "3.3.5"; } |
怎样自定义BuildConfig
字段
在我们的build.gradle
里面加入如下代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
buildTypes { release { // 不显示Log, 在java代码中的调用方式为:BuildConfig.LOG_DEBUG buildConfigField "boolean", "LEO_DEBUG", "false" minifyEnabled true zipAlignEnabled true shrinkResources true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' signingConfig signingConfigs.release } debug { // 显示Log buildConfigField "boolean", "LEO_DEBUG", "true" versionNameSuffix "-debug" minifyEnabled false zipAlignEnabled false shrinkResources false signingConfig signingConfigs.debug } } |
语法为:
1 |
buildConfigField "boolean", "LEO_DEBUG", "true" |
上述语法就定义了一个
boolean
类型的LEO_DEBUG
字段,值为true
,之后我们就可以在程序中使用BuildConfig.LEO_DEBUG
字段来判断我们所处的api环境。例如:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); CommonUtils.getVersionName(this); initViews(); if(BuildConfig.LEO_DEBUG) { Log.i("leo", "MainActivity.onCreate()"); } } |
有点参考