Kotlin快速入门4

news2024/11/19 19:38:05

Kotlin的类与对象

类的定义

Kotlin使用关键字class来声明类。后面紧跟类名字:

class LearnKotlin { //类名:LearnKotlin
    //...
}

Kotlin的类可以包含:构造函数和初始化代码块、函数、属性、内部类、对象声明。当然,也可以定义一个空类。

class Empty

类的属性

属性定义

类的属性可用var声明为可变的,否则使用关键字val声明为不可变。

class LearnKotlin {
    var IDE : String = "..."
    var practiceTime : Int = 0
    var studyReason : String = "..."
}

Kotlin没有new关键字,但我们可以像使用普通函数那样使用构造函数创建类实例:

class KotlinPractice {
    val lkt = LearnKotlin()
}

要调用或者改变其中一个属性,只需要名称引用它即可:

lkt.IDE       //使用 . 号来引用
lkt.practiceTime

当我们需要知道一个密闭的类所有属性时,可以采用反射的方式获取:

var lkt = LearnKotlin()
lkt.javaClass.getDeclaredFields().forEach { field -> println(field.name) }

Kotlin中的类可以有一个主构造方法,以及一个或者多个次构造方法。主构造方法是类头部的一部分,位于类名称之后:

class Person constructor(name: String){}

如果主构造方法没有任何注解,也没有任何修饰符,那么constructor关键字可以省略。

class Person (name: String){}

gettersetter

kotlin中,getter和setter是可选的,如果你没有在代码中创建它们,它是会默认自动生成。如上述代码:

class LearnKotlin {
    var IDE : String = "..."
    var practiceTime : Int = 0
    var studyReason : String = "..."
}

相当于:

class LearnKotlin {
    var IDE : String = "..."
    var practiceTime : Int = 0
    var studyReason : String = "..."
    set(value) {
        field = value
    }
    get() = field
}

Kotlin 中类不能有字段。提供了后端变量(Backing Fields)机制,备用字段使用field关键字声明,field关键词只能用于属性的访问器,如以上实例:

需要注意的是:

1、field关键字代表的是当前域(是不是想起了Java中的this?)。

2、val不允许设置setter函数,因为它是只读的。

下面的变量声明示例和IDE提示可以看出var和val在声明上的差别:

主构造函数方法 

java中没有主次构造函数(方法)之分,但是kotlin有。且一个kotlin类可以有一个主构造函数和多个次构造函数。

主构造函数(方法)中一般不包含任何代码,初始化代码可以放在初始化代码段中,初始化代码段使用 init 关键字作为前缀。

class KotlinPractice constructor(fileName : String){
    init {
        println("FileName is $fileName")
    }
}

主构造函数的参数可以在初始化代码段中使用。

次构造函数方法

也叫二级构造函数(方法),申明前缀有constructor修饰:

class KotlinPractice {
    //次构造函数
    constructor (fileName: String) {
        // 初始化...
    }
}

如果类中有一个主构造函数,每个次构造函数需要委托给主构造函数,可以直接委托或者通过别的构造函数。

class KotlinPractice constructor(fileName : String){
    constructor (fileName: String, fileSize: Int) : this(fileName) {
        // 初始化...
    }
}

如果一个非抽象类没有声明构造函数(主或次构造函数),它会产生一个没有参数的构造函数。构造函数是 public 。如果你不想你的类有公共的构造函数,你就得声明一个空的主构造函数:

class DoNotCreateMe private constructor () {
}

(在 JVM 虚拟机中,如果主构造函数的所有参数都有默认值,编译器会生成一个附加的无参的构造函数,这个构造函数会直接使用默认值。)

数据类

在kotlin中声明数据类极其简单,只需要使用data这个关键字在类前面声明即可。

data class MobilePhone(val brand:String,val price:Double)

当在一个类前面声明data关键字时,就表明你希望这个类是一个数据类,kotlin会根据主构造函数里的参数将equals()、hashCode()、toString()等固定且没有实际逻辑意义的方法自动生成。此外,当一个类中没有任何代码时,还可以将尾部的大括号省略。

抽象类

与Java一样,通过abstract关键字声明。抽象成员在类中不存在具体的实现。(注意:无需对抽象类或抽象成员标注open注解,open注解用法将在下篇文章讲到)

嵌套类和内部类

我们可以把一个类嵌套在其他类中,这种类称作嵌套类。而内部类使用inner关键字来表示。内部类会带有一个对外部类的对象的引用,所以内部类可以访问外部类成员属性和成员函数。

有的时候,为了消除歧义更好理解代码,要访问来自外部作用域的 this,我们使用this@label,其中 @label 是一个 代指 this 来源的标签。

