Kotlin——幕后属性、延迟初始化属性

kotlin 复制代码
class BackingProgress(name:String){
    //定义private修饰的属性,该属性是幕后属性
    private var _name:String =name

    /**
     * 幕后属性主要是实现封装和数据的隐藏,幕后属性允许开发者为类的属性创建一个隐藏的、
     * 私有的字段,这个字段只有内部方法可以访问,通过幕后属性,可以将属性的读写操作
     * 封装在内部类时间中,对外只暴露安全的访问方法,这样,可以在不破坏封装的前提下,对
     * 内部数据执行额外的操作
     */
    var name
        //重写getter方法,返回幕后属性的值
        get() = _name
        set(newName){
            //执行合理性校验,要求用户名必须在2~6位之间
            if (newName.length >6 ||newName.length<2){
                println("您设置的人名不符合要求")
            }else{
                //对幕后属性赋值
                _name = newName
            }
        }
}

fun main(args: Array<String>) {
    var p =BackingProgress("李刚")
    //访问p.name,实际商会转为访问幕后属性_name
    println(p.name)
    //对p.name赋值,实际上会转为对幕后属性_name赋值
    p.name = "孙悟空"
    println(p.name)
}

延迟初始化属性

kotlin 复制代码
class User {
    lateinit var name: String
    lateinit var birth:Date
}
fun main(args: Array<String>) {
    var user = User()
//    println(user.name) //lateinit property name has not been initialized
    user.name ="你好你好"
    println(user.name)
}
相关推荐
以和为贵10 小时前
前端也能搞懂 RAG:用 JS 手写一条最小检索增强链路
前端·人工智能·面试
风止何安啊10 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
牧艺10 小时前
用 Next.js + React Three Fiber 打造 3D 快递仓储可视化
前端·three.js
锋行天下11 小时前
如何用Vite实现Vue组件的按需打包和远程加载
前端·vue.js·前端框架
光影少年11 小时前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
糖拌西瓜皮11 小时前
Node.js核心模块实战:文件、路径、HTTP与流处理
javascript·node.js
糖拌西瓜皮11 小时前
NestJS入门指南:Java开发者的Spring Boot体验
javascript·node.js
糖拌西瓜皮12 小时前
Express框架快速上手:中间件、路由与错误处理
javascript·node.js
禅思院13 小时前
前端部署“三层漏斗”完全指南:从CI/CD到自动回滚的工程化实战【开题】
前端·架构·前端框架
快乐肚皮14 小时前
深入理解Loop Engineering
前端·后端