偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

鴻蒙開源第三方組件—日志工具組件Timber_ohos

系統(tǒng)
Timber_ohos是一個帶有小型可擴展API的日志工具組件,它可以給開發(fā)者提供統(tǒng)一的API接口,來記錄不同類型的日志,幫助開發(fā)者管理不同類型的log。

[[409611]]

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

前言

基于安卓平臺的日志工具組件Timber ( https://github.com/JakeWharton/timber), 實現(xiàn)鴻蒙的功能化遷移和重構(gòu)。代碼已經(jīng)開源到(https://gitee.com/isrc_ohos/timber_ohos),歡迎各位開發(fā)者提出寶貴意見。

背景

Timber_ohos是一個帶有小型可擴展API的日志工具組件,它可以給開發(fā)者提供統(tǒng)一的API接口,來記錄不同類型的日志,幫助開發(fā)者管理不同類型的log。同時,Timber_ohos是項目開發(fā)時的log開關(guān),通過此開關(guān)控制log的打印與關(guān)閉,從而形成不同的軟件版本。該組件功能豐富且使用簡單高效,可以被廣泛應(yīng)用于軟件項目開發(fā)中。

組件效果展示

1、測試界面。

如圖1所示,這是一個為了測試Timber_ohos功能而簡單構(gòu)建的UI頁面。點擊“測試”按鈕即可輸出相應(yīng)的log。

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術(shù)社區(qū)

圖1 測試界面UI圖

2、Log打印

Timber類的靜態(tài)方法調(diào)用如圖2中的(a)圖所示。運行項目后查看HiLog顯示,可以看到實時打印出來的日志,如圖2中的(b)圖所示。

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術(shù)社區(qū)
鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術(shù)社區(qū)

圖2 HiLog日志打印

Sample解析

1、Tree的使用

Timber_ohos將不同的日志操作以樹(Tree)的概念進行表示,種植一種樹就擁有一種日志記錄功能,種植多種樹就擁有多種日志記錄的功能,樹的種類有很多,常見的樹有:DebugTree、RealeseTree、FileTree、CrashReportingTree等,這些樹都是繼承自Tree類。

  • DebugTree:對所有的日志進行記錄。
  • RealeseTree:只對 warn,error,wtf 信息進行記錄。
  • FileTree:在運行時將日志記錄到文件中。
  • CrashReportingTree:對應(yīng)用崩潰時的信息進行記錄。

Timber_ohos中默認已經(jīng)種植了DebugTree,由于Timber_ohos本身是一個可擴展的框架,因此開發(fā)者想得到其他類型的Log日志時,就需要自己實現(xiàn)一個日志記錄類 ,然后種植到Timber_ohos中即可。

2、Sample的實現(xiàn)

Sample部分需要添加日志記錄種類,并負責(zé)整體顯示布局的搭建。首先為Timber_ohos組件添加想要的任何Tree子類實例(這里使用的是DebugTree),然后設(shè)置簡單的按鈕監(jiān)聽器,當(dāng)按動按鈕時在鴻蒙常規(guī)HiLog中出現(xiàn)調(diào)試日志。下面將詳細介紹組件的使用方法。

步驟1. 種樹(添加Tree子類實例)。

步驟2. 創(chuàng)建整體的顯示布局。

步驟3. 導(dǎo)入相關(guān)類并設(shè)置按鈕監(jiān)聽。

步驟4. 使用Tree實例。

(1)種樹(添加Tree子類實例)

本步驟是在ExampleApp類的onInitialize()方法中實現(xiàn)的。首先需要創(chuàng)建Tree子類實例,然后調(diào)用Timber的plant()方法,同時將實例作為plant()方法的參數(shù),這個過程叫做“種樹”。

  1. Timber.plant(new Timber.DebugTree(0x001f00)); 

復(fù)制(2)創(chuàng)建整體的顯示布局 在XML文件中創(chuàng)建一個DirectionalLayout作為整體顯示布局,寬度和高度都跟隨父控件變化而調(diào)整。創(chuàng)建兩個組件,分別是Text組件和Button組件,用于控制組件效果顯示。整體顯示布局如圖1所示。

  1. <DirectionalLayout 
  2.     xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  3.     ohos:height="match_parent" 
  4.     ohos:width="match_parent" 
  5.     ohos:orientation="vertical" 
  6.     ohos:padding="32vp" 
  7.     ohos:background_element="#ffffff" 
  8.     ohos:alignment="horizontal_center"
  9.     <Text   //“測試”提示 
  10.         ohos:height="match_content" 
  11.         ohos:width="match_content" 
  12.         ohos:layout_alignment="horizontal_center" 
  13.         ohos:text="Timber測試" 
  14.         ohos:text_size="35fp"/> 
  15.     <Button  //控制按鈕 
  16.         ohos:id="$+id:btn1" 
  17.         ohos:height="match_content" 
  18.         ohos:width="match_content" 
  19.         ohos:top_margin="35vp" 
  20.         ohos:text_size="25fp" 
  21.         ohos:background_element="#FF51A8DD" 
  22.         ohos:padding="10vp" 
  23.         ohos:text="測試"/> 
  24. </DirectionalLayout> 

 (3)導(dǎo)入顯示布局并設(shè)置按鈕監(jiān)聽

在MainAbilitySlice中,整體顯示布局也需要通過super.setUIContent()方法進行設(shè)置,才能生效并成功顯示。然后給按鈕設(shè)置點擊事件,當(dāng)用戶需要使用Tree子類實例時,可通過手指進行點擊。

  1. super.setUIContent(ResourceTable.Layout_ability_main);//設(shè)置整體顯示布局 
  2. findComponentById(ResourceTable.Id_btn1).setClickedListener(new Component.ClickedListener() { 
  3.     ...//按鈕的點擊事件 

 (4)使用Tree實例

當(dāng)用戶需要打印調(diào)試日志的時候,調(diào)用Timber的靜態(tài)方法,就會在鴻蒙常規(guī)HiLog上出現(xiàn)調(diào)試日志。調(diào)試日志如組件效果展示部分的圖2所示。

  1. Timber.e  ("Timber.e 測試成功?。。?quot;); 
  2. Timber.d  ("Timber.d 測試成功?。?!"); 
  3. Timber.i  ("Timber.i 測試成功!?。?quot;); 
  4. Timber.w   ("Timber.w 測試成功?。?!"); 
  5. Timber.wtf   ("Timber.wtf測試成功?。?!"); 

Library解析

Library主要為Timber_ohos組件提供日志輸出的統(tǒng)一接口。以Sample中種植的調(diào)試樹(DebugTree)為例,當(dāng)使用Timber的靜態(tài)方法Timber.e時,從MainAbilitySlice到Timber.e打印log的地方可以分為5個步驟,整體調(diào)用的流程如圖3所示。

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術(shù)社區(qū)

圖3 調(diào)用順序圖

下面我們著重介紹樹(Tree類)在Library中的實現(xiàn),核心算法prepareLog()內(nèi)部的邏輯結(jié)構(gòu)這兩個方面的內(nèi)容。

1.樹(Tree)的實現(xiàn)

Tree類是一種概念形式的日志操作,具體可分為(DebugTree、ReleaseTree、FileTree等)。而在Library內(nèi)部,Tree類也實現(xiàn)了一系列方法,以便于對森林中的各類樹進行增加、刪除、修改等操作。

(1)在Timber_ohos組件中維護一個森林對象(FOREST)。

森林對象由不同類型的日志樹組合而成,并提供對外的接口進行日志的打印。每種類型的樹都可以通過種植操作來把自己添加到森林對象中,或者通過移除操作從森林對象中刪除,從而實現(xiàn)該類型日志記錄的開啟和關(guān)閉。

  1. private static final List<Tree> FOREST = new ArrayList<>();  

(2)種樹。

調(diào)用plant()方法,把Tree實例添加進FOREST里面 可以種植一棵樹,也可以種植多棵樹。這里以種一棵樹為例??梢钥吹?,樹的種植是在plant()靜態(tài)方法的synchronized 同步代碼塊中進行的。具體流程是先將樹對象添加到 FOREST 列表中,然后將日志樹保存到 forestAsArray 數(shù)組中(將樹種植到森林中)。

需要注意的是,如果樹為空,則拋出空指針異常的錯誤;如果開發(fā)者手動種植靈魂之樹(TREE_OF_SOULS),Timber_ohos將會拋出非法數(shù)據(jù)異常。

  1. public static void plant(@NotNull Tree tree) { 
  2.   if (tree == null) { 
  3.     throw new NullPointerException("tree == null"); 
  4.   } 
  5.   if (tree == TREE_OF_SOULS) { 
  6.     throw new IllegalArgumentException("Cannot plant Timber into itself."); 
  7.   } 
  8.   synchronized (FOREST) { 
  9.     FOREST.add(tree); 
  10.     forestAsArray = FOREST.toArray(new Tree[FOREST.size()]); 
  11.   } 

 (3)移除Tree實例

同樣的,樹的移除也是在靜態(tài)方法uproot()中的synchronized 同步代碼塊中進行的。如果沒有該樹可以移除,則Timber_ohos組件將拋出一個非法數(shù)據(jù)異常;反之,Timber_ohos組件將根據(jù)移除該樹后的 FOREST列表生成 新的forestAsArray 數(shù)組。

  1. public static void uproot(@NotNull Tree tree) { 
  2.   synchronized (FOREST) { 
  3.     if (!FOREST.remove(tree)) { 
  4.       throw new IllegalArgumentException("Cannot uproot tree which is not planted: " + tree); 
  5.     } 
  6.     forestAsArray = FOREST.toArray(new Tree[FOREST.size()]); 
  7.   } 

 (4)清除森林里面全部的Tree實例

移除森林里所有的Tree實例,首先使用FOREST的clear()方法清除所有的Tree實例,將會自動生成一個對應(yīng)的新的Tree數(shù)組,而forestAsArray就是這個數(shù)組的引用。因此forestAsArray 數(shù)組被設(shè)置為空數(shù)組。

  1. public static void uprootAll() { 
  2.   synchronized (FOREST) { 
  3.     FOREST.clear(); 
  4.     forestAsArray = TREE_ARRAY_EMPTY; 
  5.   } 

 (5) 靈魂之樹(TREE_OF_SOULS)

估計很多同學(xué)好奇上述TREE_OF_SOULS。代碼實現(xiàn)中,在這里運用的是經(jīng)典設(shè)計模式中的代理模式,TREE_OF_SOULS 本質(zhì)上是一個代理對象,森林中所有其他普通的樹對象都是被代理對象,代理對象通過 for 循環(huán)來依次調(diào)用被代理對象的同名方法,從而實現(xiàn)不同類型的日志記錄,如下所示。

  1. private static final Tree TREE_OF_SOULS = new Tree() { 
  2.   @Override public void v(String message, Object... args) { 
  3.     Tree[] forest = forestAsArray; 
  4.     for (Tree tree : forest) { 
  5.       tree.v(message, args); 
  6.     } 
  7.   } 

2.核心算法( prepareLog)

Timber_ohos組件的日志記錄功能的核心算法在抽象類 Tree 的私有化 prepareLog()方法中,該方法接收四個參數(shù),如圖4所示:

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術(shù)社區(qū)

圖4 參數(shù)表

prepareLog()中首先判斷了打log的條件,然后將要打印的message信息進行了處理,最后調(diào)用了抽象方法log進行日志輸出??傮w而言 prepareLog()算法流程如下:

(1)獲取當(dāng)前線程的 tag。

(2)當(dāng)正常信息message不為null且信息長度為0時,這時正常信息message為null。

(3)當(dāng)正常信息message和異常信息t都是 null 時,說明沒有信息可以記錄,方法直接返回。

(4)異常信息t通過getStackTraceString方法轉(zhuǎn)換為字符串。

(5)正常信息message和可選格式化參數(shù) args 通過formatMessage方法拼裝成一個字符串。

(6)調(diào)用抽象方法 log 進行日志記錄,這個方法由Tree的子類來實現(xiàn)。

  1. private void prepareLog(int priority, Throwable t, String message, Object... args) { 
  2.       //獲取當(dāng)前線程的 tag 
  3.       String tag = getTag(); 
  4.       //當(dāng)正常信息message不為null且信息長度為0時,這時正常信息message為null 
  5.       if (message != null && message.length() == 0) { 
  6.         message = null
  7.       } 
  8.       //當(dāng)正常信息 message 和異常信息 t 都是 null 時,說明沒有信息可以記錄,方法直接返回 
  9.       if (message == null) { 
  10.         if (t == null) { 
  11.           return; // Swallow message if it's null and there'no throwable. 
  12.         } 
  13.         //異常信息 t 通過 getStackTraceString 方法轉(zhuǎn)換為字符串 
  14.         message = getStackTraceString(t); 
  15.       } else { 
  16.         if (args != null && args.length > 0) { 
  17.     //正常信息 message 和可選格式化參數(shù) args 通過 formatMessage 方法拼裝成一個字符串 
  18.           message = formatMessage(message, args); 
  19.         } 
  20.         if (t != null) { 
  21.           message += "\n" + getStackTraceString(t); 
  22.         } 
  23.       } 
  24.       //調(diào)用抽象方法 log 進行日志記錄,這個方法由 Tree 的子類來實現(xiàn) 
  25.       log(priority, tag, message, t); 
  26.     } 

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

 

責(zé)任編輯:jianghua 來源: 鴻蒙社區(qū)
相關(guān)推薦

2021-08-30 17:55:58

鴻蒙HarmonyOS應(yīng)用

2021-04-20 15:06:42

鴻蒙HarmonyOS應(yīng)用

2021-04-08 14:57:52

鴻蒙HarmonyOS應(yīng)用

2021-07-20 15:20:40

鴻蒙HarmonyOS應(yīng)用

2021-04-15 17:47:38

鴻蒙HarmonyOS應(yīng)用

2021-11-17 15:37:43

鴻蒙HarmonyOS應(yīng)用

2021-11-02 14:54:21

鴻蒙HarmonyOS應(yīng)用

2021-06-29 09:28:16

鴻蒙HarmonyOS應(yīng)用

2021-08-10 15:23:08

鴻蒙HarmonyOS應(yīng)用

2021-10-19 10:04:51

鴻蒙HarmonyOS應(yīng)用

2021-03-24 09:30:49

鴻蒙HarmonyOS應(yīng)用

2021-03-10 15:03:40

鴻蒙HarmonyOS應(yīng)用

2021-04-29 14:32:24

鴻蒙HarmonyOS應(yīng)用

2021-07-28 09:40:04

鴻蒙HarmonyOS應(yīng)用

2021-06-17 14:56:00

鴻蒙HarmonyOS應(yīng)用

2021-03-03 09:42:26

鴻蒙HarmonyOS圖片裁剪

2021-08-26 16:07:46

鴻蒙HarmonyOS應(yīng)用

2021-03-01 14:00:11

鴻蒙HarmonyOS應(yīng)用

2021-08-03 10:07:41

鴻蒙HarmonyOS應(yīng)用

2021-08-05 15:06:30

鴻蒙HarmonyOS應(yīng)用
點贊
收藏

51CTO技術(shù)棧公眾號