当前位置: 首页 > news >正文

Kotlin 类

文章目录

  • 什么是类
  • 类的属性
  • 类的方法(行为)
  • 构造函数
    • 主构造
    • 次构造
  • 类的实例化(对象)
  • 伴生对象
  • this

什么是类

在 Kotlin 中,变量类型都是类,像我们常见的IntString等等,都是类。

为什么要分类?其实原因很多,就像有些时候,只要提起猫,你的脑海中立马浮现出猫捉老鼠、猫吃鱼······至少不是汪汪叫的猫。有了猫这一类别,我们就能很容易地将其与它所拥有的行为、特点联系起来。还有些情况,像是一个巨大的图书馆,如果各种书都没有一定规律地堆放在一起,我们很难去找到我们想要的书。

在 Kotlin 中,使用class去定义一个类:

class 类名 { 属性/方法 }

我们能够像描述一只猫一样去定义一个类,这样就足够了:

class Cat

类名首字母需要大写,而一般情况下变量和函数采用驼峰命名(首个单词小写,后面如果有其他单词,首字母大写):

class MyClassval myVariable = "变量"fun myFun() {}

类的属性

属性,例如一只猫是什么颜色的?有多高?喜欢吃什么?就是用于描述类状态的一系列变量。直接将其定义于类中即可:

class Cat {val name: String = "小橘"
}

类的方法(行为)

方法,或者叫函数,可定义该类所具有的行为:

class Fishclass Cat {fun eat(fish: Fish) {}
}

构造函数

构造函数可以让我们在初始化类对象(将猫这一类具体到某一只猫上)时传入参数,或者直接在构造函数中声明类的属性

主构造

可以在类名后加一个小括号,并写入对应的参数、属性。这与函数类似:

class 类名([[val|var] 属性名: 类型], [参数名: 类型], ...) { 属性/方法 }

我们可以给猫定义一些属性:

class Cat(var name: String, val color: String)

也可以给它们设置默认值:

class Cat(var name: String, val color: String = "橘色")

我们也可以使用lateinit var将其定义于类中,并使用init和参数将其初始化,constructor可省:

class Cat constructor(var name: String, colorParam: String) {lateinit var color: Stringinit {color = colorParam}
}

或者是直接将color赋值为colorParam

class Cat(var name: String, colorParam: String) {val color = colorParam
}

Note:Kotlin 中可以使用lateinit关键字修饰可变变量,这样变量就可以暂时不用赋值。但是在使用时如果还未赋值,就会抛出异常:kotlin.UninitializedPropertyAccessExceptionlateinit不支持基本类型(Primitive Types,包含数字、字符)和可空类型。

// 这些是不被允许的
// 数字
lateinit var byte: Byte
lateinit var short: Short
lateinit var int: Int
lateinit var long: Long
lateinit var float: Float
lateinit var double: Double
lateinit var boolean: Boolean
// 字符
lateinit var char: Char
// 任何可空类型
lateinit var nullableAny: Any?

次构造

很多时候主构造并不能满足我们的需求,我们可以再定义次构造。次构造使用constructor声明,必须基于主构造,使用this()调用主构造。

class Cat(val name: String, val color: String) {constructor(name: String): this(name, "橘色") {}
}fun main() {val myCat = Cat("小橘")println("${myCat.name}${myCat.color} 的")
}
小橘 是 橘色 的

类的实例化(对象)

可以像调用函数一样调用它,生成Cat对象,使用.即可访问对象的属性或方法(行为):

class Cat(val name: String, val color: String)fun main() {val myCat = Cat("小橘", "橘色")print("${myCat.name}${myCat.color} 的")
}
小橘 是 橘色 的

伴生对象

对象实例化后,每个对象都拥有自己的属性值(例如两个Cat对象可能有不同的color)。如果我们要声明一些该类所有对象都共有的,并且是不受对象影响的属性或方法,可以借助companion object来定义:

class Cat {companion object {const val FAMILY = "猫科"}
}

Note:在定义不可变的顶层变量(文件中的最外面)或对象变量(object)时,如果该变量为基本类型(Primitive Types,包含数字、字符)或String,则建议使用const关键字修饰。特别地,如果该变量为对象变量,IDEA会提示需要将变量名改为全大写:

object Object {const val NAME = "一个单词直接全大写"const val A_MULTI_WORDS_NAME = "多个单词需要加下划线分割"
}

我们可以通过以下两种方式来访问该属性(通常采用Cat.FAMILY):

fun main() {println(Cat.FAMILY)print(Cat.Companion.FAMILY)
}
猫科
猫科

本质上是定义一个对象object(默认名称为Companion),我们可以指定该对象的名称,这并不影响我们使用它:

class Cat {companion object CatCompanion {const val FAMILY = "猫科"}
}fun main() {println(Cat.CatCompanion.FAMILY)print(Cat.FAMILY)
}
猫科
猫科

