@FunctionalInterface的必要性

一家之言:
jdk8完成了lamda, lamda本身一种方法引用以外, 更为重要的是, lamda是语法糖, 调用方的书写不去指明类和方法名, 而交由编译器去推断.
如果要推断, 需要哪些东西呢:

  1. 全限定类名/接口 (声明方已经提供了)

  2. 方法签名? 调用方是不会直接提供的, 不然就不是语法糖了. 所以编译器决定告诉他家一个约定: 这个全限定类名或者接口中只有一个抽象函数, 在下编译器能且只能认这个方法.

  3. 并且, 编译器为了强制规范这一条, 增加@FunctionalInterface, 如果你声明了,那就只能有且只有一个抽象函数了

(为什么限定有且只有一个抽象函数, 个人理解: 因为没有方法名, 光靠参数列表和返回值是无法唯一确认一个参数的, 就好比 void a()和 void b(), 让编译器去推是难为他了. 那为啥不然编译器检查对同参数列表和同返回值类型的函数进行检查报错呢–这一点有待进一步研究, 不过有个人理解: 1. 从数据结构算法考虑, 这个去重也太多了, 排列组合已经炸了 2. 简单的就是最好的, 复杂就即便不乱套, 至少不会优雅 3. 虚拟机兼容?)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值