详解如何实现一个Kotlin函数类型

目录

接口与函数类型

总结

接口与函数类型

业务开发中,经常会有实现一个函数式接口(即接口只有一个方法需要实现)的场景,大家应该都会不假思索的写出如下代码:

interface Callback { fun response(): String } class Achieve: Callback { override fun response(): String { return "" } }

这么写当然没什么毛病,甚至为了让kotlin支持对接口CallbackSAM转换,你还可以在接口前面增加一个fun修饰:

fun interface Callback { fun response() }

但是对于Kotlin而言,本身函数类型是可以被实现的,也就是说我们可以使用函数类型替换函数式接口,让子类去实现,代码如下:

class Achieve: () -> String { override fun invoke(): String { return "" } }

这种实现函数类型的类需要重写的方法都是invoke(),方法返回值类型对应的就是函数类型的返回值类型。

这种写法我在LeakCanary的源码中就看到了应用,比如监听Fragment是否销毁的类AndroidOFragmentDestroyWatcher

在这里写下我对这两种方式优缺点的比较:

1.函数类型相比较于接口去实现的优点如下:

参数类型更加直观

某个类实现了函数类型,能直观的看到这个函数类型需要传入的参数有哪些,是什么类型,返回值又是什么类型,而如果实现了一个接口,一般大家都习惯跳转到接口定义的地方看接口方法的实现,所以这一点函数类型会更加方便些

检索更方便

函数类型需要重写的方法名一定叫invoke,所以如果我需要看下某个实现类对重写方法的具体实现逻辑,直接在当前类中搜索invoke关键字定位到这个方法即可;而如果是一个接口接口,我得跳转到接口的定义的地方看接口方法名是什么,才能去实现类中去搜索,所以在这点上函数类型会更加方便些

2.函数类型相比较于接口去实现的缺点如下:

函数类型语义性会比较差:

毕竟定义的接口名一般是和业务进行绑定的,能大概知道这个接口是干啥用的,更加清晰直观,当然这个问题我们可以使用typealias解决,但就会失去上面参数类型更加直观的优点

多态性会比较差(自己编的,不知道合不合理)

比如如果定义的一个接口去实现,我们很容易实现下面这种功能:

fun test(achieve: Achieve) { if (achieve is Callback) { //实现某些逻辑 } }

而如果使用函数类型去实现这种逻辑:

看起来是不是很奇怪,而且对于很多需要重写的方法签名都是相同的(方法参数和返回值都是相同的),根本无法实现这种功能,具体的看下面一点的描述。

无法实现多个相同的函数类型

业务场景中也存在实现多个接口,并且接口定义的方法参数和返回值类型都是相同的,比如下面:

fun interface Callback { fun response(): String } fun interface Callback2 { fun response2(): String } class Achieve2: Callback, Callback2 { override fun response(): String { return "" } override fun response2(): String { return "" } }

如果使用函数类型根本无法实现上面的这种多个接口实现的功能:

直接进行报错。

总结

不管是实现函数类型还是接口,两者都各有其优缺点,大家需要根据业务场景进行具体的选择

到此这篇关于详解如何实现一个Kotlin函数类型的文章就介绍到这了,更多相关Kotlin函数类型内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    excel怎么用乘法函数

    excel怎么用乘法函数,乘法,函数,哪个,excel乘法函数怎么用?1、首先用鼠标选中要计算的单元格。2、然后选中单元格后点击左上方工具栏的fx公

    金蝶担保机构业务管理系统

    金蝶担保机构业务管理系统,,1.金蝶财务软件怎么使用?软件使用方法 使用需要先登陆到数据库,可只导出V3数据或只导出最新年度数据。功能介绍

    excel中乘法函数是什么?

    excel中乘法函数是什么?,乘法,函数,什么,打开表格,在C1单元格中输入“=A1*B1”乘法公式。以此类推到多个单元。1、A1*B1=C1的Excel乘法公式

    标准差excel用什么函数?

    标准差excel用什么函数?,函数,标准,什么,在数据单元格的下方输入l标准差公式函数公式“=STDEVPA(C2:C6)”。按下回车,求出标准公差值。详细

    公共CPU接口类型的详细描述

    公共CPU接口类型的详细描述,,我们知道CPU是电脑的大脑, CPU的处理速度直接决定电脑的性能, 那你知道CPU发展到现在, 都那些CPU接口类型吗.

    FM1和AM3接口将在今年年底前淘汰

    FM1和AM3接口将在今年年底前淘汰,,据来自主板制造商的消息,AMD将开始逐步淘汰Socket FM1和Socket AM3接口从本月开始的处理器,最后消失在第

    主板类型百科全书(基于芯片分类)

    主板类型百科全书(基于芯片分类),,电脑维修基础之主板型号熟悉,主板芯片型号区分,涵盖nVIDIA系列intel系列AMD系列主板型号,主板型号大全内容较

    Windows8开发版系统高清系统接口图

    Windows8开发版系统高清系统接口图,,今天,微软发布,目前由开发者体验版Windows 8操作系统为整个英文系统,Windows 8带来了一系列新功能,没有折

    excel常用函数都有哪些?

    excel常用函数都有哪些?,函数,哪些,常用,1、SUM函数:SUM函数的作用是求和。函数公式为=sum()例如:统计一个单元格区域:=sum(A1:A10)  统计多个