甚至可以继承(Kotlin 中使用: 被继承类()表示继承,这将在后续文章提到):

class Cat {companion object CatCompanion: Base() {const val FAMILY = "猫科"}
}open class Base

Kotlin 并支持使用对象来访问伴生对象的属性或方法:

fun main() {val cat = Cat()// cat.FAMILY 这是错误的
}

this

Kotlin 类中可以使用this指定类中的属性或方法,这在很多时候是可以省略的。如果有时候出现混淆,可以通过使用this避免这一情况:

class Cat(var name: String) {fun changeName(name: String) {// 函数参数的 name 与 Cat 的 name 并不是同一个// 使用 this.name 指定 Cat 的 name// 如果不指定,默认会访问到最小范围内的 name// 这里的最小范围是函数作用域中的 namethis.name = name}
}

伴生对象中的this只能访问到伴生对象的属性或变量,因为它是独立于类对象的:

class Cat(var name: String) {companion object {const val FAMILY = "猫科"fun test() {this.FAMILY// this.name 错误的}}
}

在扩展函数中使用:

class Cat(var name: String)fun Cat.speck() {print("${this.name}: 喵喵喵")
}fun main() {Cat("小橘").speck()
}
小橘: 喵喵喵

相关文章:

Kotlin 类

文章目录 什么是类类的属性类的方法(行为)构造函数主构造次构造 类的实例化(对象)伴生对象this 什么是类 在 Kotlin 中,变量类型都是类,像我们常见的Int、String等等,都是类。 为什么要分类&a…...

Forth Python语言:深度解析其四维、五维、六维与七维之奥秘

Forth Python语言:深度解析其四维、五维、六维与七维之奥秘 在编程语言的浩瀚星空中,Forth Python以其独特的魅力与深邃的内涵,吸引着众多探索者的目光。然而,这门语言究竟有何独到之处?本文将从四维、五维、六维和七…...

MySQL--复合查询

之前学过了基本的查询,虽然已经够80%的使用场景了,但是依旧需要了解剩下的20%。 一、多表笛卡尔积(多表查询) 以前我们使用基本查询的时候,from后面就跟一张表名,在多表查询这里,from后面可以跟…...

前端项目开发,3个HTTP请求工具

这一小节,我们介绍一下前端项目开发中,HTTP请求会用到的3个工具,分别是fetch、axios和js-tool-big-box中的jsonp请求。那么他们都有哪些小区别呢?我们一起来看一下。 目录 1 fetch 2 axios 3 js-tool-big-box 的 jsonp 请求 …...

Java_Mybatis

Mybatis是一款优秀的持久层框架,用户简化JDBC(使用Java语言操作关系型数据库的一套API)开发 使用Mybatis查询所有用户数据: 代码演示: UserMapper: Mapper //被调用时会通过动态代理自动创建实体类,并放入IOC容器中…...

2024HW|常见红队使用工具

目录 什么是HW? 什么是网络安全红蓝对抗? 红队 常见工具 信息收集工具 Nmap 简介 漏洞扫描工具 Nessus简介 AWVS 简介 抓包工具 Wireshark简介 TangGo 简介 web 应用安全工具 Burpsuite 简介 SQLMap webshell 管理工具 蚁剑 冰蝎 后…...

Redisson集成SpringBoot

前言:Redisson集成SpringBoot主要有两种方式,一个是使用redisson-spring-boot-starter依赖(优先推荐),毕竟springboot主打的就是约定大于配置,这个依赖就是为springboot准备的。 再一种方式就是引入rediss…...

设计模式(十二)行为型模式---模板方法模式

文章目录 模板方法模式结构优缺点UML图具体实现UML图代码实现 模板方法模式 模板方法模式(Template Method)是一种基于继承实现的设计模式,主要思想是:将定义的算法抽象成一组步骤,在抽象类中定义算法的骨架&#xff…...

【气象常用】剖面图

效果图: 主要步骤: 1. 数据准备:我用的era5的散度数据(大家替换为自己的就好啦,era5数据下载方法可以看这里【数据下载】ERA5 各高度层月平均数据下载_era5月平均数据-CSDN博客) 2. 数据处理&#xff1a…...

LabVIEW高低温试验箱控制系统

要实现LabVIEW高低温试验箱控制系统,需要进行硬件配置、软件设计和系统集成,确保LabVIEW能够有效地监控和控制试验箱的温度。以下是详细说明: 硬件配置 选择合适的试验箱: 确定高低温试验箱的型号和品牌。 确认试验箱是否支持外…...

Flutter 中的 SliverFillViewport 小部件:全面指南

Flutter 中的 SliverFillViewport 小部件:全面指南 Flutter 是一个由 Google 开发的跨平台 UI 框架,它允许开发者使用 Dart 语言来构建高性能、美观的移动、Web 和桌面应用。在 Flutter 的丰富组件库中,SliverFillViewport 是一个用于 Custo…...

明日周刊-第12期

以前小时候最期待六一儿童节了,父母总会给你满足一个愿望,也许是一件礼物也许是一次陪伴。然而这个世界上其实还有很多儿童过不上儿童节,比如某些地区的小孩子,他们更担心的是能不能见到明天的太阳。 文章目录 一周热点航天探索火…...

算法之美阅读笔记

这里写自定义目录标题 序04 缓存 -- 忘了它吧 序 在图书馆闲逛时,一本封面为绿色的清新的书引起了我的兴趣,书名是算法之美。我心里不禁嘀咕,大家好喜欢使用某某之美作为书名,比如:数学之美、架构之美。美丽美好的事物…...

新手学习STM32还是ESP32

对于新手来说,选择学习STM32还是ESP32取决于个人的学习目标和背景。以下是针对这两种微控制器的详细分析,以便您做出更明智的选择: STM32 1. 处理器架构与性能 STM32采用单核或多核处理器架构,基于ARM Cortex-M0,M0…...

关于vlookup的第一个参数的个人理解

VLOOKUP(查阅值,包含查阅值和返回值的查找区域,查找区域中返回值的列号,精确查找或近似查找) 我个人理解,第一个参数应该叫线索值,因为我们要通过它去找与其对应的(也就是与其同行的…...

vector实现后半部分

一.迭代器失效 1.定义 指原迭代器在扩容/缩容/修改后指向无效元素或无效地址处 erase的迭代器失效 2.原因: 1.有的编译器实现erase会缩容拷贝 2.删除最后一个后,其指向无效元素 VS中不允许再次使用erase完的迭代器,为了让编写的代码移植…...

Maven配置

Maven – Download Apache Maven https://maven.apache.org/install.html 得下载有 bin的...

python 第一天

循环打印 while循环 languages ["Regional Assembly Language","Autocode","FORTRAN","IPL (LISP的先驱)","FLOW-MATIC (COBOL的先驱)","COMTRAN (COBOL的先驱)","LISP","ALGOL 58","F…...

Day03 左侧菜单数据绑定

一.左侧菜单数据绑定 1.首先,进行项目结构塔建。按照Prism 框架约定,要使用自动查找绑定功能。即View (视图)中自动查找并绑定到对应的ViewModel(视图模型,处理视图业务逻辑)。就需要在项目中按…...

JavaScript笔记三-JavaScript常用对象

1、数字对象(Number) 1.1 、属性 属性描述Number.MAX_VALUEJavaScript 中所能表示的最大值Number.MIN_VALUEJavaScript 中所能表示的最小值Number.NaN非数字Number.NEGATIVE_INFINITY负无穷,在溢出时返回Number.POSITIVE_INFINITY正无穷&am…...

[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?

🧠 智能合约中的数据是如何在区块链中保持一致的? 为什么所有区块链节点都能得出相同结果?合约调用这么复杂,状态真能保持一致吗?本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里&#xf…...

国防科技大学计算机基础课程笔记02信息编码

1.机内码和国标码 国标码就是我们非常熟悉的这个GB2312,但是因为都是16进制,因此这个了16进制的数据既可以翻译成为这个机器码,也可以翻译成为这个国标码,所以这个时候很容易会出现这个歧义的情况; 因此,我们的这个国…...

rknn优化教程(二)

文章目录 1. 前述2. 三方库的封装2.1 xrepo中的库2.2 xrepo之外的库2.2.1 opencv2.2.2 rknnrt2.2.3 spdlog 3. rknn_engine库 1. 前述 OK,开始写第二篇的内容了。这篇博客主要能写一下: 如何给一些三方库按照xmake方式进行封装,供调用如何按…...

Docker 运行 Kafka 带 SASL 认证教程

Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明:server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...

解锁数据库简洁之道:FastAPI与SQLModel实战指南

在构建现代Web应用程序时,与数据库的交互无疑是核心环节。虽然传统的数据库操作方式(如直接编写SQL语句与psycopg2交互)赋予了我们精细的控制权,但在面对日益复杂的业务逻辑和快速迭代的需求时,这种方式的开发效率和可…...

在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module

1、为什么要修改 CONNECT 报文? 多租户隔离:自动为接入设备追加租户前缀,后端按 ClientID 拆分队列。零代码鉴权:将入站用户名替换为 OAuth Access-Token,后端 Broker 统一校验。灰度发布:根据 IP/地理位写…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序

一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...

GitFlow 工作模式(详解)

今天再学项目的过程中遇到使用gitflow模式管理代码,因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存,无论是github还是gittee,都是一种基于git去保存代码的形式,这样保存代码…...

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...

git: early EOF

macOS报错: Initialized empty Git repository in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/.git/ remote: Enumerating objects: 2691797, done. remote: Counting objects: 100% (1760/1760), done. remote: Compressing objects: 100% (636/636…...