成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

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

[[409611]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

前言

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

背景

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

組件效果展示

1、測試界面。

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

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術社區

圖1 測試界面UI圖

2、Log打印

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

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術社區
鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術社區

圖2 HiLog日志打印

Sample解析

1、Tree的使用

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

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

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

2、Sample的實現

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

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

步驟2. 創建整體的顯示布局。

步驟3. 導入相關類并設置按鈕監聽。

步驟4. 使用Tree實例。

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

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

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

復制(2)創建整體的顯示布局 在XML文件中創建一個DirectionalLayout作為整體顯示布局,寬度和高度都跟隨父控件變化而調整。創建兩個組件,分別是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)導入顯示布局并設置按鈕監聽

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

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

 (4)使用Tree實例

當用戶需要打印調試日志的時候,調用Timber的靜態方法,就會在鴻蒙常規HiLog上出現調試日志。調試日志如組件效果展示部分的圖2所示。

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

Library解析

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

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術社區

圖3 調用順序圖

下面我們著重介紹樹(Tree類)在Library中的實現,核心算法prepareLog()內部的邏輯結構這兩個方面的內容。

1.樹(Tree)的實現

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

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

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

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

(2)種樹。

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

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

  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實例

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

  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實例,將會自動生成一個對應的新的Tree數組,而forestAsArray就是這個數組的引用。因此forestAsArray 數組被設置為空數組。

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

 (5) 靈魂之樹(TREE_OF_SOULS)

估計很多同學好奇上述TREE_OF_SOULS。代碼實現中,在這里運用的是經典設計模式中的代理模式,TREE_OF_SOULS 本質上是一個代理對象,森林中所有其他普通的樹對象都是被代理對象,代理對象通過 for 循環來依次調用被代理對象的同名方法,從而實現不同類型的日志記錄,如下所示。

  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()方法中,該方法接收四個參數,如圖4所示:

鴻蒙開源第三方組件——日志工具組件Timber_ohos-鴻蒙HarmonyOS技術社區

圖4 參數表

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

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

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

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

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

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

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

  1. private void prepareLog(int priority, Throwable t, String message, Object... args) { 
  2.       //獲取當前線程的 tag 
  3.       String tag = getTag(); 
  4.       //當正常信息message不為null且信息長度為0時,這時正常信息message為null 
  5.       if (message != null && message.length() == 0) { 
  6.         message = null
  7.       } 
  8.       //當正常信息 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 方法轉換為字符串 
  14.         message = getStackTraceString(t); 
  15.       } else { 
  16.         if (args != null && args.length > 0) { 
  17.     //正常信息 message 和可選格式化參數 args 通過 formatMessage 方法拼裝成一個字符串 
  18.           message = formatMessage(message, args); 
  19.         } 
  20.         if (t != null) { 
  21.           message += "\n" + getStackTraceString(t); 
  22.         } 
  23.       } 
  24.       //調用抽象方法 log 進行日志記錄,這個方法由 Tree 的子類來實現 
  25.       log(priority, tag, message, t); 
  26.     } 

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-04-20 15:06:42

鴻蒙HarmonyOS應用

2021-04-08 14:57:52

鴻蒙HarmonyOS應用

2021-08-30 17:55:58

鴻蒙HarmonyOS應用

2021-11-17 15:37:43

鴻蒙HarmonyOS應用

2021-07-20 15:20:40

鴻蒙HarmonyOS應用

2021-04-15 17:47:38

鴻蒙HarmonyOS應用

2021-11-02 14:54:21

鴻蒙HarmonyOS應用

2021-08-10 15:23:08

鴻蒙HarmonyOS應用

2021-10-19 10:04:51

鴻蒙HarmonyOS應用

2021-04-29 14:32:24

鴻蒙HarmonyOS應用

2021-03-10 15:03:40

鴻蒙HarmonyOS應用

2021-06-29 09:28:16

鴻蒙HarmonyOS應用

2021-06-17 14:56:00

鴻蒙HarmonyOS應用

2021-03-24 09:30:49

鴻蒙HarmonyOS應用

2021-07-28 09:40:04

鴻蒙HarmonyOS應用

2021-03-03 09:42:26

鴻蒙HarmonyOS圖片裁剪

2021-08-03 10:07:41

鴻蒙HarmonyOS應用

2021-08-26 16:07:46

鴻蒙HarmonyOS應用

2021-03-01 14:00:11

鴻蒙HarmonyOS應用

2021-08-05 15:06:30

鴻蒙HarmonyOS應用
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费观看黄a一级视频 | 欧美日韩专区 | 国产精品久久久久久久三级 | 日韩字幕| 精品一区二区三区四区在线 | 精品视频一区二区三区 | 日本午夜网站 | 久久久av一区 | 欧美日本在线观看 | 一区二区不卡视频 | 欧美日韩成人在线观看 | 亚洲 成人 在线 | 久久精品二区 | 亚洲色片网站 | 亚洲免费在线视频 | 国产探花在线精品一区二区 | 亚洲欧美中文日韩在线v日本 | 一级黄色片在线看 | 亚洲一区二区精品 | 日韩欧美在线免费观看 | 国产激情毛片 | 国产一区二区精品在线 | 免费毛片网 | 欧美一级片在线看 | 国产精品伦一区二区三级视频 | 久久久久国产精品一区 | 日韩三级在线观看 | 99热.com| 久久久久国产一区二区三区四区 | 亚洲精品久久久久久下一站 | 亚洲精品国产a久久久久久 中文字幕一区二区三区四区五区 | 欧美激情精品久久久久久变态 | 不用播放器看的av | 久久大陆 | 亚洲视频一区在线 | 久久久久久久国产精品 | 国产一区视频在线 | 欧美电影网 | 国产 欧美 日韩 一区 | 韩日精品视频 | 九一精品 |