怎样解析Kotlin属性-创新互联

本篇文章给大家分享的是有关怎样解析Kotlin属性,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

创新互联是一家专业提供英吉沙企业网站建设,专注与成都网站制作、成都做网站、外贸营销网站建设HTML5建站、小程序制作等业务。10年已为英吉沙众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。

在Kotlin类中可以有属性。属性可以用关键字var声明为可变的,否则使用只读关键字val


属性

1.属性定义

使用var关键字声明可变的属性,属性包含默认的getter和setter方法

class PropertyAndField {
    var propertyA: String = ""
    var propertyB: String = ""
}

如果类型有具体的值,其类型可以省略

var name = "zhangsan"

使用val关键字声明只读属性,val声明的变量不允许有setter方法,默认有getter方法

class Address {
    //默认getter和setter
    var name: String = "zhangsan"
    //默认只有getter方法
    val readonly = "readonly"
}

使用属性

fun main(args: Array<String>) {
    var address = Address()
    //访问属性,自动调用其getter方法
    address.name
    address.readonly
}

2.自定义getter和setter


class Address2 {
    //自定义了setter方法 setter属性可以不被初始化
    var name: String
        get() = this.name
        set(value) {
            this.name = value
        }
}

省略属性的类型。在getter方法可以推断出属性的类型时可以省略

val no get() = 23

对于val声明的属性只能有getter方法


val readonly: String
    get() = "readonly"
    //set(value){this.readonly = value}  错误。val属性不能有setter

改变属性访问器的可见性

class Address3 {
    var name: String = "lisi"
        private set   //改变默认setter方法的可见性

    var no: Int = 22
        private set(no){this.no = no}  //改变自定义setter方法的可见性
}

编译期常量

已知类型和值的属性可以标记为编译期常量。有以下几点要求

  1. 位于顶层或者是 object 的一个成员

  2. 类型为String或原始类型

  3. 没有自定义getter

编译器常量使用const修饰符来标记

const val CONST_NO = "success"

延迟初始化属性

当属性声明为非空的必须在构造函数中初始化。但是这很不方便,例如属性可以通过依赖注入来初始化,或者使用单元测试的setup注解初始化。你仍然想在类体中引用该属性时避免空检查。这个

时候可以使用lateinit修饰符来标记属性

class Order {
    lateinit var address: Address
}

以上就是怎样解析Kotlin属性,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

本文题目:怎样解析Kotlin属性-创新互联
文章出自:https://www.cdcxhl.com/article12/ccesgc.html

成都网站建设公司_创新互联,为您提供营销型网站建设用户体验网站设计App开发域名注册全网营销推广

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网页设计公司