zoukankan      html  css  js  c++  java
  • 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模式下该文件的内容:

     
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    /**
     * 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";
    1
    public static final boolean LEO_LOG = false;
    1
    }

    怎样自定义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
            }
        }

      

    语法为:

    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()");
            }
        }
     
     
  • 相关阅读:
    hdu 3709 Balanced Number 数位dp
    通过大数据分析典型的长尾问题场景及解法
    【无人驾驶技术揭秘】从机器学习角度揭秘学习型避障小车的设计思路
    Git Flow——Git团队协作最佳实践
    【技术合集】新春来袭,锦囊妙计助程序员过个好年
    【最佳编程实践】编写「可读」代码的实践
    【开发工具推荐】31款轻量高效的开源JavaScript插件和库
    【微服务那些事】Microservices场景下的持续部署
    前端图像处理指南
    Sed&awk笔记之awk
  • 原文地址:https://www.cnblogs.com/lianghe01/p/5151461.html
Copyright © 2011-2022 走看看