精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

阿里巴巴為什么不建議直接使用@Async注解?

Android編程精選 ? 來源:碼農架構 ? 作者:碼農架構 ? 2022-10-26 11:32 ? 次閱讀

序言

67866878-5466-11ed-a3b6-dac502259ad0.png

對于異步方法調用,從Spring3開始提供了@Async注解,該注解可以被標在方法上,以便異步地調用該方法。調用者將在調用時立即返回,方法的實際執行將提交給Spring TaskExecutor的任務中,由指定的線程池中的線程執行。

在項目應用中,@Async調用線程池,推薦使用自定義線程池的模式。自定義線程池常用方案:重新實現接口AsyncConfigurer。

應用場景

同步:同步就是整個處理過程順序執行,當各個過程都執行完畢,并返回結果。

異步:異步調用則是只是發送了調用的指令,調用者無需等待被調用的方法完全執行完畢;而是繼續執行下面的流程。例如, 在某個調用中,需要順序調用 A, B, C三個過程方法;如他們都是同步調用,則需要將他們都順序執行完畢之后,方算作過程執行完畢;如B為一個異步的調用方法,則在執行完A之后,調用B,并不等待B完成,而是執行開始調用C,待C執行完畢之后,就意味著這個過程執行完畢了。在Java中,一般在處理類似的場景之時,都是基于創建獨立的線程去完成相應的異步調用邏輯,通過主線程和不同的業務子線程之間的執行流程,從而在啟動獨立的線程之后,主線程繼續執行而不會產生停滯等待的情況。

Spring已經實現的線程池

SimpleAsyncTaskExecutor:不是真的線程池,這個類不重用線程,默認每次調用都會創建一個新的線程。

SyncTaskExecutor:這個類沒有實現異步調用,只是一個同步操作。只適用于不需要多線程的地方。

ConcurrentTaskExecutor:Executor的適配類,不推薦使用。如果ThreadPoolTaskExecutor不滿足要求時,才用考慮使用這個類。

SimpleThreadPoolTaskExecutor:是Quartz的SimpleThreadPool的類。線程池同時被quartz和非quartz使用,才需要使用此類。

ThreadPoolTaskExecutor :最常使用,推薦。其實質是對java.util.concurrent.ThreadPoolExecutor的包裝。

異步的方法有:

最簡單的異步調用,返回值為void

參數的異步調用,異步方法可以傳入參數

存在返回值,常調用返回Future

Spring中啟用@Async

67efdcae-5466-11ed-a3b6-dac502259ad0.jpg ?

@Async應用默認線程池

Spring應用默認的線程池,指在@Async注解在使用時,不指定線程池的名稱。查看源碼,@Async的默認線程池為SimpleAsyncTaskExecutor。

無返回值調用

基于@Async無返回值調用,直接在使用類,使用方法(建議在使用方法)上,加上注解。若需要拋出異常,需手動new一個異常拋出。
681adc56-5466-11ed-a3b6-dac502259ad0.jpg

有返回值Future調用

686b150e-5466-11ed-a3b6-dac502259ad0.jpg

有返回值CompletableFuture調用

CompletableFuture 并不使用@Async注解,可達到調用系統線程池處理業務的功能。 JDK5新增了Future接口,用于描述一個異步計算的結果。雖然 Future 以及相關使用方法提供了異步執行任務的能力,但是對于結果的獲取卻是很不方便,只能通過阻塞或者輪詢的方式得到任務的結果。阻塞的方式顯然和我們的異步編程的初衷相違背,輪詢的方式又會耗費無謂的 CPU 資源,而且也不能及時地得到計算結果。

CompletionStage代表異步計算過程中的某一個階段,一個階段完成以后可能會觸發另外一個階段

一個階段的計算執行可以是一個Function,Consumer或者Runnable。比如:

stage.thenApply(x -> square(x)).thenAccept(x -> System.out.print(x)).thenRun(() -> System.out.println())

一個階段的執行可能是被單個階段的完成觸發,也可能是由多個階段一起觸發

在Java8中,CompletableFuture 提供了非常強大的Future的擴展功能,可以幫助我們簡化異步編程的復雜性,并且提供了函數式編程的能力,可以通過回調的方式處理計算結果,也提供了轉換和組合 CompletableFuture 的方法。

它可能代表一個明確完成的Future,也有可能代表一個完成階段( CompletionStage ),它支持在計算完成以后觸發一些函數或執行某些動作。

它實現了Future和CompletionStage接口

689357d0-5466-11ed-a3b6-dac502259ad0.jpg

默認線程池的弊端

