Kotlin——基础的函数/方法详解

对于Kotlin中的函数来说,和JavaScript或者Lua这些语言很像,它有着这些语言的特性。但是也与这些语言就着许多不同之处。或许你更了解Java语言,然而对于Java语言来说,它不是不是闭包这个特性的。由于在这篇文章主要是讲解函数的基本使用,故而只会讲解到函数的定义函数的返回值函数的参数等。剩下的部分我会在这个系列的高级篇会给大家奉上。

目录

一、函数的声明及基本使用

Kotlin中函数的声明,同JavaScript相似。

1.1、函数的声明

  • Kotlin中的函数声明关键字为:fun
  • 定义格式为:可见性修饰符 fun 函数名(参数名 :类型,...) : 返回值{}

这里的可见性修饰符请参见我的另一篇文章Kotlin——可见性修饰符详解,至于返回值以及参数请继续往下面看

例:定义一个最基本的函数

fun basis(){
    ...
}

注意:

  • 上面的例子中没有可见性修饰符,那是因为Kotlin中默认为public可见性修饰符
  • ()圆括号必须存在,即使是没有参数的情况下
  • {}大括号必须存在,即使是没有函数体的时候,不过在Kotlin中有一个特例就是,函数具备返回值的时候,如果只用一个表达式就可以完成这个函数,则可以使用单表达式函数。在下面会详细的给大家讲解
  • 在函数没有返回值时可以省略其返回值

1.2、成员函数

成员函数是指在对象中的内部函数。你可以参见我的另一篇文章Kotlin——类详解

例:声明一个类,在类中在定义一个方法,这个方法就是这个类的成员函数

class Test{
    fun foo(){}
}

1.3、函数的使用

函数的使用分为两种:

  • 普通的使用
  • 成员函数的使用

例:

// 普通的使用
basis()
// 如果函数有返回值
val x = basis()

// 成员函数的使用:先初始化对象,在根据对象使用`中缀符号(.)`调用其成员函数
Test().foo()
// 如果函数有返回值
val x = Test().foo()

二、函数的返回值

Kotlin中,函数的返回值类型可以分为:

  • Unit类型:该类型即无返回值的情况,可以省略。
  • 其他类型: 显示返回类型的情况

2.1、Unit类型

  • 这个类型可以理解为函数无返回值。

例:

fun unitFun() : Unit{
    println("我是返回值为Unit的函数,Unit可省略")
    return

    // return Unit 可省略
    // 或者 return  可省略
}

等价于

 fun unitFun(){
    println("我是返回值为Unit的函数,Unit可省略")
}

当无返回值时,使用平时Java语法写普通函数一样即可。不需显示写成Unit。这里只是做一个介绍而已

2.2 、其他显示返回类型的返回值

这个类型可以理解为,该函数具有返回值,并且返回值类型不能省略,并且return也不能省略

例: 定义一个返回类型为Int的函数

fun returnFun() : Int{
    return 2
}

三、函数的参数

对于函数中的参数来说,这里主要分为几个模块来讲解:

  • 具有参数的基本函数声明
  • 默认参数,即参数具有默认值
  • 命名参数,当传递参数的时候显示使用参数名 = 参数值
  • 可变数量的参数:即参数的个数不定。

3.1、具有参数的函数定义

定义一个具有参数的函数,使用Pascal表示法定义,即为:name : type。其中的参数必须具有显示的参数类型,并且参数与参数之间用逗号(,)隔开。

例:

fun funArgs(numA : Int, numB : Float){
    println("numA = $numA \t numB = $numB")
}

fun main(args: Array<String>) {
    funArgs(1,10f)
}

3.2、默认参数

对于默认参数,即使指一个函数中的参数具有默认值,这样在使用该函数的时候,可以省略一部分参数,可以减少函数的重载

例:定义个具有默认参数的函数

fun defArgs(numA : Int  = 1, numB : Float = 2f, numC : Boolean = false){
    println("numA  =  $numA \t numB = $numB \t numC = $numC")
}

fun main(args: Array<String>) {

    // 默认参数的函数使用
    defArgs()
    defArgs(1,10f,true)
}

输出结果为:

numA  =  1   numB = 2.0      numC = false
numA  =  1   numB = 10.0     numC = true

可以看出:当具有默认参数时,可以对是参数有默认值的参数不传递参数值。

不过这里有一点值得注意的是: 当该函数是一个成员函数时,并且该函数时覆写继承类中的方法时,则该成员函数必须从签名中省略该函数的默认值。其实这一点不必过于看重,因为在你覆写方法时,编辑器都默认会帮你实现的..

举例说明:

open class A{
    open fun foo(i : Int = 10){}
}

