收藏 分享(赏)

java中的回调函数.docx

上传人:weiwoduzun 文档编号:4295971 上传时间:2018-12-21 格式:DOCX 页数:5 大小:19.34KB
下载 相关 举报
java中的回调函数.docx_第1页
第1页 / 共5页
java中的回调函数.docx_第2页
第2页 / 共5页
java中的回调函数.docx_第3页
第3页 / 共5页
java中的回调函数.docx_第4页
第4页 / 共5页
java中的回调函数.docx_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

1、java 中的回调函数 利用接口在 WINDOWS 中,程序员想让系统 DLL 调用自己编写的一个方法,于是利用 DLL 当中回调函数(CALLBACK )的接口来编写程序,使它调用,这个就称为回调。在调用接口时,需要严格的按照定义的参数和方法调用,并且需要处理函数的异步,否则会导致程序的崩溃。这样的解释似乎还是比较难懂,这里举个简单的例子,程序员 A 写了一段程序(程序 a),其中预留有回调函数接口,并封装好了该程序。程序员 B 要让 a 调用自己的程序 b 中的一个方法,于是,他通过 a 中的接口回调自己 b 中的方法。目的达到。在C/C+中,要用回调函数,被调函数需要告诉调用者自己的指针

2、地址,但在 JAVA 中没有指针,怎么办?我们可以通过接口(interface)来实现定义回调函数。假设我是程序员 A,以下是我的程序 a:public class Callerprivate MyCallInterface mc;public Caller()public setI(MyCallInterface mc)this.mc=mc;public call()mc.fuc();/Caller 的调用方法这里需要定义一个接口,以便程序员 B 根据我的定义编写程序实现接口。public interface MyCallInterfacepublic void fuc();于是,程序员 B

3、 只需要实现这个接口就能达到回调的目的了:public class callee implements MyCallInterfacepublic void fuc()/do something下面是调用过程:public class callbackspublic static void main(String args)Callee c1=new Callee();Caller caller=new Caller();caller.setI(c1);caller.call();在以上代码中,caller 是调用者,callee 是被调用者,callbacks 表示调用过程。先产生了 Cal

4、lee 对象,利用这个 callee 对象产生的 Caller 对象则携带了一些信息(即与Callee 对象的关联),所以 Caller 对象可以利用自己的 call 方法调用 Callee 的方法。这就是整个回调过程。B 产生 A,则 A 具有调用 B 的方法的能力。caller 中具有的接口引用很关键。实现了此接口引用的 callee 只需将自己的引用传给 Caller。一般来说分为以下几步:1. 声明回调函数的统一接口 interface A,包含方法 fuc();2. 在调用类 caller 内将该接口设置为私有成员 private A XXX;3. 在 caller 内提供一个 pu

5、blic 方法,可以将外部“该接口 A 的实现类的引用”通过形参传给 XXX;4. caller 的某个方法 call()中会用到 XXX.fuc()方法;5. 在 caller 的实例中,将实现了 A 接口的对象的引用传给 caller,后调用 call()方法;注意:步骤 3 中亦可以使用 Caller 的构造函数直接实现。JAVA 排序的 compare 接口:1. interface Compare 2. boolean lessThan(Object lhs, Object rhs); 3. boolean lessThanOrEqual(Object lhs, Object rhs

6、); 4. 5. 6. import java.util.*; 7. 8. public class SortVector extends Vector 9. private Compare compare; / 私有接口成员 10. public SortVector(Compare comp) 11. compare = comp; 12. 13. public void sort() 14. quickSort(0, size() - 1); 15. 16. private void quickSort(int left, int right) 17. if(right left) 18

7、. Object o1 = elementAt(right); 19. int i = left - 1; 20. int j = right; 21. while(true) 22. while(compare.lessThan( 23. elementAt(+i), o1) 24. ; 25. while(j 0) 26. if(compare.lessThanOrEqual( 27. elementAt(-j), o1) 28. break; 29. if(i = j) break; 30. swap(i, j); 31. 32. swap(i , right); 33. quickSort(left, i-1); 34. quickSort(i+1, right); 35. 36. 37. private void swap(int loc1, int loc2) 38. Object tmp = elementAt(loc1); 39. setElementAt(elementAt(loc2), loc1); 40. setElementAt(tmp, loc2); 41. 42.

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 网络科技 > Java

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报