zoukankan      html  css  js  c++  java
  • iOS项目之使用开关控制日志输出的功能

      最近一直在做sdk的项目,用户提出了一个需求,需要屏蔽sdk内部的日志输出。由于sdk内部的日志是为了调试,如果屏蔽了肯定不方便,所以研究了一下日志输出开关的功能。

      在这里介绍两种实现方案:一种方案是使用NSUserDefaults,一种方案是使用自定义类来控制。

      第一种方案:NSUserDefaults

      这种方案比较简单,主要使用NSUserDefaults来存储日志输出的状态。直接上代码:

     // 日志状态获取
    [[[NSUserDefaults standardUserDefaults] valueForKey:@"kLogEnable"] boolValue];
    
    
     // 日志状态修改
    NSUserDefaults *userD = [NSUserDefaults standardUserDefaults];
    [userD setValue:@(s.isOn) forKey:@"kLogEnable"];
    [userD synchronize];

      然后在.pch文件中添加宏来进行判断输出日志功能:

    #define customLogEnable   [[[NSUserDefaults standardUserDefaults] valueForKey:@"kLogEnable"] boolValue]
    
    #define FirstMethodLog(format,...)  if(customLogEnable) {
    NSLog((@"%s[%d]" format), __FUNCTION__, __LINE__, ##__VA_ARGS__);
    } else {}

      这样在其他地方使用FirstMethodLog方法来输出日志,就可以实现控制日志输出的功能。

      第二种方案:自定义日志输出管理类CustomLogManager

      首先在.h文件中提供几个方法:

    // 设置日志输出状态
    + (void)setLogEnable:(BOOL)enable;
    
    // 获取日志输出状态
    + (BOOL)getLogEnable;
    
    // 日志输出方法
    + (void)customLogWithFunction:(const char *)function lineNumber:(int)lineNumber formatString:(NSString *)formatString;

      然后在.m文件中,设置静态变量来存储日志输出状态值

    // 默认值为NO
    static BOOL kLogEnable = NO;

      类方法的实现:

    + (void)setLogEnable:(BOOL)enable {
        kLogEnable = enable;
    }
    
    + (BOOL)getLogEnable {
        return kLogEnable;
    }
    
    + (void)customLogWithFunction:(const char *)function lineNumber:(int)lineNumber formatString:(NSString *)formatString {
        
        if ([self getLogEnable]) {
            // 开启了Log
            NSLog(@"%s[%d]%@", function, lineNumber, formatString);
        }
    }

      最后添加宏定义

    #define SecondMethodLog(format,...)  [CutomLogManager customLogWithFunction:__FUNCTION__ lineNumber:__LINE__ formatString:[NSString stringWithFormat:format, ##__VA_ARGS__]]

      这样在其他地方使用SecondMethodLog方法来输出日志,就可以控制日志输出了。

      在这里附上Demo:CustomLogDemo

  • 相关阅读:
    0x00 mysql 的安装,简单mysql命令的使用
    nuxt中定制iview主题颜色
    获取浏览器语言的解决方案
    nuxt页面切换效果
    MySQL(非sql sever)安全体系的学习心得
    My SQL日志 学习心得
    楼梯在SQL Server事务日志管理,三级:事务日志,备份和恢复(16周翻译)
    SQL Server事务日志管理的阶段,1级:事务日志概述
    楼梯在SQL Server事务日志管理,一级:事务日志的概述(15周翻译)
    数据库的独立子查询以及数据的删除、更新和建立视图的笔记
  • 原文地址:https://www.cnblogs.com/sjxjjx/p/8907762.html
Copyright © 2011-2022 走看看