Android原理——回调机制

Android回调机制

回调函数可以把调用者与被调用者分开,调用者不关心谁是被调用者,调用者只需知道具有特定原型和限制条件的被调函数。

1.定义一个回调函数;

2.提供函数实现的一方在初始化的时候,将回调函数的实例化接口提交给调用者;

3.当特定的事件或条件发生的时候,调用者使用接口调用回调函数对事件进行处理。

看到过一句写的比较好的描述:A类中调用B类的某个方法C,然后B类中反过来调用A类的方法D,D这个方法就叫回调方法

先引用一个Android源码中经典的例子:

    //接口类, B类实现接口,A类调用接口
    public interface OnClickListener {
        void onClick(View v);
    }
    //相当于A类
    public class MainActivity extends Activity implements OnClickListener{
    private Button button;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button = (Button)findViewById(R.id.button1);
        // A类实例化接口
        button.setOnClickListener(this);
    }
    @Override
    public void onClick(View v) {
        // 回调函数
    }
}
// 相当于B类
public class View implements Drawable.Callback, KeyEvent.Callback, AccessibilityEventSource {
    // 接口实例
    protected OnClickListener mOnClickListener;  

    // 接口实例化
    public void setOnClickListener(OnClickListener l) {
        if (!isClickable()) {
            setClickable(true);
        }
        mOnClickListener = l;
    }
    public boolean performClick() {
        if (mOnClickListener != null) {
            //B类调用A类的实现方法
            mOnClickListener.onClick(this);
            return true;
        }
        return false;
    }
}  

上面的例子写的很清楚,这里我用markdown做个图表示:

Created with Rapha?l 2.1.2A类A类B类B类setCallback(this)implements CallbackonCallback()interface Callback{}Callback callbackonCallback()

时间: 2024-08-02 10:32:51

Android原理——回调机制的相关文章

Android 接口回调机制详解

在使用接口回调的时候发现了一个经常犯的错误,就是回调函数里面的实现有可能是用多线程或者是异步任务去做的,这就会导致我们期望函数回调完毕去返回一个主函数的结果,实际发现是行不通的,因为如果回调是多线程的话你是无法和主函数同步的,也就是返回的数据是错误的,这是非常隐秘的一个错误.那有什么好的方法去实现数据的线性传递呢?先介绍下回调机制原理. 回调函数 回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用为调用它所指向的函数时,我们就说这是回调函数

弄明白Android 接口回调机制

以前对于这个机制理解不够深刻,现在重新整理下思路. 一.建模 我理解的接口回调就是,我这个类实现了一个接口里的方法doSomething,然后注册到你这里,然后我就去做别的事情去了,你在某个触发的时机回头来调用我doSomething的方法.好比,我给你打电话问某个难题,你电话里想不出来,于是说等想到了再回我电话.于是接口回调机制比喻模型如下 第一步: 首先,你我得约定,这个实现的方法是咋样的,叫什么名字,需要传入传出什么.为什么要这样呢?你我得约定电话联系,不是微信扣扣.这就是约定的接口. 我

JAVA和Android的回调机制

以 前不理解什么叫回调,天天听人家说加一个回调方法啥的,心里想我草,什么叫回调方法啊?然后自己就在网上找啊找啊找,找了很多也不是很明白,现在知道了, 所谓回调:就是A类中调用B类中的某个方法C,然后B类中反过来调用A类中的方法D,D这个方法就叫回调方法,这样子说你是不是有点晕晕的,其实我刚开始 也是这样不理解,看了人家说比较经典的回调方式: Class A实现接口CallBack callback——背景1 class A中包含一个class B的引用b ——背景2 class B有一个参数为c

Android之回调机制

作用:可以把调用者与被调用者分开. 这里举个简单的例子,程序员A写了一段程序(程序a),其中预留有回调函数接口,并封装好了该程序.程序员B要让a调用自己的程序b中的一个方法,于是,他通过a中的接口回调自己b中的方法.Android的例子就是:Button点击后,去调用自己程序员写的方法,这样按钮的点击可以根据情况,执行到不同的方法. 整个机制构成三要素就是:我(客户端),你(服务端),约定(接口) 详见: http://blog.sina.com.cn/s/blog_77c632410101cj

Android接口回调机制

开发中,接口回调是我们经常用到的. 接口回调的意思即,注册之后并不立马执行,而在某个时机触发执行. 举个例子: A有一个问题不会,他去问B,B暂时解决不出来,B说,等我(B)解决了再告诉你(A)此时A可以继续先做别的事情. 那么就只有当B解决完问题后告诉A问题解决了,A才可以能解决这个问题. 代码中比如最常用的: 一个Activity中给按钮一个接口回调方法,只有用户点击了这个按钮,告诉按钮被点击了,才会执行按钮接口回调的方法 Button btn = new Button(this); btn

关于android接口回调机制

In my previous post I showed how to perform asynchronous web API calls in native Android code, after showing how to do it in native iOS a few days before. My Android post was glaringly missing support for callback functions however, so today I'll sho

android 回调机制应用场景

简述android/java回调机制调用流程: 在A类中调用B类中的方法method_B(CallBack call , ...) ,然后在B类中调用A类中的方法method_A(...) 上述流程的前提背景: 1. A类实现一个回调接口CallBack 2. A类中有B类的实例b 3. B类中的方法method_B(CallBack  call , ...) 一定包含CallBack类型参数(即A类的实例) 回调机制应用场景: 1. 开发场景:例如Activity调用另一个类中的方法,在该方法

接口_ _接口回调机制

在Android中到处可见接口回调机制,尤其是UI事件处理方面,本文给大家介绍android接口回调机制,涉及到android接口回调相关知识,对本文感兴趣的朋友可以参考下本篇文章 在使用接口回调的时候发现了一个经常犯的错误,就是回调函数里面的实现有可能是用多线程或者是异步任务去做的,这就会导致我们期望函数回调完毕去返回一个主函数的结果,实际发现是行不通的,因为如果回调是多线程的话你是无法和主函数同步的,也就是返回的数据是错误的,这是非常隐秘的一个错误.那有什么好的方法去实现数据的线性传递呢?先

Java接口回调机制

一.前言 最近在看android Fragment与Activity进行数据传递的部分,看到了接口回调的内容,今天来总结一下. 二.回调的含义和用途 1.什么是回调? 一般来说,模块之间都存在一定的调用关系,从调用方式上看,可以分为三类同步调用.异步调用和回调.同步调用是一种阻塞式调用,即在函数A的函数体里通过书写函数B的函数名来调用之,使内存中对应函数B的代码得以执行.异步调用是一种类似消息或事件的机制解决了同步阻塞的问题,例如A通知B后,他们各走各的路,互不影响,不用像同步调用那样,A通知B