2024年最全Kotlin学习手记——构造器、init块、工厂函数,2024年最新vivo安卓开发面试

尾声

评论里面有些同学有疑问关于如何学习material design控件,我的建议是去GitHub搜,有很多同行给的例子,这些栗子足够入门。

有朋友说要是动真格的话,需要NDK以及JVM等的知识,首现**NDK并不是神秘的东西,**你跟着官方的步骤走一遍就知道什么回事了,无非就是一些代码格式以及原生/JAVA内存交互,进阶一点的有原生/JAVA线程交互,线程交互确实有点蛋疼,但平常避免用就好了,再说对于初学者来说关心NDK干嘛,据鄙人以前的经历,只在音视频通信和一个嵌入式信号处理(离线)的两个项目中用过,嵌入式信号处理是JAVA->NDK->.SO->MATLAB这样调用的我原来MATLAB的代码,其他的大多就用在游戏上了吧,一般的互联网公司会有人给你公司的SO包的。
至于JVM,该掌握的那部分,相信我,你会掌握的,不该你掌握的,有那些专门研究JVM的人来做,不如省省心有空看看计算机系统,编译原理。

一句话,平常多写多练,这是最基本的程序员的素质,尽量挤时间,读理论基础书籍,JVM不是未来30年唯一的虚拟机,JAVA也不一定再风靡未来30年工业界,其他的系统和语言也会雨后春笋冒出来,但你理论扎实会让你很快理解学会一个语言或者框架,你平常写的多会让你很快熟练的将新学的东西应用到实际中。
初学者,一句话,多练。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

在这里插入图片描述

lateinit 这玩意好像有坑,kotlin中的新玩意,大神都嫌弃它,我们可以了解一下,既然是坑我们不用去记住它,免得被坑。。

在这里插入图片描述

lazy是比较推荐的延迟初始化方式,实际上它是一个属性代理

在这里插入图片描述

在这里插入图片描述接口代理其实就是可以把一些没必要实现的接口方法隐藏起来不去实现,方便一些,而不用每一个接口都要写一下。其中by关键字右边的就是实际代理类对象,它是构造函数中的一个属性,by关键字左边的是代理类对象实现的接口。

例子:

//超级数组 同时支持list和map接口,通过接口代理的方式不必实现list和map接口的所有方法

class SuperArray(

private val list: MutableList<E?> = ArrayList(),

private val map: MutableMap<Any, E> = HashMap()

) : MutableList<E?> by list, MutableMap<Any, E> by map {

override fun isEmpty() = list.isEmpty() && map.isEmpty()

override val size: Int

get() = list.size + map.size

override fun clear() {

list.clear()

map.clear()

}

override operator fun set(index: Int, element: E?): E? {

if (list.size <= index) {

repeat(index - list.size + 1) {

list.add(null)

}

}

return list.set(index, element)

}

override fun toString(): String {

return “”“List: [ l i s t ] ; M a p : [ list]; Map: [ list];Map:[map]”“”

}

}

fun main() {

val superArray = SuperArray()

val superArray2 = SuperArray()

superArray += “Hello”

superArray[“Hello”] = “World”

superArray2[superArray] = “World”

superArray[1] = “world”

superArray[4] = “!!!”

println(superArray)

println(superArray2)

}

在这里插入图片描述

在这里插入图片描述

lazy属性代理 代理了Person实例的firstName的getter方法,实际是一个函数 传递一个lambda表达式

class Person(val name: String){

//lazy属性代理 代理了Person实例的firstName的getter方法

// 实际是一个函数 传递一个lambda表达式

val firstName by lazy {

name.split(" ")[0]

}

val lastName by lazy {

name.split(" ")[1]

}

}

observable代理属性,监听set值变化:

class StateManager {

//observable代理属性,监听set值变化

var state: Int by Delegates.observable(0) {

property, oldValue, newValue ->

println(“State changed from $oldValue -> $newValue”)

}

}

自定义代理属性:

class Foo {

val x: Int by X()

var y: Int by X()

}

class X {

operator fun getValue(thisRef: Any?, property: KProperty<*>): Int {

return 2

}

operator fun setValue(thisRef: Any?, property: KProperty<*>, i: Int) {

}

}

其中getValue和setValue方法的参数写法是固定的

调用:

fun main() {

val stateManager = StateManager()

stateManager.state = 3

stateManager.state = 4

println(Foo().x)

}

自定义实例:读取Config.properties中的配置项

Config.properties文件中一般是key-value的配置

author=xxxx

version=1.0

desc=This is a demo.

class PropertiesDelegate(private val path: String, private val defaultValue: String = “”){

private lateinit var url: URL

private val properties: Properties by lazy {

val prop = Properties()

url = try {

javaClass.getResourceAsStream(path).use {

prop.load(it)

}

javaClass.getResource(path)

} catch (e: Exception) {

try {

ClassLoader.getSystemClassLoader().getResourceAsStream(path).use {

prop.load(it)

}

ClassLoader.getSystemClassLoader().getResource(path)!!

} catch (e: Exception) {

FileInputStream(path).use {

prop.load(it)

}

URL(“file://${File(path).canonicalPath}”)

}

}

prop

}

operator fun getValue(thisRef: Any?, property: KProperty<*>): String {

return properties.getProperty(property.name, defaultValue)

}

operator fun setValue(thisRef: Any?, property: KProperty<*>, value: String) {

properties.setProperty(property.name, value)

File(url.toURI()).outputStream().use {

properties.store(it, “Hello!!”)

}

}

}

abstract class AbsProperties(path: String){

protected val prop = PropertiesDelegate(path)

}

class Config: AbsProperties(“Config.properties”){

var author by prop

var version by prop

var desc by prop

}

fun main() {

val config = Config()

println(config.author)

总结

现在新技术层出不穷,如果每次出新的技术,我们都深入的研究的话,很容易分散精力。新的技术可能很久之后我们才会在工作中用得上,当学的新技术无法学以致用,很容易被我们遗忘,到最后真的需要使用的时候,又要从头来过(虽然上手会更快)。

我觉得身为技术人,针对新技术应该是持拥抱态度的,入了这一行你就应该知道这是一个活到老学到老的行业,所以面对新技术,不要抵触,拥抱变化就好了。

Flutter 明显是一种全新的技术,而对于这个新技术在发布之初,花一个月的时间学习它,成本确实过高。但是周末花一天时间体验一下它的开发流程,了解一下它的优缺点、能干什么或者不能干什么。这个时间,并不是我们不能接受的。

如果有时间,其实通读一遍 Flutter 的文档,是最全面的一次对 Flutter 的了解过程。但是如果我们只有 8 小时的时间,我希望能关注一些最值得关注的点。

(跨平台开发(Flutter)、java基础与原理,自定义view、NDK、架构设计、性能优化、完整商业项目开发等)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

的了解过程。但是如果我们只有 8 小时的时间,我希望能关注一些最值得关注的点。

(跨平台开发(Flutter)、java基础与原理,自定义view、NDK、架构设计、性能优化、完整商业项目开发等)

[外链图片转存中…(img-jYl3s5Ap-1715888482469)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 21
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值