class Outer {                  // 外部类
    private val num: Int = 100
    var value = "成员变量"
    class Nest {             // 嵌套类
        fun foo() = 2
    }
    inner class Inner {       // 内部类
        fun foo() = num  // 访问外部类成员
        fun innerTest() {
            var o = this@Outer //获取外部类的成员变量
            println("内部类可以引用外部类成员,例如:" + o.value)
        }
    }
}

fun main(args: Array<String>) {
    val demo = Outer.Nest().foo() // 嵌套类调用格式:外部类.嵌套类.嵌套类方法/属性
    println(demo)

    val inner = Outer().Inner().foo()
    println(inner) //   1
    val inTest = Outer().Inner().innerTest()
    println(inTest)   // 内部类可以引用外部类的成员属性等
}

对应控制台输出为:

这里需要注意的是,嵌套类和内部类在调用时的重要区别:

var nestDemo = Outer.Nest()// 嵌套类,Outer后边没有括号
var innerDemo = Outer().Inner();// 内部类,Outer后边有括号

匿名内部类

kotlin使用对象表达式来创建匿名内部类,使用方式与Java类似,以下为调用接口示例(如果对接口使用有疑问,不要慌,下一篇会讲到)。这里,object 是 Kotlin 的关键字,要实现匿名内部类,就必须使用 object 关键字,不能随意替换其它单词。

class Outer {
    var value = "成员变量"
    fun setInterFace(test: TestInterFace) {
        test.test()
    }
}

interface TestInterFace {
    fun test()
}

fun main(args: Array<String>) {
    var test = Outer()  //声明类对象

    test.setInterFace(object : TestInterFace{
        override fun test() {
            println("创建匿名内部类的实例")
        }
    })
}

类的修饰符

与Java类似,类的修饰符包含类属性修饰符(classModifier)和访问权限修饰符(accessModifier)。

类属性修饰符,标示类本身特性:

abstract    // 抽象类  
final       // 类不可继承,默认属性
enum        // 枚举类
open        // 类可继承,类默认是final的
annotation  // 注解类

访问权限修饰符:

private    // 仅在同一个文件中可见
protected  // 同一个文件中或子类可见
public     // 所有调用的地方都可见
internal   // 同一个模块中可见

示例如下:

// 文件名:LearnKotlin.kt
package ktlearn

private fun foo() {} // 在 LearnKotlin.kt 内可见

public var num: Int = 5 // 该属性随处可见

internal val nit = 6    // 相同模块内可见

End,如有问题请留言。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1417267.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

BGP:05 BGP自动路由汇总

路由汇总&#xff0c;能有效地减少 BGP 路由器通告的路由条目数量&#xff0c;减小设备的路由表规模&#xff0c;并将拓扑变化产生的影响限制在一个相对更小的范围内。 自动路由聚合是在自然边界路由器上自动执行的&#xff0c;在默认情况下&#xff0c;BGP的自动路由聚合功能是…

go包与依赖管理

包&#xff08;package&#xff09; 包介绍 Go语言中支持模块化的开发理念&#xff0c;在Go语言中使用包&#xff08;package&#xff09;来支持代码模块化和代码复用。一个包是由一个或多个Go源码文件&#xff08;.go结尾的文件&#xff09;组成&#xff0c;是一种高级的代码…

springboot134英语知识应用网站的设计与实现

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…

深度强化学习(王树森)笔记07

深度强化学习&#xff08;DRL&#xff09; 本文是学习笔记&#xff0c;如有侵权&#xff0c;请联系删除。本文在ChatGPT辅助下完成。 参考链接 Deep Reinforcement Learning官方链接&#xff1a;https://github.com/wangshusen/DRL 源代码链接&#xff1a;https://github.c…

C++多线程2(复习向)

lock_guard lock_guard是C中提供的对互斥锁有关操作的高级接口&#xff0c;可对互斥锁进行自动上锁和解锁&#xff0c;多用于作为局部变量。&#xff08;在对象创建时&#xff0c;构造函数中自动为传入的互斥锁对象上锁&#xff0c;局部变量被系统回收时&#xff0c;其析构函数…

消失的数字(c语言多种解法)

题目 该题目取自力扣&#xff08;LeetCode&#xff09;面试题 17.04. 消失的数字 该题目主要考察时间复杂度的把握&#xff0c;题目如下&#xff1a; 数组nums包含从0到n的所有整数&#xff0c;但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗&a…

幻兽帕鲁服务器出租,腾讯云PK阿里云怎么收费?

幻兽帕鲁服务器价格多少钱&#xff1f;4核16G服务器Palworld官方推荐配置&#xff0c;阿里云4核16G服务器32元1个月、96元3个月&#xff0c;腾讯云换手帕服务器服务器4核16G14M带宽66元一个月、277元3个月&#xff0c;8核32G22M配置115元1个月、345元3个月&#xff0c;16核64G3…