class B : A(){
    override fun foo(i: Int) {
        super.foo(i)
        println(i)
    }
}

fun main(args: Array<String>) {
    B().foo()
}

输出结果为:10

如果你对类继承不了解,可以参见我的另一篇文章Kotlin——面向对象的特征与类继承详解

3.3、命名参数

即在使用函数时显示使用参数名 = 参数值这种方式传递参数

例:这里举例一个普通的具有参数函数与具有默认参数函数的结合使用

fun callFun(str : String,
        isTrue : Boolean = false,
        numA : Int = 2,
        numB: Float = 2.0f,
        numC : Int = 2){}

可以看出,上面实例中的str参数是不具备默认值的。

  1. 我们可以这样使用它:

    callFun("str")  // 这样是可以的,因为后面的参数都具有默认值
  2. 当使用非默认参数调用它时,使用起来就和Java函数一样:
    callFun("str",true,2,2.0,2)   // 这样阅读性很差,因为你除了看函数的定义外,你不知道这些参数的含义
  3. 使用命名参数我们可以使代码更具有可读性:
    callFun("str",isTrue = true,numA = 3, numB = 3.0f, numC = 3)
  4. 当我们不需要所有的参数时:
    callFun("str",isTrue = true)

不过当我们使用命名参数时,虽然可以提高代码的阅读性,及在我们使用第34时有一个坑,就是Java中不支持这种写法的。而在实际的项目开发中,几乎上都是和Java语言混用的。那么这种用法就不适合了。所有这里还是推荐使用12两点的用法。这是只是介绍Kotlin的这种便利性而已。

3.4、可变数量参数

  • 当一个函数中的参数是不定数量的个数并且是同一个类型,则可是使用vararg修饰符去修饰这个变量,则被vararg修饰的参数相当于一个固定类型的数组。
  • 声明格式:fun 函数名(vararg 参数名 : 类型,...) :返回值{}

例:

fun varargFun(numA: Int, vararg str : String){
    // ...
}

其中,既然vararg修饰的变量相当于一个固定类型的数组,则我们可以对它进行一些高级的操作。这里只举例一些简单的用法,如果你有兴趣,可以参见我的另一篇文章Kotlin——泛型之数组详解

例:

fun varargFun(numA: Int, vararg str : String){
        // 遍历
    for (s in str) {

    }

// 获取元素
//    str[index]
//    str.component1() ... str.component5()

// 或者其高阶函数用法
//    str.map {  }
//    str.filter {  }
//    str.sortBy {  }

}

在传递参数值时,我们可以一个一个参数的传递,或者可以直接传递一个当前定义类型的数组。不过在传递数组时,请使用伸展操作符( * )

例:

普通传递 : varargFun(1,"aaa","bbb","ccc","ddd","fff")
数组传递:
        val strArray = arrayOf("aaa","bbb","ccc","ddd","fff")
        varargFun(1,*strArray)

四、单表达式函数

  • 上面提到了单表达式函数。这里详细的讲解一下。因为在结构体非常简单的情况下,使用单表达式函数还是能提高代码的阅读性的,并且可以少些两行代码。
  • 单表达式函数:即函数具备返回值的时候,可以省略花括号并且在=赋值符号之后指定代码体,而函数的返回值是有编辑器自动推断的。

例:

// 无参数的情况
fun test1() = 2                     // 自动推断为:返回类型为Int

// 有参数的情况
fun test2(num : Int) = num * 2      // 自动推断为:返回类型为Int

// 或者
fun test3(x : Float, y : Int = 2) = x * y  // 和默认参数一起使用,返回值为Float型

fun main(args: Array<String>) {
    println(test1())
    println(test2(2))
    println(test3(2f))
}

输出结果为:

2
4
4.0

总结

对于Kotlin中函数/方法的基本用法就讲解到这里,在后续的章节中,会为大家奉上函数的高级用法以及高阶函数的使用,并且会讲到其和lambda表达式的连用。

这一篇讲解的内容及其简单,如果您有编程经验您只要主要关注可变个数参数的函数,以及单表达式函数就可以额。

源代码

如果各位大佬看了之后感觉还阔以,就请各位大佬随便star一下,您的关注是我最大的动力。

我的个人博客Jetictors

我的掘金Jteictors

GithubJteictors

欢迎各位大佬进群共同研究、探索

QQ群号:497071402

原文地址:https://www.cnblogs.com/Jetictors/p/8506941.html

时间: 2024-09-27 22:40:58

Kotlin——基础的函数/方法详解的相关文章

Java基础之hashCode方法详解

