Android Studio - Gradle build设置自动log开关

Android Studio - Gradle build设置自动log开关

应用场景

通常情况下我们的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模式下该文件的内容:

/**
 * Automatically generated file. DO NOT MODIFY
 */
package com.leo.kang.cetfour;
 
public final class BuildConfig {
  public static final boolean DEBUG = false;
  public static final String APPLICATION_ID = "com.leo.demo";
  public static final String BUILD_TYPE = "release";
  public static final String FLAVOR = "baidu";
  public static final int VERSION_CODE = 47;
  public static final String VERSION_NAME = "3.6.1";
  public static final boolean LEO_LOG = false;
}

怎样自定义BuildConfig字段

在我们的build.gradle里面加入如下代码:

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
    }
}

语法为:

buildConfigField "boolean", "LEO_DEBUG", "true"
上述语法就定义了一个boolean类型的LEO_DEBUG字段,值为true,之后我们就可以在程序中使用BuildConfig.LEO_DEBUG字段来判断我们所处的api环境。例如:

@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()");
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 178,267评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,439评论 19 139
  • 自定义常量 开发阶段利用 Log 日志方便代码调试是再常见不过的事情。出于安全考虑,这种做法仅限于 Debug 模...
    亦枫阅读 2,203评论 0 15
  • 霜降 悄悄地远了 作别天边那最后一缕 凝在枫树梢头的叶子底 也许 冬至便也是在此刻 敲着我透明的窗玻璃 无疑 在冬...
    Lotus吴阅读 210评论 0 4
  • 一座城里,包含了太多人的欢聚和离散。你是否正深情的爱着某座城,是否正在那里向理想的生活一路奔去?我爱着南京,我在...
    邦妮的生活馆阅读 337评论 2 2

友情链接更多精彩内容