【鸿蒙学院】调试鸿蒙(HarmonyOS)App源代码的两种方式_鸿蒙编辑器怎么调试代码

图2 调试运行按钮

如果未遇到断点,点击该按钮会正常运行程序,一旦遇到断点,程序执行就会在断点处停止执行。知道按F7或F8键才继续一行一行执行程序,以便监控程序中的相关变量的状态。F7表示Step Into,F8表示Step Over。其中Step Into表示会跟踪到方法内部,例如,当前正在执行一个方法,按F7键会继续跟踪到方法内部,然后继续一行一行代码执行。Step Over会将方法当做一行代码执行,不会跟踪到方法内部。所以如果认为某一个方法肯定没有问题,就按F8,如果认为该方法可能会有一些问题,就按F7。

调试过程的效果如图3所示。我们可以看到,在下方的Variables视图中会显示相关变量的当前值。

图3 调试代码

2. 输出日志

另外一种调试代码的方式就是输出日志,可以直接使用System.out.println(…)的方式将信息输出到LogCat视图中,例如,执行下面的代码,会在LogCat视图中看到如图4所示的信息。

System.out.println("hello world"); 

图4在LogCat视图中输出的调试信息

HarmonyOS还提供了另外一种输出日志的方式,这就是HiLog类,该类提供了多个静态方法,用于输出不同级别的日志信息。这些静态方法如表1所示。

表1 HiLog类中用于输出日志信息的方法

方法名功能
debug用于输出调试日志信息
info用于输出普通的日志信息
warn用于输出警告日志信息
error用于输出普通错误日志信息
fatal用于输出致命错误日志信息

这5个方法的参数完全相同,例如,error方法的原型如下:

public static int error(HiLogLabel label, String format, Object... args);

其中label参数表示输出日志的相关信息,类型是HiLogLabel对象,format表示要输出的日志文本(可以包括格式化占位符),args参数表示格式化的参数值,是可选的参数。

使用输出日志方法的案例如下:

HiLogLabel label = new HiLogLabel(HiLog.LOG_APP ,223, "MY_TAG");
HiLog.error(label, "这是一行错误信息,原因:%{private}s","Url不可访问");
HiLog.warn(label,"这是一个警告,原因是:%{public}s", "变量的值可能是负数"); 

其中HiLogLabel构造方法的第1个参数表示日志类型,目前只能是HiLog.LOG_APP,后续会开放更多的日志类型。第2个参数是domain,就是一个整数类型,第3个参数是日志的标签。Domain和日志标签都会以某种形式显示在日志信息上。

在输出日志信息时,运行格式化日志信息,也就是为日志信息指定占位符。占位符需要在%和符号(如s、d)之间加{private}或{public},如果加{private},输出的信息就是,也就是说会隐藏占位符对应的信息,如果加{public},则输出原始的占位符信息。Domain在输出时被转换为十六进制数放到标签的前面,中间用斜杠(/)分隔。

执行这段代码,会在HiLog视图中输出如图5所示的日志信息。

图5 在HiLog视图输出日志信息

使用error方法会输出深红色的日志信息,日志的内容与其他方法输出的日志内容相同。不过要注意,使用HiLog的相关方法输出的日志分为5个级别,分别是DEBUG(调试)、INFO(信息)、WARN(警告)、ERROR(错误)、FATAL(致命错误)。这5个级别分别用5个整数表示,这些整数都在HiLog类中定义,代码如下:

public final class HiLog {
    public static final int DEBUG = 3;
    public static final int INFO = 4;
    public static final int WARN = 5;
    public static final int ERROR = 6;
    public static final int FATAL = 7;
    … …
} 

如果要在HiLog视图中过滤这些级别的信息。只有不大于当前级别的信息才会给显示。例如,要过滤WARN信息,只有DEBUG、INFO和WARN这3类信息才会被显示,由于ERROR和FATAL的值逗比WARN大,所以这两类信息不会被显示。

  • EOF -

推荐阅读  点击标题可跳转

1.开发跨设备的鸿蒙(HarmonyOS) App

2.鸿蒙(HarmonyOS)大神都喜欢玩命令行

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数HarmonyOS鸿蒙开发工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年HarmonyOS鸿蒙开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上HarmonyOS鸿蒙开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注鸿蒙获取)
img

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

…(img-O1tlOrMM-1712873304917)]

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 15
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值