在線程池應用中,參考阿里巴巴java開發規范:線程池不允許使用Executors去創建,不允許使用系統默認的線程池,推薦通過ThreadPoolExecutor的方式,這樣的處理方式讓開發的工程師更加明確線程池的運行規則,規避資源耗盡的風險。

Executors各個方法的弊端:

newFixedThreadPool和newSingleThreadExecutor:主要問題是堆積的請求處理隊列可能會耗費非常大的內存,甚至OOM。

newCachedThreadPool和newScheduledThreadPool:要問題是線程數最大數是Integer.MAX_VALUE,可能會創建數量非常多的線程,甚至OOM。

@Async默認異步配置使用的是SimpleAsyncTaskExecutor,該線程池默認來一個任務創建一個線程,若系統中不斷的創建線程,最終會導致系統占用內存過高,引發OutOfMemoryError錯誤。針對線程創建問題,SimpleAsyncTaskExecutor提供了限流機制,通過concurrencyLimit屬性來控制開關,當concurrencyLimit>=0時開啟限流機制,默認關閉限流機制即concurrencyLimit=-1,當關閉情況下,會不斷創建新的線程來處理任務。基于默認配置,SimpleAsyncTaskExecutor并不是嚴格意義的線程池,達不到線程復用的功能。歡迎關注公眾號"Java學習之道",查看更多干貨!

@Async應用自定義線程池

自定義線程池,可對系統中線程池更加細粒度的控制,方便調整線程池大小配置,線程執行異常控制和處理。在設置系統自定義線程池代替默認線程池時,雖可通過多種模式設置,但替換默認線程池最終產生的線程池有且只能設置一個(不能設置多個類繼承AsyncConfigurer)自定義線程池有如下模式:

重新實現接口AsyncConfigurer

繼承AsyncConfigurerSupport

配置由自定義的TaskExecutor替代內置的任務執行器

通過查看Spring源碼關于@Async的默認調用規則,會優先查詢源碼中實現AsyncConfigurer這個接口的類,實現這個接口的類為AsyncConfigurerSupport。但默認配置的線程池和異步處理方法均為空,所以,無論是繼承或者重新實現接口,都需指定一個線程池。且重新實現 public Executor getAsyncExecutor()方法。

實現接口AsyncConfigurer

68c7f602-5466-11ed-a3b6-dac502259ad0.jpg

繼承AsyncConfigurerSupport

69311c2c-5466-11ed-a3b6-dac502259ad0.jpg

配置自定義的TaskExecutor

由于AsyncConfigurer的默認線程池在源碼中為空,Spring通過beanFactory.getBean(TaskExecutor.class)先查看是否有線程池,未配置時,通過beanFactory.getBean(DEFAULT_TASK_EXECUTOR_BEAN_NAME, Executor.class),又查詢是否存在默認名稱為TaskExecutor的線程池。所以可在項目中,定義名稱為TaskExecutor的bean生成一個默認線程池。也可不指定線程池的名稱,申明一個線程池,本身底層是基于TaskExecutor.class便可。 比如:

Executor.class:ThreadPoolExecutorAdapter->ThreadPoolExecutor->AbstractExecutorService->ExecutorService->Executor
這樣的模式,最終底層為Executor.class,在替換默認的線程池時,需設置默認的線程池名稱為TaskExecutor
TaskExecutor.class:ThreadPoolTaskExecutor->SchedulingTaskExecutor->AsyncTaskExecutor->TaskExecutor
這樣的模式,最終底層為TaskExecutor.class,在替換默認的線程池時,可不指定線程池名稱。 6973833c-5466-11ed-a3b6-dac502259ad0.jpg ?

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • spring
    +關注

    關注

    0

    文章

    338

    瀏覽量

    14311
  • 線程池
    +關注

    關注

    0

    文章

    57

    瀏覽量

    6834
  • 注解
    +關注

    關注

    0

    文章

    18

    瀏覽量

    2669

