kotlin之操作符重载
一元操作符
表达式 | 对应的函数 |
+a | a.unaryPlus() |
-a | a.unaryMinus() |
!a | a.not() |
a++ | a.inc() |
a-- | a.dec() |
fun main(arg: Array<String>) {
var a = "a"
println(a++)
println(a)
println(++a)
}
operator fun String.inc():String{//重载String的++
return this +this
}
二元操作符
表达式 | 对应的函数 |
a+b | a.plus(b) |
a-b | a.minus(b) |
a*b | a.tims(b) |
a/b | a.div(b) |
a%b | a.mod(b) |
a.b | a.rangeTo(b) |
a in b | b.contains(a) |
a !in b | !b.contains(a) |
fun main(arg: Array<String>) {
var s= "hello"
print(s*10) }
//重载乘法操作符
operator fun String.times(other:Any?):String{
var result = ""
if (other!= null){
if (other is Int)
for (i in 1..other){
result+=this
}
}
return result
}
方括号操作符重载
表达式 | 对应的函数 |
a[i] | a.get(i) |
a[i,j] | a.get(i,j) |
a[i_1,...,i_n] | a.get(i_1,..,i_n) |
a[i]=b | a.set[i,b] |
a[i,j]=b | a.set(i,j,b) |
a..b | a.rangeTo(b) |
a[i_1,...,i_n]=b | a.set(i_1,..i_n,b) |
fun main(arg: Array<String>) {
val arr1 :Array<Any> = arrayOf("3", "2")
val arr2 :Array<Any> = arrayOf("9", "8") println("arr1[1] = ${arr1[1]}")
println("arr2[1] = ${arr2[1]}") val arr3 = arrayOf(arr1, arr2)
println("arr3[0][0] = ${arr3[0][0]}") }
//重载一维数组[i]操作符
operator fun Array<Any>.get(i:Int):Int{
if (this[i] is Int){
return this[i] as Int
}else if (this[i] is String){
try {
return this[i].toString().toInt()
}catch (e:Exception){ }
}
return 0
}
//重载二维数组[i][j]操作符
operator fun Array<Array<Any>>.get(i:Int,j:Int):Int{
if (this[i][j] is Int){
return this[i][j] as Int
}else if (this[i][j] is String){
try {
return this[i][j].toString().toInt()
}catch (e:Exception){ }
}
return 0
}
赋值操作符重载
表达式 | 对应的函数 |
a+=b | a.pulsAssign(b) |
a-=b | a.minusAssign(b) |
a*=b | a.timesAssign(b) |
a/=b | a.divAssign(b) |
a%=b | a.modAssign(b) |
fun main(arg: Array<String>) {
val myString = myString()
myString.value="sss"
myString*=3
print(myString) }
class myString{
var value :String = "hello"
override fun toString(): String {
return "myString(value='$value')"
} } operator fun myString.timesAssign(n:Int):Unit{
val v =this.value
for (i in 1..n-1)
this.value+=v
}
逻辑操作符重载
表达式 | 对应的函数 |
a>b | a.compaerTo(b)>0 |
a<b | a.compaerTo(b)<0 |
a>=b | a.compaerTo(b)>=0 |
a<=b | a.compaerTo(b)<=0 |
a==b | a?.equals(b)?(b==null) |
a!=b | !a?.equals(b)?(b==null) |
fun main(arg: Array<String>) { val myClass1 = myClass(1, 2)
val myClass2 = myClass(1, 2)
val myClass3 = myClass(3, 4)
println(myClass1 == myClass2)
println(myClass3 == myClass2)
} class myClass(a: Int, b: Int) {
private var a: Int = a
private var b: Int = b
operator fun compareTo(c: myClass): Int {
var m = this.a + this.b
var n = c.a + c.b
return m - n } override fun equals(other: Any?): Boolean {
if (this === other) return true
if (javaClass != other?.javaClass) return false other as myClass if (a != other.a) return false
if (b != other.b) return false return true
} override fun hashCode(): Int {
var result = a
result = 31 * result + b
return result
} }
kotlin之操作符重载的更多相关文章
- Kotlin 之操作符重载
Kotlin 之操作符重载 参考: kotlin in action kotlin 官方参考文档 运算符重载 Kotlin允许我们为自己的类型提供预定义的一组操作符实现(这些操作符都对应的成员函数 ...
- Kotlin操作符重载:把标准操作加入到任何类中(KAD 17)
作者:Antonio Leiva 时间:Mar 21, 2017 原文链接:https://antonioleiva.com/operator-overload-kotlin/ 就像其他每种语言一样, ...
- Kotlin——最详细的操作符与操作符重载详解(上)
本篇文章为大家详细的介绍Koltin特有的操作符重载.或许对于有编程经验的朋友来说,操作符这个词绝对不陌生,就算没有任何编辑基础的朋友,数学中的算数运算符也绝不陌生.例如(+.-.*./.>.& ...
- c++ 操作符重载和友元
操作符重载(operator overloading)是C++中的一种多态,C++允许用户自定义函数名称相同但参数列表不同的函数,这被称为函数重载或函数多态.操作符重载函数的格式一般为: operat ...
- paip.操作符重载的缺失 Java 的一个大缺点
paip.操作符重载的缺失 Java 的一个大缺点 #----操作符重载的作用 1.提升用户体验 操作符重载..可以让代码更加自然.... 2.轻松实现代码代码移植 例如 java代码会直接移植到 ...
- C#中如何利用操作符重载和转换操作符
操作符重载 有的编程语言允许一个类型定义操作符应该如何操作类型的实例,比如string类型和int类型都重载了(==)和(+)等操作符,当编译器发现两个int类型的实例使用+操作符的时候,编译器会生成 ...
- 操作符重载.xml
pre{ line-height:1; color:#1e1e1e; background-color:#d2d2d2; font-size:16px;}.sysFunc{color:#627cf6; ...
- [置顶] operator overloading(操作符重载,运算符重载)运算符重载,浅拷贝(logical copy) ,vs, 深拷贝(physical copy)
operator overloading(操作符重载,运算符重载) 所谓重载就是重新赋予新的意义,之前我们已经学过函数重载,函数重载的要求是函数名相同,函数的参数列表不同(个数或者参数类型).操作符重 ...
- C++一些注意点之操作符重载
重载操作符需要注意 (1)重载操作符必须具有一个类类型操作数.不能重载内建类型的操作符. operator +(int,int);//这个是错误的,都为内建类型 operator +(int,clas ...
随机推荐
- 关于stm32 SDIO初始化TF卡 失败的问题
类似问题:http://www.openedv.com/thread-33232-1-1.html 现象:初始化4bit SDIO模式的TF卡,卡死在初始化过程中. 问题现象代码移植于野火开发板相关例 ...
- jmeter——http、jdbc、soap请求
1.jmeter——http 请求 1.1添加线程组 1.2添加http请求 1.3发起http请求 1.协议:通常一个http请求都会有相对应的协议,如HTTP,HTTPS等.这里除非有特殊要求,一 ...
- python学习之非空即为真,函数,集合
python基础 非空即真,非零即真 #之前代码:sex = input("请输入性别:") if sex != '': print("输入成功") else: ...
- 可能是最全面的 Python 字符串拼接总结
来源: 枫恋寒 链接: https://segmentfault.com/a/119000001.png"font-size: 12px;"> 在 Python 中字符串连接 ...
- Java锁--ReentrantLock
转载请注明出处:http://www.cnblogs.com/skywang12345/p/3496101.html ReentrantLock介绍 ReentrantLock是一个可重入的互斥锁,又 ...
- 优雅的退出和调用服务器close() 方法
在开发中,创建这种“友好的”退出方式的一种方法就是,将服务器的 while 循环放在一个 try-except 语句中的 except 子句中,并监控 EOFError 或 KeyboardInter ...
- 前端面试题-HTML+CSS
引用GitHub 上 ltadpoles的前端面试 https://github.com/ltadpoles HTML部分 1. Doctype作用,HTML5 为什么只需要写<!DOCTYPE ...
- C指针的运算
指针的运算在数组中才有意义 int *p; p++,一定是在一片连续的区域才有意义,当然越界也会带来诸多问题. void main() { ; int *p = #//这根本无界可言 ...
- SIGAI深度学习第九集 卷积神经网络3
讲授卷积神经网络面临的挑战包括梯度消失.退化问题,和改进方法包括卷积层.池化层的改进.激活函数.损失函数.网络结构的改 进.残差网络.全卷机网络.多尺度融合.批量归一化等 大纲: 面临的挑战梯度消失问 ...
- Maratona Brasileira de Popcorn( 二分答案+暴力 )
题意:输入三个数n,c,t . 桌子上有n堆爆米花,每一堆有ai个, 现在有c个人一起吃爆米花,每人每分钟最多能吃t个爆米花,但有两个规定:1.一堆爆米花只能一个人吃, 2.每个人只能吃连续的若干堆爆 ...