HarmonyOS NEXT实战:日志工具

##HarmonyOS Next实战##HarmonyOS SDK应用服务##教育##

目标:封装日志工具,实现日志工具简单可用。

在应用开发过程中,可在关键代码处输出日志信息。在运行应用后,通过查看日志信息来分析应用执行情况(如应用是否正常运行、代码运行时序、运行逻辑分支是否正常等)。

系统提供不同的API供开发者调用并输出日志信息,即HiLog与console。两个API在使用时略有差异,本文重点介绍HiLog的用法,console的具体用法可查看API参考console。

HiLog中定义了DEBUG、INFO、WARN、ERROR、FATAL五种日志级别,并提供了对应的方法输出不同级别的日志。

参数解析

  • domain:用于指定输出日志所对应的业务领域,取值范围为0x0000~0xFFFF,开发者可以根据需要进行自定义。
  • tag:用于指定日志标识,可以为任意字符串,建议标识调用所在的类或者业务行为。tag最多为31字节,超出后会截断,不建议使用中文字符,可能出现乱码或者对齐问题。
  • level:用于指定日志级别。取值见LogLevel。
  • format:格式字符串,用于日志的格式化输出。日志打印的格式化参数需按照“%{private flag}specifier”的格式打印。

说明

  • isLoggable()和具体日志打印接口使用的domain和tag应保持一致。
  • isLoggable()使用的level,应和具体日志打印接口级别保持一致。

约束与限制:日志最多打印4096字节,超出限制文本将被截断。

实战:

import { hilog } from **********';

/**
 * 日志级别
 */
export enum LogLevel {
  debug = "debug",
  info = "info",
  warn = 'warn',
  error = "error"
}

/**
 * 日志工具
 * ###待考虑:设置打印日志级别
 */
export class LoggerKit {
  private domain: number;
  private prefix: string;
  private enableLogLevels: LogLevel[];

  /**
   * 日志记录器工具
   * @param domain 域,默认:0xABCD
   * @param prefix 前缀,默认:LoggerKit
   * @param enableLogLevels 启用日志级别,默认:全部启用
   */
  constructor(domain: number = 0xABCD, prefix: string = 'LoggerKit',
    enableLogLevels = [LogLevel.debug, LogLevel.info, LogLevel.warn, LogLevel.error]) {
    this.domain = domain;
    this.prefix = prefix;
    this.enableLogLevels = enableLogLevels;
  }

  debug(...args: string[]) {
    if (this.enableLogLevels.includes(LogLevel.debug)) {
      hilog.debug(this.domain, this.prefix, getFormat(args), args);
    }
  }

  info(...args: string[]) {
    if (this.enableLogLevels.includes(LogLevel.info)) {
      hilog.info(this.domain, this.prefix, getFormat(args), args);
    }
  }

  warn(...args: string[]) {
    if (this.enableLogLevels.includes(LogLevel.warn)) {
      hilog.warn(this.domain, this.prefix, getFormat(args), args);
    }
  }

  error(...args: string[]) {
    if (this.enableLogLevels.includes(LogLevel.error)) {
      hilog.error(this.domain, this.prefix, getFormat(args), args);
    }
  }

  static LK_domain: number = 0xABCD;
  static LK_prefix: string = 'LoggerKit';
  static LK_enableLogLevels: LogLevel[] = [LogLevel.debug, LogLevel.info, LogLevel.warn, LogLevel.error];

  static debug(...args: string[]) {
    if (LoggerKit.LK_enableLogLevels.includes(LogLevel.debug)) {
      hilog.debug(LoggerKit.LK_domain, LoggerKit.LK_prefix, getFormat(args), args);
    }
  }

  static info(...args: string[]) {
    if (LoggerKit.LK_enableLogLevels.includes(LogLevel.info)) {
      hilog.info(LoggerKit.LK_domain, LoggerKit.LK_prefix, getFormat(args), args);
    }
  }

  static warn(...args: string[]) {
    if (LoggerKit.LK_enableLogLevels.includes(LogLevel.warn)) {
      hilog.warn(LoggerKit.LK_domain, LoggerKit.LK_prefix, getFormat(args), args);
    }
  }

  static error(...args: string[]) {
    if (LoggerKit.LK_enableLogLevels.includes(LogLevel.error)) {
      hilog.error(LoggerKit.LK_domain, LoggerKit.LK_prefix, getFormat(args), args);
    }
  }
}

function getFormat(args: string[]) {
  let format = ''
  for (let i = 0; i < args.length; i++) {
    if (i == 0) {
      format = '%{public}s'
    } else {
      format += ', %{public}s'
    }
  }
  return format
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
06-24 14:18
点赞 评论 收藏
分享
05-26 22:25
门头沟学院 Java
Java小肖:不会是想叫你过去把你打一顿吧,哈哈哈
点赞 评论 收藏
分享
Yki_:你要算时间成本呀,研究生两三年,博士三四年,加起来就五六年了,如果你本科去腾讯干五年,多领五年的年薪,加上公司内涨薪,可能到时候十五年总薪资也跟博士差不多
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务