用 Java 实现回调例程

作者:John D. Mitchell
摘要
在 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 ()
 {
 // 噢!必定发生了感兴趣的事件!
 // 执行某些操作 ...
 }

    //...
}

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
回调函数是指在程序执行过程中,将某个函数的地址作为参数传递给另一个函数,在特定条件下由后者调用执行。在C语言中,回调函数通常是通过函数指针来实现的。 以下是一个简单的C语言例程,演示了回调函数的使用: ```c #include <stdio.h> // 回调函数的定义 typedef int (*CompareFunc)(int, int); // 排序函数,使用回调函数来比较两个数的大小 void sort(int arr[], int size, CompareFunc compare) { for (int i = 0; i < size - 1; i++) { for (int j = 0; j < size - i - 1; j++) { if (compare(arr[j], arr[j + 1]) > 0) { int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } // 比较函数,用于从小到大排序 int ascending(int a, int b) { return a - b; } // 比较函数,用于从大到小排序 int descending(int a, int b) { return b - a; } int main() { int arr[] = {5, 2, 8, 1, 9}; int size = sizeof(arr) / sizeof(arr[0]); // 使用回调函数进行从小到大排序 sort(arr, size, ascending); printf("从小到大排序结果: "); for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } printf("\n"); // 使用回调函数进行从大到小排序 sort(arr, size, descending); printf("从大到小排序结果: "); for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } printf("\n"); return 0; } ``` 在上面的例程中,定义了一个`sort`函数,它接受一个整数数组、数组大小和一个回调函数作为参数。`sort`函数根据回调函数的比较结果来进行排序。然后,通过定义两个不同的比较函数`ascending`和`descending`,分别实现了从小到大和从大到小的排序。 在`main`函数中,首先使用回调函数`ascending`进行排序,并输出结果,然后使用回调函数`descending`进行排序,并再次输出结果。 通过回调函数,我们可以在不修改原始函数的情况下,动态地改变其行为,提高代码的灵活性和复用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wxyxl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值