真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java項目中如何實現(xiàn)異步回調(diào)

這篇文章將為大家詳細講解有關Java項目中如何實現(xiàn)異步回調(diào),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

創(chuàng)新互聯(lián)主營圖們網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,app軟件開發(fā)公司,圖們h5小程序開發(fā)搭建,圖們網(wǎng)站營銷推廣歡迎圖們等地區(qū)企業(yè)咨詢

Java 異步回調(diào)機制

一、什么是回調(diào)

回調(diào),回調(diào)。要先有調(diào)用,才有調(diào)用者和被調(diào)用者之間的回調(diào)。所以在百度百科中是這樣的:

軟件模塊之間總是存在著一定的接口,從調(diào)用方式上,可以把他們分為三類:同步調(diào)用、回調(diào)和異步調(diào)用。

回調(diào)是一種特殊的調(diào)用,至于三種方式也有點不同。

1、同步回調(diào),即阻塞,單向。

2、回調(diào),即雙向(類似自行車的兩個齒輪)。

3、異步調(diào)用,即通過異步消息進行通知。

二、CS中的異步回調(diào)(Java案例)

比如這里模擬個場景:客戶端發(fā)送msg給服務端,服務端處理后(5秒),回調(diào)給客戶端,告知處理成功。代碼如下:

回調(diào)接口類:

/**
 * @author Jeff Lee
 * @since 2015-10-21 21:34:21
 * 回調(diào)模式-回調(diào)接口類
 */
public interface CSCallBack {
  public void process(String status);
}

模擬客戶端:

/**
 * @author Jeff Lee
 * @since 2015-10-21 21:25:14
 * 回調(diào)模式-模擬客戶端類
 */
public class Client implements CSCallBack {

  private Server server;

  public Client(Server server) {
    this.server = server;
  }

  public void sendMsg(final String msg){
    System.out.println("客戶端:發(fā)送的消息為:" + msg);
    new Thread(new Runnable() {
      @Override
      public void run() {
        server.getClientMsg(Client.this,msg);
      }
    }).start();
    System.out.println("客戶端:異步發(fā)送成功");
  }

  @Override
  public void process(String status) {
    System.out.println("客戶端:服務端回調(diào)狀態(tài)為:" + status);
  }
}

模擬服務端:

/**
 * @author Jeff Lee
 * @since 2015-10-21 21:24:15
 * 回調(diào)模式-模擬服務端類
 */
public class Server {

  public void getClientMsg(CSCallBack csCallBack , String msg) {
    System.out.println("服務端:服務端接收到客戶端發(fā)送的消息為:" + msg);

    // 模擬服務端需要對數(shù)據(jù)處理
    try {
      Thread.sleep(5 * 1000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
    System.out.println("服務端:數(shù)據(jù)處理成功,返回成功狀態(tài) 200");
    String status = "200";
    csCallBack.process(status);
  }
}

測試類:

/**
 * @author Jeff Lee
 * @since 2015-10-21 21:24:15
 * 回調(diào)模式-測試類
 */
public class CallBackTest {
  public static void main(String[] args) {
    Server server = new Server();
    Client client = new Client(server);

    client.sendMsg("Server,Hello~");
  }
}

運行下測試類 — 打印結果如下:

客戶端:發(fā)送的消息為:Server,Hello~
客戶端:異步發(fā)送成功
服務端:服務端接收到客戶端發(fā)送的消息為:Server,Hello~
(這里模擬服務端對數(shù)據(jù)處理時間,等待5秒)
服務端:數(shù)據(jù)處理成功,返回成功狀態(tài) 200
客戶端:服務端回調(diào)狀態(tài)為:200

一步一步分析下代碼,核心總結如下

1、接口作為方法參數(shù),其實際傳入引用指向的是實現(xiàn)類
2、Client的sendMsg方法中,參數(shù)為final,因為要被內(nèi)部類一個新的線程可以使用。這里就體現(xiàn)了異步。
3、調(diào)用server的getClientMsg(),參數(shù)傳入了Client本身(對應第一點)。

三、回調(diào)的應用場景

回調(diào)目前運用在什么場景比較多呢?從操作系統(tǒng)到開發(fā)者調(diào)用:

1、Windows平臺的消息機制
2、異步調(diào)用微信接口,根據(jù)微信返回狀態(tài)對出業(yè)務邏輯響應。
3、Servlet中的Filter(過濾器)是基于回調(diào)函數(shù),需容器支持。

補充:其中 Filter(過濾器)和Interceptor(攔截器)的區(qū)別,攔截器基于是Java的反射機制,和容器無關。但與回調(diào)機制有異曲同工之妙。

總之,這設計讓底層代碼調(diào)用高層定義(實現(xiàn)層)的子程序,增強了程序的靈活性。

四、模式對比

上面講了Filter和Intercepter有著異曲同工之妙。其實接口回調(diào)機制和一種設計模式—觀察者模式也有相似之處:

觀察者模式:

GOF說道 — “定義對象的一種一對多的依賴關系,當一個對象的狀態(tài)發(fā)送改變的時候,所有對他依賴的對象都被通知到并更新?!彼且环N模式,是通過接口回調(diào)的方法實現(xiàn)的,即它是一種回調(diào)的體現(xiàn)。

接口回調(diào):

與觀察者模式的區(qū)別是,它是種原理,而非具體實現(xiàn)。

關于Java項目中如何實現(xiàn)異步回調(diào)就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


文章名稱:Java項目中如何實現(xiàn)異步回調(diào)
網(wǎng)址分享:http://weahome.cn/article/psjejg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部