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

HarmonyOS 基礎之線程管理

開發 前端 OpenHarmony
不同應用在各自獨立的進程中運行。當應用以任何形式啟動時,系統為其創建進程,該進程將持續運行。當進程完成當前任務處于等待狀態,且系統資源不足時,系統自動回收。

[[422872]]

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

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

https://harmonyos.51cto.com

概述

不同應用在各自獨立的進程中運行。當應用以任何形式啟動時,系統為其創建進程,該進程將持續運行。當進程完成當前任務處于等待狀態,且系統資源不足時,系統自動回收。

在啟動應用時,系統會為該應用創建一個稱為“主線程”的執行線程。該線程隨著應用創建或消失,是應用的核心線程。UI界面的顯示和更新等操作,都是在主線程上進行。主線程又稱UI線程,默認情況下,所有的操作都是在主線程上執行。如果需要執行比較耗時的任務(如下載文件、查詢數據庫),可創建其他線程來處理。

如果應用的業務邏輯比較復雜,可能需要創建多個線程來執行多個任務。這種情況下,代碼復雜難以維護,任務與線程的交互也會更加繁雜。要解決此問題,開發者可以使用TaskDispatcher來分發不同的任務。

TaskDispatcher介紹

TaskDispatcher是一個任務分發器,它是Ability分發任務的基本接口,隱藏任務所在線程的實現細節。

為保證應用有更好的響應性,我們需要設計任務的優先級。在UI線程上運行的任務默認以高優先級運行,如果某個任務無需等待結果,則可以用低優先級。

線程優先級介紹:

HIGH:最高任務優先級,比默認優先級、低優先級的任務有更高的幾率得到執行。

DEFAULT:默認任務優先級, 比低優先級的任務有更高的幾率得到執行。

LOW:低任務優先級,比高優先級、默認優先級的任務有更低的幾率得到執行。

TaskDispatcher具有多種實現,每種實現對應不同的任務分發器。在分發任務時可以指定任務的優先級,由同一個任務分發器分發出的任務具有相同的優先級。系統提供的任務分發器有GlobalTaskDispatcher、ParallelTaskDispatcher、SerialTaskDispatcher 、SpecTaskDispatcher。

實踐

1.同步派發任務syncDispatch

發任務并在當前線程等待任務執行完成。在返回前,當前線程會被阻塞

  1. /** 
  2.    * 同步派發任務 
  3.    */ 
  4.   private void syncDispatch() { 
  5.       TaskDispatcher globalTaskDispatcher = getGlobalTaskDispatcher(TaskPriority.DEFAULT); 
  6.       globalTaskDispatcher.syncDispatch(new Runnable() { 
  7.           @Override 
  8.           public void run() { 
  9.               HiLog.info(LABEL_LOG, "sync task1 run"); 
  10.           } 
  11.       }); 
  12.       HiLog.info(LABEL_LOG, "after sync task1"); 
  13.  
  14.       globalTaskDispatcher.syncDispatch(new Runnable() { 
  15.           @Override 
  16.           public void run() { 
  17.               HiLog.info(LABEL_LOG, "sync task2 run"); 
  18.           } 
  19.       }); 
  20.       HiLog.info(LABEL_LOG, "after sync task2"); 
  21.  
  22.       globalTaskDispatcher.syncDispatch(new Runnable() { 
  23.           @Override 
  24.           public void run() { 
  25.               HiLog.info(LABEL_LOG, "sync task3 run"); 
  26.           } 
  27.       }); 
  28.       HiLog.info(LABEL_LOG, "after sync task3"); 
  29.   } 

運行之后查看日志:

HarmonyOS 基礎之線程管理-鴻蒙HarmonyOS技術社區

 