【MySQL】补充和navicat的一些简单使用

文章目录 前言在这里插入图片描述 事情起因因为这个articlecount的c是小写了&#xff0c;我想改成大写 一、修改二、navicat的使用步骤1.连接2.建库&#xff0c;建表 三.填写数据总结 前言 事情起因因为这个articlecount的c是小写了&#xff0c;我想改成大写 提示&#xff1a;…

[css] 让文字进行竖着 分散对齐

.demo2 {width: 60px;background-color: aqua;height: 200px;display: grid;place-items: center;}参考&#xff1a; css 让文字进行竖着书写&#xff0c; 附带个小知识&#xff0c;行内块元素添加文字之后底部对不齐的问题

系统架构15 - 软件工程(3)

软件过程模型 瀑布模型特点缺点 原型化模型特点两个阶段不同类型注意 螺旋模型V 模型特点 增量模型特点 喷泉模型基于构件的开发模型(CBSD)形式化方法模型敏捷模型特点“适应性” (adaptive) 而非“预设性” (predictive)“面向人的” (People-oriented) 而非“面向过程的” (P…

动态规划算法题刷题笔记

首先看动态规划的三要素&#xff1a;重叠子问题、最优子结构和状态转移方程。 重叠子问题&#xff1a;存在大量的重复计算 最优子结构&#xff1a; 状态转移方程&#xff1a;当前状态转移成以前的状态 动态规划的解题步骤主要有&#xff1a; 确定 dp 数组以及下标的含义状…

【Redis】Redis有哪些适合的场景

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;Redis ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 &#xff08;1&#xff09;会话缓存&#xff08;Session Cache&#xff09; &#xff08;2&#xff09;全页缓存&#xff08;FPC…

JetpackCompose 之 状态学习

1.无状态组件 1.1导入依赖 implementation("androidx.core:core-ktx:1.9.0")implementation("androidx.lifecycle:lifecycle-runtime-ktx:2.6.1")implementation("androidx.activity:activity-compose:1.7.0")implementation(platform("an…

MyBatis详解(3)-- 动态代理及映射器

MyBatis详解&#xff08;3&#xff09; mybatis 动态代理动态代理的规范selectOne和selectListnamespace mybatis映射器映射器的引入&#xff1a; 映射器的组成select 元素结构&#xff1a;单个参数传递多个参数传递 insert 元素结构主键回填&#xff1a;自定义主键生成规则 u …

CSS 双色拼接按钮效果

<template><view class="sss"><button> <!-- 按钮 --><view class="span"> 按钮 </view> <!-- 按钮文本 --></button></view></template><script></script><style>body {b…

JUC-ReentrantLock,ReentrantReadWriteLock,StampedLock

1. 概述 前面介绍过了synchronized关键字作用的锁升级过程 无锁->偏向锁->轻量锁->重锁 下面再介绍实现Lock接口的锁的升级过程 无锁->独占锁&#xff08;ReentrantLock&#xff0c;Synchronized&#xff09;->读写锁(ReentranReadWriteLock)->邮戳锁(Stamp…

app逆向-apktool逆向工具安装使用

文章目录 一、前言二、安装三、执行 一、前言 apktool是一个能够解析和分析安卓应用文件&#xff08;APK&#xff09;的工具&#xff0c;帮助了解应用程序的内部结构和功能。 二、安装 window版本 下载地址&#xff1a;版本2.9.3&#xff0c;并将下载的 jar 重命名为apktoo…

【缓存周总结】Redis缓存的使用以及数据安全的处理

前言 Redis非关系型数据库已经是很常见的工具了&#xff0c;项目中用到的也很多&#xff0c;这篇文章系统的分析下使用过程中可能会遇到的问题 一、缓存 缓存是数据交换的缓冲区&#xff0c;是存贮数据的临时地方&#xff0c;一般读写性能较高。 我们项目中引用的Redis目的就是…

SPI:JDK 与 SpringBoot

浅谈Java SPI原理与其在JDBC、Flink中的应用 API&#xff1a;由被调方提供的实现了某个完整功能的接口&#xff0c;主调方直接调用该接口来享用该功能&#xff0c;而无需关注该接口的具体实现。比如使用 JDK 的 InputStream#read 从文件系统中读取数据。 SPI&#xff1a;被调方…

DOM 型 XSS 攻击演示(附链接)

一、介绍 DOM&#xff08;Document Object Model&#xff09;型 XSS&#xff08;Cross-Site Scripting&#xff09;攻击是一种 Web 应用程序中的安全漏洞&#xff0c;其特点是攻击者成功地注入了恶意脚本&#xff0c;这些脚本在用户的浏览器中执行&#xff0c;从而导致恶意行为…