与接口一样,继承抽象类也是加冒号,不过后面的抽象类要写构造函数。同样,覆写抽象类中的方法全部都要加override关键字。另外,如果想要某个被覆写的方法不能再被子类覆写,加上final即可,与java一样。

  • 普通类继承:

open class SimpleClass(var x: Int, val y: String) {

open fun zzz(string: String){

}

//final方法不能被覆写

final override fun overridable(){

}

}

//继承类

class SimpleClass2(x: Int, y: String): SimpleClass(x, y){

override fun zzz(string: String){

}

}

如果类要被子类继承,则要被继承的类名和方法名前面都要加open关键字,否则不能被继承和覆写。

  • 属性引用:

class Person(age: Int, name: String) {

var age: Int = age

var name: String = name

}

fun main() {

val ageRef = Person::age

val person = Person(18, “Bennyhuo”)

val nameRef = person::name //绑定接受者的属性引用,调用set的时候可以不用传接受者

ageRef.set(person, 20)

nameRef.set(“Andyhuo”)

}

扩展方法和扩展属性:

class PoorGuy{

var pocket: Double = 0.0

}

//定义类的扩展方法

fun PoorGuy.noMoney() {

println(“noMoney”)

}

//定义类的扩展属性 property = backing field + getter + setter

var PoorGuy.moneyLeft: Double

get() {

return this.pocket

}

set(value) {

pocket = value

}

就是在类定义大括号之外,再后续给类定义方法和属性,有点像java静态方法的调用形式,但这样定义的是成员方法和属性,并不是java中那样的静态方法。

fun main() {

val poorGuy = PoorGuy()

poorGuy.noMoney()

println(poorGuy.moneyLeft)

poorGuy.moneyLeft = 10000.0

println(poorGuy.moneyLeft)

}

类和扩展方法不一定在同一个kt文件中,但必须在方法的外层定义,即不能在某个函数方法中定义,必须是顶层的,如不能在main方法中定义。

fun Person.eat(s : String) {

println(“eat$s”)

}

var Person.howOld: Int

get() {

return this.age

}

set(value) {

age = value

}

fun main() {

val eat = Person::eat

val person = Person(10, “张三”)

person.eat(“aaa”)

eat(person, “222”)

println(person.howOld)

}

上面文件中只要导入Person这个类就可以给它定义扩展方法。

  • 给系统类添加扩展方法:

//给String类定义扩展方法 给String前后加count个空格

fun String.padding(count: Int, char: Char = ’ '): String {

//生成重复count次的空格连续串

val padding = (1 … count).joinToString(“”){ char.toString() }

return “ p a d d i n g {padding} padding{this}${padding}”

}

//给String类定义扩展方法 判断字符串是否是邮箱

fun String.isEmail(): Boolean {

return matches(Regex(“(?:[a-z0-9!# %&'*+/=?^_`{|}~-]+(?:\\.[a-z0-9!# %&'+/=?^_`{|}~-]+)|”(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21\x23-\x5b\x5d-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])")@(?😦?:a-z0-9?\.)+a-z0-9?|\[(?😦?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-][a-z0-9]:(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21-\x5a\x53-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])+)\])"))

}

//给String类定义扩展方法 字符串重复count次

fun String.times(count: Int): String {

return (1 … count).joinToString(“”) { this }

}

上面是给String类定义扩展方法,使用起来简单:

fun main() {

println(“admin@bennyhuo.com”.isEmail())

println(“Hello”.padding(10))

println(“*”.times(10))

//定义对扩展方法的引用

val stringTimes = String::times

val stringTimesBound = “*”::times

}

只要字符串点方法名即可, 看到这个顿时感觉便捷性这块kotlin确实比java强了太多!

空类型安全:

  • kotlin中,指定类型的变量不能赋值为null,即空类型安全

var nonNull: String = “Hello”

nonNull = null //赋值为空,这一行编译器会报错

val length = nonNull.length //这样使用是安全的

就是说kotlin中明确的类型是不能赋值为一个null值的,这与java明显不同。

  • 定义可接受null类型的变量,在类型后面加一个

var nullable: String? = “Hello”

val length = nullable?.length //安全访问可能为空的变量

这时变量可能为null, 所以要判空,判空方式 ?. 比java简洁,有点类似js语法。

但是用 ?.操作符之后,如果变量为null,则最终等号左边的变量结果 也可能为null, 因此在使用length之前还要再判断length是否为null.

var nullable: String? = “Hello”

val length = nullable?.length ?: 0 //确保length不为空的写法 等价三目运算 boolean? a : b

其中操作符 ?:等价于三目运算符,length 为null 返回右边的,不为null返回左边的。

说明: String 类型是 String? 类型的子类, Int 类型是 Number 类型的子类,使用遵循里氏替换原则:所有使用父类的地方都可以使用子类替换,反之则不行

var x: String = “Hello”

var y: String? = “World”

// x = y // Type mismatch

y = x // OK

var a: Int = 2

var b: Number = 10.0

// a = b // Type mismatch

b = a // OK

  • 引用其他平台语言的对象要使用?. 判空:

java类

public class Person {

@Nullable

public String getTitle(){

return null;

}

}

kotlin类

val person = Person() // 创建一个java的Person类实例

val title = person.title // 此时的title类型是java平台的String类型,不是kotlin的String类型

//kotlin中无法判断title的实际类型是来自哪个平台的,所以主动添加?.可确保安全访问
这里我就分享一份资料,希望可以帮助到大家提升进阶。

内容包含:Android学习PDF+架构视频+面试文档+源码笔记高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 这几块的内容。分享给大家,非常适合近期有面试和想在技术道路上继续精进的朋友。

如果你有需要的话,可以点击Android学习PDF+架构视频+面试文档+源码笔记获取免费领取方式

喜欢本文的话,不妨给我点个小赞、评论区留言或者转发支持一下呗~

img

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-Nzd2ELgD-1710971098190)]
[外链图片转存中…(img-pmo9viF9-1710971098191)]
[外链图片转存中…(img-8xmj7V1e-1710971098191)]
[外链图片转存中…(img-lL0pimtW-1710971098191)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
[外链图片转存中…(img-cenTHZsI-1710971098192)]

Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