Java实现回调

参考博客:

一、简述

从软件模块之间的调用方式看,分为三类:同步调用、异步调用和回调。

1️⃣同步调用

同步调用是最基本并且最简单的一种调用方式,类 A 的 a() 调用类 B 的 b(),一直等待 b() 执行完毕,a() 继续往下走。该调用方式适用于 b() 执行时间不长的情况,因为 b() 执行时间过长或者直接阻塞的话,a() 的余下代码是无法执行下去的,这样会造成整个流程的阻塞。

2️⃣异步调用

异步调用是为了解决同步调用可能出现阻塞,导致整个流程卡住而产生的一种调用方式。类 A 的 a() 通过新起线程的方式调用类 B 的 b(),代码接着直接往下执行,这样无论 b() 执行时间多久,都不会阻塞住 a() 的执行。但是,由于 a() 不等待 b() 的执行完成,在 a() 需要 b() 执行结果的情况下(视具体业务而定,有些业务比如启异步线程发个微信通知、刷新缓存这种就没必要),必须通过一定的方式对 b() 的执行结果进行监听。Java 中,可以使用 Future+Callable 的方式做到这一点。

3️⃣回调

在面向对象的语言中,回调则是通过接口或抽象类来实现的,实现这种接口的类为回调类,回调类的对象为回调对象。回调的思想是:

  1. class A 实现接口 CallBack——背景 1
  2. class A 中包含一个 class B 的引用 b——背景 2
  3. class B 有一个参数为 callback 的方法 b(CallBack callback)——背景 3
  4. A 的对象 a 在自己的 a() 里调用 B 的方法 b(CallBack callback)——A 类调用 B 类的某个方法
  5. 然后 b 就可以在 b(CallBack callback) 中调用 A 的方法——B 类调用 A 类的某个方法

综上:

  • 类 A 的 a() 调用类 B 的 b()。
  • 类 B 的 b() 执行完毕主动调用类 A 的 callback()。

该调用方式如图,也就是一种双向的调用方式。回调函数是一个函数或过程,不过它是一个由调用方自己实现,供被调用方使用的特殊函数。



 

二、下载文件的例子

(25条消息) Java回调方法(CallBack)_Amosstan的博客-CSDN博客_java 回调

<think>好的,我现在需要回答用户关于Java回调函数实现原理的问题。首先,我得回顾一下回调函数的基本概念。回调函数是一种常见的编程模式,允许在某个操作完成后执行特定的代码。在Java中,由于没有函数指针,通常通过接口来实现回调机制。 用户提供的引用中有几个例子,比如学生类的gotoschool方法,接受一个Callable接口的实例,并在某个操作后调用call方法。这说明Java回调的核心在于传递接口的实现类对象,然后在适当的时候调用接口中的方法。 接下来,我需要明确回调机制的工作流程。引用3提到,回调函数是调用者将函数指针传递给调用函数,这在Java中转化为传递接口实例。当某个事件发生时(比如异步操作完成),调用该接口的方法,从而触发回调逻辑。 另外,引用2中的例子展示了异步回调,通过启动新线程来执行耗时操作,这样不会阻塞主线程。这说明Java回调可以结合多线程实现异步处理,提高程序效率。 需要注意的是,Java回调与钩子函数的区别。引用3指出,钩子函数是在消息到达目标前捕获并处理,而回调函数是在特定操作完成后执行。这点需要明确区分,避免混淆。 现在需要组织这些信息,分步骤解释回调的原理和实现机制。首先介绍接口的作用,然后通过同步和异步回调的例子说明具体实现方式。同时,可以对比其他语言(如C/C++的函数指针)来帮助理解。 可能还需要提到匿名内部类或Lambda表达式(在Java 8+)简化回调实现,但用户提供的引用中没有涉及这些,所以暂时不深入,除非必要。 最后,确保回答结构清晰,逐步引导用户理解,并引用提供的资料来支持解释。同时,生成相关问题时要围绕回调机制的应用、异步实现、与其他概念的区别等方面。</think>### Java回调函数的实现原理及机制 #### 1. **回调函数的核心原理** Java回调函数的本质是通过**接口传递行为**,实现程序间的协作。其核心步骤如下: 1. **定义接口**:声明一个包含回调方法的接口,例如: ```java public interface Callable { void call(); } ``` 2. **调用方持有接口引用**:调用方(如`Student`类)通过参数接收接口的实现类对象: ```java public void gotoschool(int time, Callable callable) { // ...操作完成后调用回调 callable.call(); } ``` 3. **被调用方实现接口**:使用方(如其他类)实现该接口,定义具体的回调逻辑[^1]。 #### 2. **同步与异步回调的区别** - **同步回调**:直接在主线程中执行回调,会阻塞后续代码。 ```java callable.call(); // 直接调用,无异步处理 ``` - **异步回调**:通过多线程分离回调逻辑,避免阻塞主流程,如引用[2]中的示例: ```java new Thread(() -> A.work(classB.this)).start(); ``` 此时回调逻辑在子线程中执行,主线程可继续执行`System.out.println("classB:classA已经完成工作了")`[^2]。 #### 3. **回调与钩子函数的区别** - **回调函数**:由调用方主动触发,在**特定操作完成后**执行(如网络请求返回)。 - **钩子函数**:在**事件发生前拦截并处理**(如监听键盘输入),可修改或终止事件[^3]。 #### 4. **典型应用场景** 1. 事件驱动编程(如按钮点击事件)。 2. 异步任务通知(如文件下载完成回调)。 3. 框架扩展点(如Spring的`BeanPostProcessor`)。 #### 代码示例 ```java // 定义回调接口 interface PaymentCallback { void onSuccess(String msg); void onFailure(String error); } // 调用方 class PaymentService { void processPayment(PaymentCallback callback) { try { // 模拟支付操作 Thread.sleep(1000); callback.onSuccess("支付成功"); } catch (Exception e) { callback.onFailure("支付超时"); } } } // 使用方 public class Main { public static void main(String[] args) { new PaymentService().processPayment(new PaymentCallback() { @Override public void onSuccess(String msg) { System.out.println(msg); // 输出:支付成功 } @Override public void onFailure(String error) { System.err.println(error); } }); } } ``` 相关问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值