從運行結果我們可以看到,只有在當前線程等待任務執行完成之后才會繼續往下執行,否則當前線程會被阻塞,所以在使用syncDispatch的時候我們需要注意,如果對syncDispatch使用不當, 將會導致死鎖。如下情形可能導致死鎖發生:

  • 在專有線程上,利用該專有任務分發器進行syncDispatch。
  • 在被某個串行任務分發器(dispatcher_a)派發的任務中,再次利用同一個串行任務分發器(dispatcher_a)對象派發任務。
  • 在被某個串行任務分發器(dispatcher_a)派發的任務中,經過數次派發任務,最終又利用該(dispatcher_a)串行任務分發器派發任務。例如:dispatcher_a派發的任務使用dispatcher_b進行任務的派發,在dispatcher_b派發的任務中又利用dispatcher_a進行派發任務。
  • 串行任務分發器(dispatcher_a)派發的任務中利用串行任務分發器(dispatcher_b)進行同步派發任務,同時dispatcher_b派發的任務中利用串行任務分發器(dispatcher_a)進行同步派發任務。在特定的線程執行順序下將導致死鎖。

2.異步派發任務asyncDispatch

派發任務,并立即返回,返回值是一個可用于取消任務的接口。

  1. /** 
  2.    * 異步派發任務 
  3.    */ 
  4.   private void asyncDispatch() { 
  5.       TaskDispatcher globalTaskDispatcher = getGlobalTaskDispatcher(TaskPriority.DEFAULT); 
  6.       Revocable revocable = globalTaskDispatcher.asyncDispatch(new Runnable() { 
  7.           @Override 
  8.           public void run() { 
  9.               HiLog.info(LABEL_LOG, "async task1 run"); 
  10.           } 
  11.       }); 
  12.       HiLog.info(LABEL_LOG, "after async task1"); 
  13.   } 

運行之后查看日志:

HarmonyOS 基礎之線程管理-鴻蒙HarmonyOS技術社區

 

從運行結果我們可以看到,只有在當前線程等待任務執行完成之后才會繼續往下執行,否則當前線程會被阻塞,所以在使用

3. 異步延遲派發任務delayDispatch

異步執行,函數立即返回,內部會在延時指定時間后將任務派發到相應隊列中。延時時間參數僅代表在這段時間以后任務分發器會將任務加入到隊列中,任務的實際執行時間可能晚于這個時間。具體比這個數值晚多久,取決于隊列及內部線程池的繁忙情況。

  1. /** 
  2.     * 異步延遲派發任務 
  3.     */ 
  4.    private void delayDispatch() { 
  5.        final long callTime = System.currentTimeMillis(); 
  6.        final long delayTime = 50L; 
  7.        TaskDispatcher globalTaskDispatcher = getGlobalTaskDispatcher(TaskPriority.DEFAULT); 
  8.        Revocable revocable = globalTaskDispatcher.delayDispatch(new Runnable() { 
  9.            @Override 
  10.            public void run() { 
  11.                HiLog.info(LABEL_LOG, "delayDispatch task1 run"); 
  12.                final long actualDelay = System.currentTimeMillis() - callTime; 
  13.                HiLog.info(LABEL_LOG, "actualDelayTime >= delayTime: %{public}b", (actualDelay >= delayTime)); 
  14.            } 
  15.        }, delayTime); 
  16.        HiLog.info(LABEL_LOG, "after delayDispatch task1"); 
  17.    } 

運行之后查看日志:

HarmonyOS 基礎之線程管理-鴻蒙HarmonyOS技術社區

從運行結果我們可以看出,程序首先執行"after delayDispatch task1",然后執行"delayDispatch task1 run",最后執行"actualDelayTime >= delayTime: %{public}b", (actualDelay >= delayTime),這里 actualDelayTime >= delayTime: true可以看出延時時間參數僅代表在這段時間以后任務分發器會將任務加入到隊列中,任務的實際執行時間可能晚于這個時間。

4. 任務組Group

