回調概念:

  軟件模塊之間總是存在著一定的接口,從調用方式上,可以把他們分為三類:同步調用、回調和異步調用。同步調用是一種阻塞式調用,調用方要等待對方執行完畢 才返回,它是一種單向調用;回調是一種雙向調用模式,也就是說,被調用方在接口被調用時也會調用對方的接口;異步調用是一種類似消息或事件的機制,不過它 的調用方向剛好相反,接口的服務在收到某種訊息或發生某種事件時,會主動通知客戶方(即調用客戶方的接口)。回調和異步調用的關系非常緊密,通常我們使用 回調來實現異步消息的注冊,通過異步調用來實現消息的通知。同步調用是三者當中最簡單的,而回調又常常是異步調用的基礎。

  Java(Java教程 Java培訓 實現回調:

  在 Java 支持方法指針之前,Java 接口不能提供一種實現回調的好方法。如果您習慣于傳遞在事件驅動編程模型中調用的函數指針,則您會喜歡本技巧。 熟悉 MS-Windows 和 X Window System 事件驅動編程模型的開發人員,習慣于傳遞在某種事件發生時調用(即“回調”)的函數指針。Java 的面向對象模型目前并不支持方法指針,這樣似乎就不可能使用這種很好的機制。但我們并不是一點辦法都沒有!

  Java 的接口支持提供了一種獲得回調的等價功能的機制。其技巧就是:定義一個簡單接口,并在該接口中聲明我們要調用的方法。

  例如,假定我們希望在某個事件發生時得到通知。我們可以定義一個接口:

  public interface InterestingEvent

  { // 這僅是一個常規方法。因此如果需要,

  // 它可有返回值,也可接收參數。

  public void interestingEvent ();

  }

  這使得我們可以控制實現該接口的類的任何對象。因此,我們不必關心任何外部類型信息。與在將 C++ 代碼用于 Motif 時使用窗口小部件的數據域來容納對象指針的難以控制的 C 函數相比,這種方法要好得多。

  發出事件信號的類必須等待實現了 InterestingEvent 接口的對象,并在適當時候調用 interestingEvent() 方法。

  public class EventNotifier

  { private InterestingEvent ie;

  private boolean somethingHappened;

  public EventNotifier (InterestingEvent event)

  { // 保存事件對象以備后用。

  ie = event;

  // 還沒有要報告的事件。

  somethingHappened = false;

  } //...

  public void doWork ()

  { // 檢查在別處設置的謂詞。

  if (somethingHappened)

  { // 通過調用接口的這個方法發出事件信號。

  ie.interestingEvent ();

  } //...

  }

  // ...

  }

  在上例中,我使用 somethingHappened 謂詞來跟蹤是否應觸發事件。在許多情況下,調用此方法足以保證向 interestingEvent() 發出信號。

  希望接收事件通知的代碼必須實現 InterestingEvent 接口,并將自身引用傳遞給事件通知程序。

  public class CallMe implements InterestingEvent

  { private EventNotifier en;

  public CallMe ()

  { // 創建事件通知程序,并將自身引用傳遞給它。

  en = new EventNotifier (this);

  }

  // 為事件定義實際的處理程序。

  public void interestingEvent ()

  { // 噢!必定發生了感興趣的事件!

  // 執行某些操作 ...

  }

  //...

  }

  JAVA的CALLBACK通過接口來實現。

  例: 1.class A,class B

  2.class A實現接口operate

  3.class B擁有一個參數為operate接口類型的函數test(operate o)

  4.class A運行時調用class B中test函數,以自身傳入參數

  5.class B已取得A,就可以隨時回調A所實現的operate接口中的方法

  public interface BoomWTC

  { //獲得拉登的決定

  public benLaDengDecide();

  // 執行轟炸世貿

  public void boom();

  }

  public class At$911 implements BoomWTC

  { private boolean decide;

  private TerroristAttack ta;

  public At$911(){

  Date now=new Date();

  SimpleDateFormat myFmt1=new SimpleDateFormat("yy/MM/dd HH:mm");

  this.dicede= myFmt.format(dt).equals("01/09/11 09:44");

  this.ta=new TerroristAttack();

  }

  //獲得拉登的決定

  public boolean benLaDengDecide(){

  return decide;

  }

  // 執行轟炸世貿

  public void boom(){

  ta.attack(new At$911);

  } }

  public class TerroristAttack{

  public TerroristAttack(){

  }

  public attack(BoomWTC bmw){

  if(bmw.benLaDengDecide()){

  //let's go.........

  } }

  }