想要明白hashCode的作用,必须要先知道java中的集合.(不明白的请看Java基础之集合框架详解(二)List篇和Java基础之集合框架详解(三)Set篇) Java中的Collection集合有两类,一类是List,另一类是Set,前者集合内的元素是有序的,元素可以重复:后者元素无序且元素不可重复.而我们通常使用Object.equals方法来判断两个元素是否重复.即当我们想查找一个元素中是否包含某个对象时,就是逐一取出每个元素与要找的元素进行比较,当发现某个元素与要查找的对象进行equ

memcache缓存函数方法详解

1.Memcache::add用法  代码:bool Memcache::add ( string $key , mixed $var [, int $flag [, int $expire ]] ) 说明: 如果$key不存在的时候,使用这个函数来存储$var的值.功能相同的函数是memcache_add(). 参数: $key :将要存储的键值. $var :存储的值,字符型和整型会按原值保存,其他类型自动序列化以后保存. $flag:是否用MEMCACHE_COMPRESSED来压缩存储的

C#基础 一(方法详解)

需要知道:类和方法的关系 方法和参数修饰符 自定义方法可以有或没有参数,也可以有或没有返回值.可以被各种关键字(static.virtual.public.new等)修饰以限制其行为. C#参数修饰符 无                                       如果一个参数没有用参数修饰符标记,则认为它将按值传递,这意味着被调用的方法收到原始数据的一份副本. out                                     输出参数由被调用的方法赋值,因此它按引

php调用C代码的方法详解和zend_parse_parameters函数详解

http://blog.csdn.net/super_ufo/article/details/3863731 php调用C代码的方法详解 在php程序中需要用到C代码,应该是下面两种情况: 1 已有C代码,在php程序中想直接用 2 由于php的性能问题,需要用C来实现部分功能 针对第一种情况,最合适的方法是用system调用,把现有C代码写成一个独立的程序.参数通过命令行或者标准输入传入,结果从标准输出读出.其次,稍麻烦一点的方法是C代码写成一个daemon,php程序用socket来和它进行

Python数据类型及其方法详解

Python数据类型及其方法详解 我们在学习编程语言的时候,都会遇到数据类型,这种看着很基础也不显眼的东西,却是很重要,本文介绍了python的数据类型,并就每种数据类型的方法作出了详细的描述,可供知识回顾. 一.整型和长整型 整型:数据是不包含小数部分的数值型数据,比如我们所说的1.2.3.4.122,其type为"int" 长整型:也是一种数字型数据,但是一般数字很大,其type为"long" 在python2中区分整型和长整型,在32位的机器上,取值范围是-2

JqGrid 使用方法详解

JQGrid JQGrid是一个在jquery基础上做的一个表格控件,以ajax的方式和服务器端通信. JQGrid Demo 是一个在线的演示项目.在这里,可以知道jqgrid可以做什么事情. 下面是转自其他人blog的一个学习资料,与其说是学习资料,说成查询帮助文档更加合适. jqGrid学习之 ------------- 安装 jqGrid安装很简单,只需把相应的css.js文件加入到页面中即可. 按照官网文档: /myproject/css/ ui.jqgrid.css         

jQuery插件制作方法详解

jQuery插件制作方法详解 jquery插件给我的感觉清一色的清洁,简单.如Jtip,要使用它的功能,只需要在你的元素的class上加 上Jtip,并引入jtip.js及其样式即可以了.其他事情插件全包.我喜欢jquery的一个重要原因是发现她已经有了很多很好,很精彩的插件.写一 个自己的jQuery插件是非常容易的,如果你按照下面的原则来做,可以让其他人也容易地结合使用你的插件. jquery插件给我的感觉清一色的清洁,简单.如Jtip,要使用它的功能,只需要在你的元素的class上加上Jt

objective C 内存管理及属性方法详解

oc为每个对象提供一个内部计数器,这个计数器跟踪对象的引用计数,当对象被创建或拷贝时,引用计数为1,每次保持对象时,调用retain接口,引用计数加1,如果不需要这个对象时调用release,引用计数减1,当对像的引用计数为0时,系统就会释放掉这块内存,释放对象调用dealloc 当对象包含其他对象时,就得在dealloc中自己释放他们 NSObject是IOS所有类的基类 有两个基本函数,alloc和dealloc alloc类似于C++的new,dealloc类似于delete 当对象的re

BigDecimal 使用方法详解

BigDecimal 使用方法详解 博客分类: java基础 bigdecimalmultiplyadddivide BigDecimal 由任意精度的整数非标度值 和 32 位的整数标度 (scale) 组成.如果为零或正数,则标度是小数点后的位数.如果为负数,则将该数的非标度值乘以 10 的负 scale 次幂.因此,BigDecimal 表示的数值是 (unscaledValue × 10-scale). 可以处理任意长度的浮点数运算. BigDecimal add(BigDecimal