温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java中的闭包与回调方法分析

发布时间:2021-07-21 09:46:07 来源:亿速云 阅读:129 作者:chen 栏目:编程语言

本篇内容介绍了“Java中的闭包与回调方法分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

闭包是一个可调用的对象,它记录了一些信息,这些信息来自于创建他的作用域,用过这个定义 可以看出内部类是面向对象的闭包 因为他不仅包含外围类对象的信息 还自动拥有一个指向此外围类对象的引用 在此作用域内 内部类有权操作所有的成员 包括private成员;

Java代码

interface Incrementable  {  void increment();  }  class Callee1 implements Incrementable  {  private int i=0;  public void increment()  {  i++;  System.out.println(i);  }  }  class MyIncrement  {  void increment()  {  System.out.println("other increment");  }  static void f(MyIncrement mi)  {  mi.increment();  }  }  class Callee2 extends MyIncrement  {  private int i=0;  private void incr()  {  i++;  System.out.println(i);  }  private class Closure implements Incrementable //内部类  {  public void increment()  {  incr();  }  }  Incrementable getCallbackReference()  {  return new Closure(); //新建内部类  }  }  class Caller  {  private Incrementable callbackRefference;  Caller(Incrementable cbh)  {  callbackRefference = cbh;  }  void go()  {  callbackRefference.increment();//调用increment()方法  }  }  public class Callbacks  {  public static void main(String [] args)  {  Callee1 c1=new Callee1();  Callee2 c2=new Callee2();  MyIncrement.f(c2);  Caller caller1 =new Caller(c1);  Caller caller2=new Caller(c2.getCallbackReference());//将内部类中的Closure赋给Caller  caller1.go();  caller1.go();  caller2.go();  caller2.go();  }  }

输出:

other increment

1

2

1

2

Callee2 继承字MyIncrement 后者已经有一个不同的increment()方法并且与Incrementable接口期望的increment()方法完全不相关 所以如果Callee2继承了MyIncrement 就不能为了Incrementable的用途而覆盖increment()方法 于是这能使用内部类独立的实现Incrementable

内部类Closure实现了Incrementable 一提供一个放回Caller2的钩子 而且是一个安全的钩子 无论谁获得此Incrementbale的引用 都只能调用increment() 除此之外没有其他功能。

“Java中的闭包与回调方法分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI