运算符的重载
预定义的运算符的操作对象只能是基本数据类型,实际上,对于很多用户自定义的类型,也需要有类似的运算操作。
运算符重载,是对已有的运算符赋予多重含义,使同一个运算符作用于不同类型的数据时,产生不同的行为,得出不同的结果。
运算符重载的实质是函数重载。在实现过程中,首先把指定的运算表达式转换为对运算符函数的调用,运算对象转换为运算符函数的实参,然后根据实参的类型来确定要调用的函数,这个过程在编译过程中完成。
fun main(args: Array<String>) {
//这里的 .. 就是通过运算符的重载来实现表达一个区间的功能
//step 就是一个中缀表达式,是对前面区间的一个描述
//运算符的重载,中缀表达式,本质上都是特殊的函数,在Kotlin中都是通过函数的调用来完成的
for(i in 1..100 step 20){
println("$i")
}
/**
* cmd+左键查看 .. 的源码
* 会发现一个rangeTo的函数,该函数被operator关键字修饰,就重载了 .. 的实现
*
*/
/**
* 在Kotlin中,使用infix关键字修饰的函数
* 就表示该函数是可以以中缀的形式来使用的
*/
/**
* 关于中缀表达式
* 一个函数只有拥有两个角色类似的对象时,才将其声明为中缀函数
*
* 约定:如果一个方法会改动其接受者,那么不要声明为中缀表达式,避免可读性太低
*/
}
中缀(infix)表达式演示
package zyf.kotlin
/**
* 创建一个密闭类(相当于java中的枚举类)
*/
sealed class MyInfix{
object LESS:MyInfix(){
override fun toString(): String {
return "小于"
}
}
object MORE:MyInfix(){
override fun toString(): String {
return "大于"
}
}
object EQUAL:MyInfix(){
override fun toString(): String {
return "等于"
}
}
}
/**
* 使用infix关键字,定义一个中缀表达式
* 这里的 Int.vs
* 就表示,为 Int 类型扩展一个方法,该方法名为 vs
* 接受一个 Int 类型的参数变量
* 返回值为 MyInfix (我们上面定义的密闭类)
*
*/
infix fun Int.vs(num:Int):MyInfix =
if(this - num >0){
MyInfix.MORE
}else if (this-num<0){
MyInfix.LESS
}else{
MyInfix.EQUAL
}
fun main(args: Array<String>) {
println(7 vs 9)
}