原文標題:阿里巴巴為什么不建議直接使用@Async注解?

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    榮邦佳業有阿里巴巴

    了吧。那就是阿里巴巴阿里巴巴成立一周年之際,通過馬云的積極奔走并請大俠金庸從中穿針引線、廣發英雄帖,中國互聯網的風云人物---新浪的王志東、網易的丁磊、搜狐的張朝陽以及8848的王峻濤等,在馬云的誠意
    發表于 04-15 10:04

    阿里巴巴Android開發手冊》正式發布,獻給移動開發者的新年禮物

    (《阿里巴巴Java開發手冊》主要作者)對手冊的指導。最后越早遵循統一的開發規范,團隊就越受益,希望該手冊能夠為Android開發團隊和開發者帶來切實的幫助,同時,我們也呼吁廣大Android開發者參與進來,不斷完善該規范,您可以在評論處提交您的建議。識別以下二維碼,閱讀
    發表于 02-28 16:29

    阿里巴巴敏捷研發的探索與實踐

    摘要: 今天你敏捷了嗎?敏捷產品開發提倡快速迭代、小步快跑,以便更靈活地應對變化,目前逐漸演變為行業潮流。阿里巴巴內部也在不斷進行敏捷實踐。點此查看原文:http
    發表于 03-07 17:26

    阿里巴巴開源的通用緩存訪問框架JetCache介紹

    Cache的注解式緩存,支持TTL、多級緩存、分布式自動刷新,也提供類似JSR107規范的Cache API。JetCache是由阿里巴巴開源的通用緩存訪問框架,如果你對Spring Cache很熟悉
    發表于 04-24 16:09

    國內芯片—阿里巴巴的人工智能實力

    成立于2016年,2017年首次對外公布的阿里巴巴工智能實驗室(A.I. Labs)目前主要聚焦AI技術,研究對象包括機器學習、下一代人機交互、自動駕駛、服務機器人等領域。 云棲大會上,阿里巴巴
    發表于 09-27 17:54

    阿里巴巴禁止開發人員使用isSuccess作為變量名的原因是什么

    為什么阿里巴巴禁止開發人員使用isSuccess作為變量名
    發表于 04-08 14:46

    詳解阿里巴巴智能對話開發平臺

    四大維度全景揭秘阿里巴巴智能對話開發平臺
    發表于 07-31 11:15

    哪里可以下載阿里巴巴的地方和鏈接?

    你知道我可以從哪里下載阿里巴巴的地方和鏈接嗎?
    發表于 11-04 09:25

    阿里巴巴無線空口提案正式成為LoRa國際標準

    技術之一,已經在全世界各個國家得到了廣泛應用,無線頻譜技術標準是無線通信領域的“重中之重”,直接影響網絡的性能、競爭力和建設成本。對此,阿里巴巴提出了《LoRaWAN CN470頻譜技術標準》方案,并經
    發表于 12-13 10:10

    數據揭秘你不知道的阿里巴巴數據中心

    Alibaba Cluster Data 開源:270GB 數據揭秘你不知道的阿里巴巴數據中心
    發表于 04-30 09:37

    阿里巴巴ai模型破世界紀錄_阿里巴巴的人工智能未來發展解析

    阿里巴巴近日再爆大事件,阿里巴巴ai模型在閱讀理解領域頂級賽事SQuAD破世界紀錄引起大家的高度關注,跟隨小編一起來了解一下是什么情況,看看阿里巴巴人工智能的未來發展趨勢以及全球人工智能的未來發展趨勢是什么。
    發表于 01-16 11:47 ?1694次閱讀

    阿里巴巴回應“收縮招聘”:系假新聞,只是阿里巴巴近期的一次人才盤點和人才體系升級

    速途網10月23日消息(報道:吳佳馨)近日有傳言稱,阿里巴巴已縮減headcount,所有業務線批offer。今日下午,阿里巴巴對此傳言做出回應,稱該消息為假新聞,這只是阿里巴巴近期
    發表于 10-25 11:15 ?403次閱讀

    阿里巴巴馬云占股份多少?阿里巴巴馬云持股比例?目前馬云持股降至4.8%

    馬云在阿里巴巴占多少股份你知道嗎?之前大概馬云在阿里巴巴的持股比例為7%,現在馬云在阿里持股降至5%以下但是仍為最大個人股東。
    發表于 07-13 17:02 ?2.6w次閱讀
    <b class='flag-5'>阿里巴巴</b>馬云占股份多少?<b class='flag-5'>阿里巴巴</b>馬云持股比例?目前馬云持股降至4.8%

    阿里巴巴注冊元宇宙

    近日,阿里巴巴元宇宙商標已經被其他公司搶注,目前商標狀態均為申請中。阿里巴巴通過成立XR 實驗室逐步實現元宇宙的四個階段布局,擁抱元宇宙。
    的頭像 發表于 11-08 11:40 ?3158次閱讀

    阿里巴巴完成雙重主要上市

    8月28日阿里巴巴在香港聯交所主板主要上市,成為在港交所、紐交所雙重主要上市的公司。如今,阿里巴巴完成雙重主要上市。 此外,有投資機構認為阿里巴巴最快有望于9月份就納入港股通。 截至8月28日收盤,
    的頭像 發表于 08-29 16:06 ?349次閱讀