• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# HiChecker开发指导
2
3
4## 概述
5
6HiChecker是OpenHarmony提供的用于检测代码错误使用方式和运行结果的一种检测框架,可在应用和系统开发阶段用于运行时的缺陷扫描。本章节内容适用于标准系统。
7
8
9## 开发指导
10
11
12### 场景介绍
13
14HiChecker的主要作用是给基于OpenHarmony的应用(包含系统和三方应用)开发者提供一套检测工具,用来检测应用程序开发过程中容易被人忽略的部分问题,包括应用关键线程调用耗时函数、应用进程中事件出现分发、执行超时以及应用进程中元能力资源泄露等,检测到的问题以日志记录或进程崩溃等形式展现出来以便开发者发现并修改相关问题。
15
16
17### 接口说明
18
19HiChecker提供的主要接口及功能如下:
20
21  **表1** HiChecker函数接口
22
23| **类** | **方法(包括返回值、方法名、参数列表)** | **描述** |
24| -------- | -------- | -------- |
25| HiChecker | uint_64_t&nbsp;RULE_CAUTION_PRINT_LOG<br/>=&nbsp;1&lt;&lt;63; | 告警规则,当有告警时记录日志。 |
26|| uint_64_t&nbsp;RULE_CAUTION_TRIGGER_CRASH&nbsp;=&nbsp;1&lt;&lt;62; | 告警规则,当有告警时让应用退出。 |
27|| uint_64_t&nbsp;RULE_THREAD_CHECK_SLOW_PROCESS&nbsp;=&nbsp;1; | 检测规则,检测是否有耗时函数被调用。 |
28|| uint_64_t&nbsp;RULE_CHECK_SLOW_EVENT&nbsp;=&nbsp;1&lt;&lt;32; | 检测规则,检测有事件分发或处理超过规定的时间阈值。 |
29|| uint_64_t&nbsp;RULE_CHECK_ABILITY_CONNECTION_LEAK&nbsp;=&nbsp;1&lt;&lt;33; | 检测规则,检测ability泄露。 |
30|| AddRule(uint_64_t&nbsp;rule)&nbsp;:&nbsp;void | 添加一条或者多条规则到系统,系统根据添加的规则进行检测或反馈。 |
31|| RemoveRule(uint_64_t&nbsp;rule)&nbsp;:&nbsp;void | 删除一组规则,删除的规则后续将不再生效。 |
32|| GetRule()&nbsp;:&nbsp;uint_64_t | 获取当前线程规则、进程规则、告警规则的合集。 |
33|| Contains(uint_64_t&nbsp;rule)&nbsp;:&nbsp;bool | 当前已添加的规则集中是否包含了某一个特定的规则,&nbsp;如果传入的rule是线程级别的rule,仅查询当前线程中是否包含。 |
34|| NotifySlowProcess(std::string&nbsp;tag)&nbsp;:&nbsp;void | 通知有慢处理,通知系统当前代码调用了耗时较长的慢处理流程,以告知应用重要线程中尽量避开直接调用。 |
35|| NotifySlowEvent(std::string&nbsp;tag)&nbsp;:&nbsp;void | 通知发生事件分发超时或执行超时。 |
36|| NotifyAbilityConnectionLeak(Caution&nbsp;caution)&nbsp;:&nbsp;void | 通知发生AbilityConnection泄露。 |
37| Caution | GetTriggerRule()&nbsp;:&nbsp;uint_64_t | 获取触发当前告警的检测规则。 |
38|| GetCautionMsg()&nbsp;:&nbsp;std::string | 获取更多辅助信息。 |
39|| GetStackTrace()&nbsp;:&nbsp;std::string | 获取告警触发时的堆栈信息。 |
40
41
42### 开发实例
43
44C++使用示例
45
461. 在使用hichecker功能相关的代码文件中,包含hichecker头文件:
47
48   ```
49   #include "hichecker.h"
50   ```
51
52   如果非DFX子系统,需要加上HiviewDFX域。
53
54
55   ```
56   using namespace OHOS::HiviewDFX;
57   ```
58
59   通过静态调用使用相关接口。
60
61
62   ```
63   HiChecker::AddRule(Rule::RULE_THREAD_CHECK_SLOW_PROCESS); //添加一条规则
64   HiChecker::AddRule(Rule::RULE_CHECK_SLOW_EVENT | Rule::RULE_CAUTION_PRINT_LOG); //添加多条规则
65   HiChecker::Contains(Rule::RULE_CAUTION_PRINT_LOG); // true
66   HiChecker::GetRule(); //RULE_THREAD_CHECK_SLOW_PROCESS | RULE_CHECK_SLOW_EVENT | RULE_CAUTION_PRINT_LOG
67   ```
68
69   当规则被触发时,根据添加的告警规则执行告警(默认为写日志)。
70
71   - RULE_CAUTION_PRINT_LOG
72      日志输出触发告警的规则、线程ID、线程名、堆栈等信息。
73
74   - RULE_CAUTION_TRIGGER_CRASH
75      进程直接退出,日志输出退出提示以及辅助信息。
76
77   通知接口的使用:
78
79   - NotifySlowProcess(std::string tag)
80      通知系统当前代码调用了耗时较长的慢处理流程,入参示例:
81
82
83      ```
84      “threadId:xx,threadName:xx,actualTime:xx,delayTime:xx“
85      ```
86
87   - NotifySlowEvent(std::string tag)
88      通知发生事件分发超时或执行超时,入参示例:
89
90
91      ```
92      “threadId:xx,threadName:xx,eventName:xx,actualTime:xx,delayTime:xx“
93      ```
94
95   - NotifyAbilityConnectionLeak(Caution caution)
96      通知发生AbilityConnection泄露,入参示例:传入一个Caution实例。
97
98
99      ```
100      Caution caution(Rule::RULE_CHECK_ABILITY_CONNECTION_LEAK , cautionMessage, stackTrace)
101      // cautionMessage与其它通知接口类似
102      // stackTrace为发生泄露时的堆栈信息
103      ```
104
1052. 编译设置,在引入hichecker相关模块的BUILD.gn里增加子系统依赖:
106
107   ```
108   include_dirs = [ "//base/hiviewdfx/interfaces/innerkits/libhichecker/include" ]
109   external_deps = [ "hichecker_native:libhichecker" ]
110   ```
111