表示一組任務,且該組任務之間有一定的聯系,由TaskDispatcher執行createDispatchGroup創建并返回。將任務加入任務組,返回一個用于取消任務的接口。

  1. /** 
  2.    * 任務組 
  3.    */ 
  4.   private void dispatchGroup() { 
  5.       String dispatcherName = "parallelTaskDispatcher"
  6.       TaskDispatcher dispatcher = createParallelTaskDispatcher(dispatcherName, TaskPriority.DEFAULT); 
  7.       // 創建任務組。 
  8.       Group group = dispatcher.createDispatchGroup(); 
  9.       // 將任務1加入任務組,返回一個用于取消任務的接口。 
  10.       dispatcher.asyncGroupDispatch(group, new Runnable() { 
  11.           @Override 
  12.           public void run() { 
  13.               HiLog.info(LABEL_LOG, "download task1 is running"); 
  14.           } 
  15.       }); 
  16.       // 將與任務1相關聯的任務2加入任務組。 
  17.       dispatcher.asyncGroupDispatch(group, new Runnable() { 
  18.           @Override 
  19.           public void run() { 
  20.               HiLog.info(LABEL_LOG, "download task2 is running"); 
  21.           } 
  22.       }); 
  23.       // 在任務組中的所有任務執行完成后執行指定任務。 
  24.       dispatcher.groupDispatchNotify(group, new Runnable() { 
  25.           @Override 
  26.           public void run() { 
  27.               HiLog.info(LABEL_LOG, "the close task is running after all tasks in the group are completed"); 
  28.           } 
  29.       }); 
  30.   } 

運行之后查看日志:

HarmonyOS 基礎之線程管理-鴻蒙HarmonyOS技術社區

5. 同步設置屏障任務syncDispatchBarrier

