Java介面回撥機制詳解

溫布利往事發表於2015-12-31

一、前言

最近在看android fragment與Activity進行資料傳遞的部分,看到了介面回撥的內容,今天來總結一下。

二、回撥的含義和用途

1、什麼是回撥?

一般來說,模組之間都存在一定的呼叫關係,從呼叫方式上看,可以分為三類同步呼叫、非同步呼叫和回撥。同步呼叫是一種阻塞式呼叫,即在函式A的函式體裡通過書寫函式B的函式名來呼叫之,使記憶體中對應函式B的程式碼得以執行。非同步呼叫是一種類似訊息或事件的機制解決了同步阻塞的問題,例如 A通知 B後,他們各走各的路,互不影響,不用像同步呼叫那樣, A通知 B後,非得等到 B走完後, A才繼續走 。回撥是一種雙向的呼叫模式,也就是說,被呼叫的介面被呼叫時也會呼叫對方的介面,例如A要呼叫B,B在執行完又要呼叫A。

2、回撥的用途

回撥一般用於層間協作,上層將本層函式安裝在下層,這個函式就是回撥,而下層在一定條件下觸發回撥。例如作為一個驅動,是一個底層,他在收到一個資料時,除了完成本層的處理工作外,還將進行回撥,將這個資料交給上層應用層來做進一步處理,這在分層的資料通訊中很普遍。

三、Java實現介面回撥

在C/C++中,要實現回撥函式,被呼叫函式要告訴呼叫者自己的指標地址。但是Java沒有指標地址,不能傳遞方法的地址,一般採用介面回撥的方法來實現:把實現某一介面的類建立的物件的引用賦給該介面宣告的介面變數,那麼該介面變數就可以呼叫被呼叫類實現的介面的方法。

原理:首先建立一個回撥物件,然後再建立一個控制器物件,將回撥物件需要被呼叫的方法告訴控制器物件,控制器物件負責檢查某個場景是否出現或某個條件是否滿足,當滿足時,自動呼叫回撥物件的方法。

例如老闆A對員工B說,我現在交給你一個任務,並且我把我的電話號碼給你,你一旦完成任務就給我打電話。

詳細的程式碼如下:

1、建立一個回撥介面

public interface CallBack
{
    public void doEvent();
}

2、建立回撥介面的實現類,此例中,員工幹完活後還要幹什麼事情是老闆說了算的。

public class Boss implements CallBack
{
    public void doEvent()
    {
        System.out.println("打電話給老闆,告知已經完成工作了");
    }
}

3、建立控制類,也就是本例中的員工物件,他要持有老闆的地址(即回撥介面)

public class Employee
{
    CallBack callBack;
    public Employee(CallBack callBack)
    {
        this.callBack=callBack;
    }
    public void doWork()
    {
        System.out.println("玩命幹活中....");
        callBack.doEvent();
    }
}

4、測試類

public class TestMain
{
    public static void main(String[] args)
    {
        //建立控制器物件,將提供給他的回撥物件傳入
        Employee employee=new Employee(new Boss());
        //啟動控制器物件執行
        employee.doWork();
    }
}

執行結果截圖:

Java介面回撥機制

四、Android中的介面回撥

在android中回撥機制被大量的使用。比如,在Activity中定義了很多生命週期的不同狀態要呼叫的方法,這些方法都是空實現,系統框架要呼叫,使用者也要呼叫來實現。

舉個簡單的例子就是Button的點選響應事件實現機制

      button.setOnClickListener(new OnClickListener() 
        {
            @Override
            public void onClick(View v) 
            {

            }
        });

OnClickListener就是android系統所約好的介面,然後在我們寫的應用程式中傳入回撥物件,這樣就可以達到介面統一,實現不同的效果。這種實現機制類似於下面的程式碼:

public class A
{
    public void setOnClickListener(OnClickListener onClickListener)
    {
        onClickListener.onClick();
    }

    public interface OnClickListener
    {
        public void onClick();
    }
}
public class B 
{
    public static void main(String[] args)
    {
        A a=new A();
        a.setOnClickListener(new OnClickListener()
        {
            public void onClick()
            {
                // TODO 自動生成的方法存根

            }
        });
    }
}

其中A相當於Button,a即button按鈕,B類相當於View。

五、參考資料

1、 http://blog.csdn.net/bjyfb/article/details/10462555

2、 http://www.jcodecraeer.com/a/chengxusheji/java/2012/0822/370.html

相關文章