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. public final class BuildConfig {  
  2.   public static final boolean DEBUG = false;  
  3.   public static final String APPLICATION_ID = "com.leo.demo";  
  4.   public static final String BUILD_TYPE = "release";  
  5.   public static final String FLAVOR = "baidu";  
  6.   public static final int VERSION_CODE = 47;  
  7.   public static final String VERSION_NAME = "3.6.1";  
  8.     public static final boolean LEO_LOG = false;  
  9. }  

怎样自定义BuildConfig字段
在我们的build.gradle里面加入如下代码:
  1. buildTypes {  
  2.         release {  
  3.             // 不显示Log, 在java代码中的调用方式为:BuildConfig.LOG_DEBUG  
  4.             buildConfigField "boolean""LEO_DEBUG""false"  
  5.    
  6.             minifyEnabled true  
  7.             zipAlignEnabled true  
  8.             shrinkResources true  
  9.             proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'  
  10.    
  11.             signingConfig signingConfigs.release  
  12.         }  
  13.    
  14.         debug {  
  15.             // 显示Log  
  16.             buildConfigField "boolean""LEO_DEBUG""true"  
  17.    
  18.             versionNameSuffix "-debug"  
  19.             minifyEnabled false  
  20.             zipAlignEnabled false  
  21.             shrinkResources false  
  22.             signingConfig signingConfigs.debug  
  23.         }  
  24.     }  

语法为:


buildConfigField "boolean", "LEO_DEBUG", "true"
上述语法就定义了一个boolean类型的LEO_DEBUG字段,值为true,之后我们就可以在程序中使用BuildConfig.LEO_DEBUG字段来判断我们所处的api环境。例如:
  1. @Override  
  2.   protected void onCreate(Bundle savedInstanceState) {  
  3.       super.onCreate(savedInstanceState);  
  4.   
  5.       setContentView(R.layout.activity_main);  
  6.   
  7.       CommonUtils.getVersionName(this);  
  8.   
  9.       initViews();  
  10.   
  11.       if(BuildConfig.LEO_DEBUG) {  
  12.           Log.i("leo""MainActivity.onCreate()");  
  13.       }  
  14.   }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值