在任務組上設立任務執行屏障,同步等待任務組中的所有任務執行完成,再執行指定任務。

  1. /** 
  2.  * 同步設置屏障任務 
  3.  */ 
  4. private void syncDispatchBarrier() { 
  5.     String dispatcherName = "parallelTaskDispatcher"
  6.     TaskDispatcher dispatcher = createParallelTaskDispatcher(dispatcherName, TaskPriority.DEFAULT); 
  7.     // 創建任務組。 
  8.     Group group = dispatcher.createDispatchGroup(); 
  9.     // 將任務加入任務組,返回一個用于取消任務的接口。 
  10.     dispatcher.asyncGroupDispatch(group, new Runnable() { 
  11.         @Override 
  12.         public void run() { 
  13.             HiLog.info(LABEL_LOG, "task1 is running");  // 1 
  14.         } 
  15.     }); 
  16.     dispatcher.asyncGroupDispatch(group, new Runnable() { 
  17.         @Override 
  18.         public void run() { 
  19.             HiLog.info(LABEL_LOG, "task2 is running");  // 2 
  20.         } 
  21.     }); 
  22.  
  23.     dispatcher.syncDispatchBarrier(new Runnable() { 
  24.         @Override 
  25.         public void run() { 
  26.             HiLog.info(LABEL_LOG, "barrier");  // 3 
  27.         } 
  28.     }); 
  29.     HiLog.info(LABEL_LOG, "after syncDispatchBarrier");  // 4 

運行之后查看日志:

HarmonyOS 基礎之線程管理-鴻蒙HarmonyOS技術社區

6. 異步設置屏障任務asyncDispatchBarrier

在任務組上設立任務執行屏障后直接返回,指定任務將在任務組中的所有任務執行完成后再執行。

  1. /** 
  2.    * 異步設置屏障任務 
  3.    */ 
  4.   private void asyncDispatchBarrier() { 
  5.       TaskDispatcher dispatcher = createParallelTaskDispatcher("dispatcherName", TaskPriority.DEFAULT); 
  6.       // 創建任務組。 
  7.       Group group = dispatcher.createDispatchGroup(); 
  8.       // 將任務加入任務組,返回一個用于取消任務的接口。 
  9.       dispatcher.asyncGroupDispatch(group, new Runnable() { 
  10.           @Override 
  11.           public void run() { 
  12.               HiLog.info(LABEL_LOG, "task1 is running");  // 1 
  13.           } 
  14.       }); 
  15.       dispatcher.asyncGroupDispatch(group, new Runnable() { 
  16.           @Override 
  17.           public void run() { 
  18.               HiLog.info(LABEL_LOG, "task2 is running");  // 2 
  19.           } 
  20.       }); 
  21.  
  22.       dispatcher.asyncDispatchBarrier(new Runnable() { 
  23.           @Override 
  24.           public void run() { 
  25.               HiLog.info(LABEL_LOG, "barrier");  // 3 
  26.           } 
  27.       }); 
  28.       HiLog.info(LABEL_LOG, "after asyncDispatchBarrier");  // 4 
  29.   } 

運行之后查看日志:

HarmonyOS 基礎之線程管理-鴻蒙HarmonyOS技術社區

總結

線程它就像一面雙刃劍,用的好的時候可以給我們帶來事半功倍等效果,用的不好時就會給我們帶來困擾,并且這個困擾還不是一時半會能解決掉的(因為發現問題的時候,往往是到了需要優化期了,各項業務相互牽扯),故在項目初期就需要嚴格考慮考量這些問題了。

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

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

https://harmonyos.51cto.com

 

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

2021-09-15 14:55:49

鴻蒙HarmonyOS應用

2011-06-13 10:41:17

JAVA

2009-03-12 10:52:43

Java線程多線程

2023-03-05 16:12:41

Linux進程線程

2021-04-15 05:51:25

Linux

2010-10-20 17:26:26

SQLServer線程

2023-12-17 14:24:46

計算機進程線程

2021-09-30 10:04:01

鴻蒙HarmonyOS應用

2021-09-16 10:05:09

鴻蒙HarmonyOS應用

2021-10-14 15:14:36

鴻蒙HarmonyOS應用

2021-08-12 15:01:09

鴻蒙HarmonyOS應用

2011-05-28 08:44:44

云計算BSMIT

2021-09-17 14:43:54

鴻蒙HarmonyOS應用

2021-12-03 09:49:59

鴻蒙HarmonyOS應用

2023-06-07 13:49:00

多線程編程C#

2011-07-04 16:04:20

Applet

2011-01-11 13:47:27

Linux管理進程

2011-01-11 13:53:33

Linux管理磁盤

2023-10-31 08:22:31

線程類型.NET

2021-09-14 09:34:05

鴻蒙HarmonyOS應用
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美中文字幕一区二区三区 | 欧美日韩中文在线 | 天堂一区二区三区 | 成人av网站在线观看 | 伊人二区| 一区二区三区精品视频 | 91精品国产91久久久久久最新 | 欧美人妇做爰xxxⅹ性高电影 | 国产美女精品 | 久久99精品国产99久久6男男 | 欧美激情亚洲天堂 | 欧美一区二区三区国产 | 国产精品一区二区三区久久 | 久久久www成人免费精品 | 久久久国产精品 | 夜夜爽99久久国产综合精品女不卡 | 日韩av在线免费 | 久久综合久 | 久久国产精品偷 | 成人在线黄色 | av一区二区三区四区 | 亚av在线 | 亚洲一区二区三区久久 | 国产亚洲一区二区三区在线观看 | 高清视频一区二区三区 | 97国产超碰 | 手机看黄av免费网址 | 成在线人视频免费视频 | 国产美女视频黄 | 最新午夜综合福利视频 | 伊人久久在线 | www.蜜桃av| 97caoporn国产免费人人 | 天天天天操 | 国产精品人人做人人爽 | 国产激情免费视频 | 成人性视频在线播放 | 精品国产乱码久久久久久蜜柚 | 欧美日韩在线一区二区三区 | 一片毛片| 午夜爽爽男女免费观看hd |