kotlin学习笔记(八)
来源:互联网 发布:怎么在淘宝投诉卖家 编辑:程序博客网 时间:2024/05/05 03:10
属性和字段
属性声明
在 Kotlin 中类可以有属性,我们可以使用 var 关键字声明可变属性,或者用 val 关键字声明只读属性。
public class Address { public var name: String = ... public var street: String = ...public var city: String = ... public var state: String? = ...public var zip: String = ...}
我们可以像使用 java 中的字段那样,通过名字直接使用一个属性:
fun copyAddress(address: Address) : Address {val result = Address() //在 kotlin 中没有 new 关键字result.name = address.name //accessors are calledresult.street = address.street}
Getter 和 Setter
声明一个属性的完整语法如下:
var <propertyName>: <PropertyType> [ = <property_initializer> ]<getter><setter>
语法中的初始化语句,getter 和 setter 都是可选的。如果属性类型可以从初始化语句或者类的成员函数中推断出来,那么他的类型也是忽略的。
例子:
var allByDefault: Int? // 错误: 需要一个初始化语句, 默认实现了 getter 和 setter 方法var initialized = 1 // 类型为 Int, 默认实现了 getter 和 setter
只读属性的声明语法和可变属性的声明语法相比有两点不同: 它以 val 而不是 var 开头,不允许 setter 函数:
val simple: Int? // 类型为 Int ,默认实现 getter ,但必须在构造函数中初始化val inferredType = 1 // 类型为 Int 类型,默认实现 getter
我们可以像写普通函数那样在属性声明中自定义的访问器,下面是一个自定义的 getter 的例子:
var isEmpty: Booleanget() = this.size == 0
下面是一个自定义的setter:
var stringRepresentation: Stringget() = this.toString()set (value) {setDataFormString(value) // 格式化字符串,并且将值重新赋值给其他元素}
为了方便起见,setter 方法的参数名是value,你也可以自己任选一个自己喜欢的名称.
如果你需要改变一个访问器的可见性或者给它添加注解,但又不想改变默认的实现,那么你可以定义一个不带函数体的访问器:
var settVisibilite: String = "abc"//非空类型必须初始化private set // setter 是私有的并且有默认的实现var setterVithAnnotation: Any?@Inject set // 用 Inject 注解 setter
备用字段
在 kotlin 中类不可以有字段。然而当使用自定义的访问器时有时候需要备用字段。出于这些原因 kotlin 使用 field
关键词提供了自动备用字段,
var counter = 0 //初始化值会直接写入备用字段set(value) {if (value >= 0)field = value}
field
关键词只能用于属性的访问器.
编译器会检查访问器的代码,如果使用了备用字段(或者访问器是默认的实现逻辑),就会自动生成备用字段,否则就不会.
比如下面的例子中就不会有备用字段:
val isEmpty: Booleanget() = this.size == 0
备用属性
如果你想要做一些事情但不适合这种 "隐含备用字段" 方案,你可以试着用备用属性的方式:
private var _table: Map<String, Int>? = nullpublic val table: Map<String, Int>get() {if (_table == null)_table = HashMap() //参数类型是推导出来的return _table ?: throw AssertionError("Set to null by another thread")}
综合来讲,这些和 java 很相似,可以避免函数访问私有属性而破坏它的结构
编译时常量
那些在编译时就能知道具体值的属性可以使用 const
修饰符标记为 编译时常量. 这种属性需要同时满足以下条件:
在"top-level"声明的 或者 是一个object的成员(Top-level or member of an object)
以
String
或基本类型进行初始化没有自定义getter
这种属性可以被当做注解使用:
const val SUBSYSTEM_DEPRECATED: String = "This subsystem is deprecated"@Deprected(SUBSYSTEM_DEPRECATED) fun foo() { ... }
延迟初始化属性
通常,那些被定义为拥有非空类型的属性,都需要在构造器中初始化.但有时候这并没有那么方便.例如在单元测试中,属性应该通过依赖注入进行初始化, 或者通过一个 setup 方法进行初始化.在这种条件下,你不能在构造器中提供一个非空的初始化语句,但是你仍然希望在访问这个属性的时候,避免非空检查.
为了处理这种情况,你可以为这个属性加上 lateinit
修饰符
public class MyTest {lateinit var subject: TestSubject@SetUp fun setup() {subject = TestSubject()}@Test fun test() {subject.method() }}
这个修饰符只能够被用在类的 var 类型的可变属性定义中,不能用在构造方法中.并且属性不能有自定义的 getter 和 setter访问器.这个属性的类型必须是非空的,同样也不能为一个基本类型.
在一个延迟初始化的属性初始化前访问他,会导致一个特定异常,告诉你访问的时候值还没有初始化.
复写属性
参看复写成员
代理属性
最常见的属性就是从备用属性中读(或者写)。另一方面,自定义的 getter 和 setter 可以实现属性的任何操作。有些像懒值( lazy values ),根据给定的关键字从 map 中读出,读取数据库,通知一个监听者等等,像这些操作介于 getter setter 模式之间。
像这样常用操作可以通过代理属性作为库来实现。更多请参看这里。
- kotlin学习笔记(八)
- Kotlin学习笔记(八)对象
- Kotlin笔记(八)Lambda表达式
- Kotlin学习笔记(一)
- kotlin学习笔记(二)
- kotlin学习笔记(三)
- kotlin学习笔记(四)
- kotlin学习笔记(四)
- kotlin学习笔记(五)
- kotlin学习笔记(六)
- kotlin学习笔记(七)
- kotlin学习笔记(二)
- Kotlin学习笔记(一)
- kotlin 学习笔记(1)
- Kotlin 学习笔记(2)
- Kotlin学习笔记(一)
- Kotlin学习笔记(二)
- kotlin学习笔记(一)
- 后台返回数据快速赋值到页面封装js
- Reuters-21578 数据集处理
- java 编写代码实现Stack类 ,采用单链表
- 字符相似性几种度量方法
- 【Windows】快捷键操作指南
- kotlin学习笔记(八)
- java实现遍历树形菜单方法——service层
- 金庸群侠传之武林浩荡1.7全隐藏完整攻略流程(图文)
- JAVA-POI导出excel表格
- python3 windows 编码问题
- 连接
- IAR 开发STM8 学习
- sin(a+b)的展开式证明
- 算法——图之无向图