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

Kotlin面向对象基础使用方法(继承、接口、Lambda、空指针检查机制等)

三、面向对象

1、继承

1.1 open改变类的继承属性

在kotlin设计时默认所有的非抽象类是无法被继承的,如果想要使得一个非抽象类可以被继承,我们需要使用open关键字。

open class Person {var name ="";var age = 0;fun eat() {println(name + " is eating. He is " + age +" years old.")}
}

同理如果类中的方法需要继承也需要使用open关键字

1.2 主构造函数与次构造函数

主构造函数:

  • 主构造函数的特点是没有函数体,直接定义在类名后面即可。
  • 主构造函数只能有一个,而且通常用于初始化类的属性,以及执行与类的整体初始化相关的操作。
  • 主构造函数的参数可以带有默认值,从而允许创建对象时省略某些参数。

我们使用init关键字编写主构造函数的逻辑

class Person(val name: String, val age: Int) {init {println("Person对象已创建,姓名:$name,年龄:$age")}
}

注意:

在主构造函数中声明val、var的字段会自动成为该类的字段,这样就会导致和父类中同名的字段冲突。如果不使用val、var关键字数据的作用域仅限定在主构造函数中。

image-20230907182600740

副构造函数:

  • 副构造函数是类中的额外构造函数,可以有多个,它们用constructor关键字声明。
  • 副构造函数通常用于提供不同的构造方式,允许使用不同的参数组合来创建对象。
class Person(val name: String, val age: Int) {// 主构造函数init {println("Person对象已创建,姓名:$name,年龄:$age")}// 副构造函数1,接受姓名参数constructor(name: String) : this(name, 0) {println("副构造函数1被调用")}// 副构造函数2,接受年龄参数constructor(age: Int) : this("未知姓名", age) {println("副构造函数2被调用")}
}

1.3 继承的格式

格式:

class 新的类名(无/参数) : 被继承类(无/参数){}

重写类的继承方法需要关键字override,并且被重写的方法需要有open关键字修饰。

open class Person(val name:String,val age:Int) {open fun eat() {println(name + " is eating. He is " + age +" years old.")}}class Student(val sno:String,val age1:Int) : Person(sno,age1){override fun eat(){println("$name Dont $age")}
}fun main(){var i = Student("JAck",19)i.eat()
}

kotlin规定,当一个类既有主构造函数又有次构造函数,所有的次构造函数都必须调用主构造函数。

open class Person(val name:String,val age:Int) {fun eat() {println(name + " is eating. He is " + age +" years old.")}}class Student(val sno:String,val grade:Int,name: String,age: Int) : Person(name,age){//通过次构造函数调用主构造函数constructor(name: String,age: Int) : this("",0,name,age){}constructor() : this("",0)
}fun main(){var i = Student("JAck",19)var p = Student("abs",1,"jaks",1)i.eat()
}

在这里this的用法是什么??

在这个类中,this关键字的使用是为了调用不同构造函数的目的。

具体来说,这个Student类具有以下构造函数:

  1. 主构造函数:Student类的主构造函数接受四个参数,分别是snogradenameage。这些参数用于初始化类的属性,其中snograde是继承自Person类的属性,而nameage是本类的属性。
  2. 第一个副构造函数:这个副构造函数接受两个参数,即nameage,它通过使用this关键字来**调用了主构造函数,**传递了空字符串 ""0 作为参数,这意味着它将调用主构造函数以初始化snograde属性,并且将传递的nameage参数用于初始化本类的属性。
  3. 第二个副构造函数:这个副构造函数不接受任何参数,它同样通过使用this关键字来**调用了第一个副构造函数,**传递了空字符串 "" 和零 0 作为参数,从而也会触发调用主构造函数,并且初始化本类的属性。

2、接口

接口的基本用法和java一致,但是在kotlin中允许代码对接口中的方法进行默认实现。

interface Study{fun readBooks()fun doHomework(){println("ANT")}
}

3、数据类——Java中toString、equals、hashCode的省略

在kotlin中我们不必写这些繁琐的方法,直接使用关键字data即可,代码如下:

//使用data修饰
data class Cellphone(val brand: String,val price: Double) {
}fun main(args: Array<String>) {val cellphone1 = Cellphone("Samsung",1299.99)val cellphone2 = Cellphone("Samsung",1299.99)println(cellphone1)println( "cellphone1 == cellphone2 ??   "+(cellphone1 == cellphone2))
}

image-20230907204200998

Kotlin会根据主构造函数中的参数帮你将equals(),hash Code(),toString()等固定且无实际逻辑意义的方法自动生成。

4、单例类——object关键字

在kotlin中创建一个单例类的方式极其简单,只需要将class关键字改为object关键字即可。

object Singleton {fun singletonTest(){println("This is a OneInstance")}
}

此时Singleton就是一个单例类了,我们可以在这个类中直接编写需要的函数。

可以看出在Kotlin中我们不需要私有化构造函数。

5、Lambda编程

5.1 集合的创建和遍历

5.11 List集合

5.111、listOf

一般情况下我们需要使用这种方式初始化:

    val list = ArrayList<String>()list.add("Apple")list.add("Banana")list.add("Orange")

在kotlin中提供了一个内置的listOf函数来简化初始化集合的写法。

val list = listOf<String>("Apple","Banana","Orange")

当然我们也可以使用for-in遍历这个集合,并且Kotlin会自动补全fruit的类型。

    for(fruit in list){println(fruit)}

image-20230910204303363

不过需要注意的是使用listOf创建的集合是一个不可变集合,就是该集合只能用于读取操作。

为什么会不可修改呢?

image-20230910205556031

通过源码我们发现底层是数组的存储方式这样就能解释listOf`创建的集合只能用于读写操作了,同样他的查询效率也是比较高的。

5.112、mutableListOf

使用mutableListOf创建的集合是一个可变集合,可以对集合进行增删改查的操作。

image-20230910205431981

查看源码可以发现创建的是一个Arraylist类型的集合。使用链表的形式存储。

5.12 Set类型

Set集合的用法基本上和List集合的一样,只不过创建集合的方式变成了setOf()mutableSetof()

5.13 Map类型

Map类的的基本创建方法和Java中是一致的。

    val map = HashMap<String, Int>()map.put("Apple",1)map.put("Banana",2)map.put("Orange",3)

当然kotlint在Map中同样提供了mapOfmutableMapOf方法用于集合的创建。Kotlin 的 mapOfmutableMapOf 在底层都使用哈希表(Hash Table)作为存储结构,mapOf是数组存储,mutableMapOfLinkedHash

val map = mapOf("Apple" to 1,"Banana" to 2,"Orange" to 3)for((fruit,number) in map){println(fruit + number)
}

需要注意的时这里的to不是关键字而是一个infix函数。

Kotlin 中,infix函数允许你以更自然的方式使用中缀表示法调用函数。

image-20230911124706544

5.2 集合函数式API

5.21 Lambda表达式的优化过程

{参数名:参数类型 -> 函数体}

val maxLengthFruit = list.maxBy({fruit:String -> fruit.length})
  • Kotlin规定当Lambda参数是函数的最后一个参数时,可以将Lambda表达式移到括号外面
val maxLengthFruit = list.maxBy(){fruit:String -> fruit.length}
  • 如果Lambda表达式是函数的唯一个参数,还可以将括号省略。而且kotlin具有出色的推到机制,我们还可以不声明参数类型。
val maxLengthFruit = list.maxBy{fruit -> fruit.length}
  • 并且当Lambda表达式参数列表只有一个参数时,也不必要声明参数名。可以使用it代替
val maxLengthFruit = list.maxBy{it.length}

5.22 常用API

  1. 计算最大长度:maxBy{it.length}

  2. 小写转大写:map { it.uppercase() }

  3. 过滤集合中的数据:filter函数

    val newList = list.filter { it.length > 5 }.map { it.uppercase() }
    
  4. 判断集合是否存在至少一个元素满足要求:any.{}

  5. 判断集合是否所有元素都满足要求:all.{}

    val anyResult = list.any{it.length >= 5}
    val allResult = list.all { it.length >= 10 }
    

    image-20230911173431696

6、空指针检查机制

Kotlin将空指针检查机制提到了编译时期,它默认所有的参数和变量都是非空的。

那么我们应该如何表示一个可空的类型呢?

6.1 ?

很简单在类名后加一个?代表可以是非空整形,例如:
I n t ? Int? Int
但是此时就可能出现潜在的空指针异常风险,那么我们应该如何解决呢?Kotlin提供了一个辅助判空工具——?.。

6.2 辅助判空工具

6.2.1 ?.

例如这段代码:

if(A != null){A.do()
}

可以简化为这样的形式:

A?.do()

6.2.2 ?:

例如这段代码:

if(A != null){A
}else{B
}

可以简化为以下形式:

Val c = A ?: C

左边表达式不为空就返回左边的值,否则返回右边的值。

6.2.3 非空断言工具——!!

Kotlin的这种检查机制在某些情况下也会出现问题,例如:

image-20230911194503533

此时是无法通过编译的,因为uppercase无法知道content不是空值。

此时就需要一种断言工具——!!

val upString = content!!.uppercase()

这是一种有风险的写法,意在告诉Kotlin,这里对象肯定不是空你不需要帮我检查空指针。

6.2.4 let辅助工具

这个函数提供了函数式API的编程接口,并将原始对象作为参数传递到Lambda表达式中。

obj.let{ obj1 ->//业务逻辑}

在这里,obj和obj1实际上是同一个对象。

如使用let修改这一段代码:

fun doStuday(study: Study?) {study?.doHomework()study?.readBooks()
}

修改结果如下:

fun doStuday(study: Study?) {study?.let {it.readBooks()it.doHomework()}
}

let是可以处理全局变量的判空问题但是if不行,因为if可以导致别的线程修改了这个全局变量。

相关文章:

Kotlin面向对象基础使用方法(继承、接口、Lambda、空指针检查机制等)

三、面向对象 1、继承 1.1 open改变类的继承属性 在kotlin设计时默认所有的非抽象类是无法被继承的&#xff0c;如果想要使得一个非抽象类可以被继承&#xff0c;我们需要使用open关键字。 open class Person {var name "";var age 0;fun eat() {println(name …...

Android USB电源管理

The USB peripheral detects the lack of 3 consecutive SOF packets as a suspend request from the USB host. 1 驱动shutdown顺序 系统关机或重启的过程中&#xff0c;会调用设备驱动的shutdown函数来完成设备的关闭操作&#xff0c;有需要的设备可以在驱动中定义该函数。其…...

YOLO目标检测——路标数据集+已标注voc和yolo格式标签下载分享

实际项目应用&#xff1a;自动驾驶、视频监控和安防、物体识别和分类、城市规划和地理信息系统等等数据集说明&#xff1a;YOLO路标目标检测数据集&#xff0c;真实场景的高质量图片数据&#xff0c;数据场景丰富&#xff0c;图片格式为jpg&#xff0c;共900张图片&#xff0c;…...

Item-Based Recommendations with Hadoop

Mahout在MapReduce上实现了Item-Based Collaborative Filtering&#xff0c;这里我尝试运行一下。 安装Hadoop 从下载Mahout并解压 准备数据 下载1 Million MovieLens Dataset&#xff0c;解压得到ratings.dat&#xff0c;用 sed ‘s/:&#x1f626;[0-9]{1,}):&#x1f626;…...

基于物理层网络编码的相位同步算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ..........................................................................%数据长度 Len…...

数据结构——七大排序[源码+动图+性能测试]

本章代码gitee仓库&#xff1a;排序 文章目录 &#x1f383;0. 思维导图&#x1f9e8;1. 插入排序✨1.1 直接插入排序✨1.2 希尔排序 &#x1f38a;2. 选择排序&#x1f38b;2.1 直接选择排序&#x1f38b;2.2 堆排序 &#x1f38f;3. 交换排序&#x1f390;3.1 冒泡排序&#…...

G. The Morning Star

Problem - G - Codeforces 思路&#xff1a;想了挺长时间的&#xff0c;一直没想到一个简便的方法在瞎搞。我们发现对于某个点来说&#xff0c;其他的点如果能够跟他匹配&#xff0c;那么一定在这8个方向上&#xff0c;而同时这8个方向其实对应这4条直线&#xff0c;假设点为(x…...

电池的健康状态 SOH 估计

电池的健康状态 SOH 估计 SOH&#xff08;State of Health&#xff09;估计通常用于描述电池的健康状态&#xff0c;即电池当前容量与初始容量的比值。 一种常见的SOH估计方法是基于经验的电池寿命预测方法&#xff0c;包括循环周期数法、安时法与加权安时法、面向事件的老化…...

Web 安全之 Permissions Policy(权限策略)详解

什么是 Permissions Policy&#xff08;权限策略&#xff09;&#xff1f; Permissions Policy 为 web 开发人员提供了明确声明哪些功能可以在网站上使用&#xff0c;哪些功能不能在网站上使用的机制。可以设置一组策略&#xff0c;用于限制站点代码可以访问的 API 或者修改浏…...

【黄啊码】nginx如何设置php运行的

禁止访问 PHP 脚本可以通过 Nginx 服务器配置中的多种方式来实现。以下是其中的一些常见方法&#xff0c;您可以根据实际需求选择合适的方式&#xff1a; 1 禁用 PHP 解析&#xff1a; 在 Nginx 配置中&#xff0c;确保 PHP 脚本无法被解析&#xff0c;从而禁止 PHP 执行。 lo…...

无涯教程-JavaScript - ISPMT函数

描述 ISPMT函数计算在特定投资期间支付的利息。提供此功能是为了与Lotus 1-2-3兼容。 语法 ISPMT (rate, per, nper, pv)争论 Argument描述Required/OptionalRateThe interest rate for the investment.RequiredPerThe period for which you want to find the interest, an…...

LeetCode 面试题 03.05. 栈排序

文章目录 一、题目二、C# 题解 一、题目 栈排序。 编写程序&#xff0c;对栈进行排序使最小元素位于栈顶。最多只能使用一个其他的临时栈存放数据&#xff0c;但不得将元素复制到别的数据结构&#xff08;如数组&#xff09;中。该栈支持如下操作&#xff1a;push、pop、peek 和…...

构建微服务项目时启动网关服务失败的解决方案

启动网关服务时报“Unable to create the temporary folder: C:\WINDOWS\TEMP\/nio-file-upload”错误。 代码与之前没有任何变化&#xff0c;但就是启动不了&#xff0c;观察错误意思大概是不能创建临时文件夹&#xff1a;C盘下的WINDOWS下的TEMP目录下的nio-file-upload这个东…...

零基础教程:使用yolov8训练无人机VisDrone数据集

1.准备数据集 1.先给出VisDrone2019数据集的下载地址&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1e2Q0NgNT-H-Acb2H0Cx8sg 提取码&#xff1a;31dl 2.将数据集VisDrone放在datasets目录下面 2.数据集转换程序 1.在根目录下面新建一个.py文件&#xff0c;取名叫…...

【Mysql专题】使用Mysql做排行榜,线上实例

背景 我们这里有个需求&#xff0c;对存量用户的余额做排行处理&#xff0c;这个实现方式很多&#xff0c;这边介绍的是&#xff0c;通过Mysql直接实现&#xff0c;将排名也直接返回出来。 我知道大家在网上能找到一大把这种实例&#xff0c;我在这里可不是【重复造轮子】。我…...

matlab数据处理: cell table array+datetime

原数据文件.csv matlab xlsread(filename{i},B2:T2881) 会同于Excel最多1048576行 舍弃 a{1,i} xlsread(filename{i},‘B2:T2881’);%读取excel文件,选定区域’B2:G2881’ readcell(filename{i},Range,E2:M2881) 会全部读取 优选 对于日期 yyyy-MM-dd HH:mm:ss.000 matlab cel…...

如何应用运营商大数据精准营销?

如何应用运营商大数据精准营销&#xff1f; 越来越多的企业逐渐觉察到运营商大数据所带来的商业价值&#xff0c;精准营销也被他们用的越来越娴熟。那么&#xff0c;企业的大数据精准营销该如何应用呢&#xff1f;想必是很多资源有限的中小型公司最想了解的。 一 数据驱动运营…...

AJAX学习笔记5同步与异步理解

AJAX学习笔记4解决乱码问题_biubiubiu0706的博客-CSDN博客 示例 前端代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>演示AJAX同步和异步</title> </head> <body> <script…...

911面试

WebPack分包 webpack分包 ts泛型 ts泛型 优化if-else和switch 优化if-else 左侧固定&#xff0c;右侧自适应 左侧固定&#xff0c;右侧自适应...

【Java基础篇 | 面向对象】—— 继承

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【JavaSE_primary】 本专栏旨在分享学习JavaSE的一点学习心得&#xff0c;欢迎大家在评论区讨论&#x1f48c; 继承允许一个类继承另一个…...

DELL precision上安装nvidia A4000驱动 cuda cudnn

一、安装驱动 参考这篇文章进行安装Ubuntu安装Nvidia显卡驱动_Kevin__47的博客-CSDN博客 【出现问题】 禁用nouveau后出现黑屏&#xff0c;有几行代码&#xff0c;断线一直在闪 【解决方法】 1、参考这篇文章Ubuntu20.04安装nvidia显卡驱动并解决重启后黑屏问题_ubuntu安装…...

数据结构算法刷题(29)动态规划

思路一&#xff1a;回溯&#xff1a;按照选和不选的判断方式&#xff0c;使用回溯来解决这个问题。 class Solution: def rob(self, nums: List[int]) -> int: n len(nums) #数组的长度 def dfs(i): if i<0: #到达边界条件后 return 0 #返回最大金额是0 res max(dfs(i…...

W11下CMake MinGW配置OpenCV和Qt

&#x1f482; 个人主页:风间琉璃&#x1f91f; 版权: 本文由【风间琉璃】原创、在CSDN首发、需要转载请联系博主&#x1f4ac; 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦 前言 前几天将cuda版本的opencv给编译成功了&#xff0c;当时用的VS的MSVC&…...

反转字符串 反转字符串 || 反转字符串 |||

思想总结&#xff1a;首先将字符串转变为字符数组&#xff0c;再进行遍历并反转字符。 1.反转字符串 代码&#xff1a; class Solution {public void reverseString(char[] s) {reverse(s,0,s.length); //左闭右开}public static void reverse(char[] ch,int i,int j) { 翻转函…...

XML解析 不允许有匹配 _[xX][mM][lL]_ 的处理指令目标

以上错误是在解析xml参数时候报出的。 我这里错误的原因在于&#xff0c;<?xml version\"1.0\" encoding\"UTF-8\"?>少了个空格&#xff0c;参考下图&#xff1a; 下面一行才是对的。...

【C++进阶(五)】STL大法--list模拟实现以及list和vector的对比

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:C从入门到精通⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习C   &#x1f51d;&#x1f51d; list模拟实现 1. 前言2. list类的大致框架与结构…...

Docker安装RabbitMQ集群_亲测成功

先安装Docker Centos7离线安装Docker 华为云arm架构安装Docker RabbitMQ集群模式介绍 RabbitMQ集群搭建和测试总结_亲测 RabbitMQ 有三种模式&#xff1a;单机模式&#xff0c;普通集群模式&#xff0c;镜像集群模式。单机模式即单独运行一个 rabbitmq 实例&#xff0c;而…...

50道基础数据结构面试题

程序员必备的50道数据结构和算法面试题 在本文中&#xff0c;将分享一些常见的编程面试问题&#xff0c;这些问题来自于不同经验水平的程序员&#xff0c;囊括从刚大学毕业的人到具有一到两年经验的程序员。 编码面试主要包括数据结构和基于算法的问题&#xff0c;以及一些诸…...

【Linux基础】权限管理

​&#x1f47b;内容专栏&#xff1a; Linux操作系统基础 &#x1f428;本文概括&#xff1a; 用户之间的切换、sudo提权、Linux权限管理、文件访问权限的相关方法、目录权限、粘滞位等 &#x1f43c;本文作者&#xff1a; 阿四啊 &#x1f438;发布时间&#xff1a;2023.9.11 …...

C++初阶--类和对象(中)

目录 类的6个默认成员函数构造函数使用方法 析构函数使用方法 拷贝构造函数使用方法 赋值运算符重载赋值运算符重载 const成员 上篇末尾我们讲到了关于c实现栈相较于c语言在传递参数时的一些优化&#xff0c;但实际上&#xff0c;c在 初始化 清理 赋值 拷贝等方面也做了很大程…...

网站新手引导怎么做/十大软件免费下载网站排行榜

一单选题 1 i最后等于多少&#xff08;&#xff09; int i 1;int j i;if((i>j)&&(i j)) ij; 占坑 4.4补...

个人博客模板 wordpress/推广专员

1、状态更新 服务端InstanceInfo对象状态更新的流程和续约流程类似&#xff0c;不过该过程不再经过SpringCloud提供的InstanceRegistry类了&#xff0c;即SpringCloud没有再对状态更新过程进行扩展&#xff0c;即没有增加状态变更事件的广播。基本流程如下&#xff1a; Instan…...

wordpress 七牛云加速/快速seo软件

动态加载 对动态库的加载分为自动加载和动态加载两种 自动加载 程序在开始执行的时候, 将依赖的动态库文件加载到内存中, 再进行函数的链接, 称为自动加载 (之前讲动态库讲过) 动态加载 程序在执行期间, 需要使用到某个动态库中的文件的时候, 可以向动态链接器发出请求, 请求…...

企业文化包括哪六个/网站优化 秦皇岛

王可伟 作品 地形篇&#xff08;第十&#xff09;&#xff08;读《孙子兵法》&#xff0c;悟管理、营销之道&#xff09;本篇论述军事地形学上的问题。孙子通过“地有六形”、“兵有六败”的论述&#xff0c;揭示了敌情与军事地理的相互关系&#xff0c;提出了“料敌制胜&#…...

广东省阳江网络问政平台/安徽关键词seo

前面几章早已讲到了科技公司与金融力量之间的关系&#xff0c;而当这个金融力量发生动乱的时候&#xff0c;这些科技公司又会发生什么&#xff1f;科技像是我们这个社会的大脑&#xff0c;而金融则是血液。发生金融危机时&#xff0c;就像人的血液出了问题&#xff0c;自然会对…...

0基础做下载网站/郑州网站建设方案

正向代理和反向代理的区别&#xff1f; 正向代理和反向代理的本质都是代为收发请求和响应。 正向代理是一个位于客户端和目标服务器之间的代理服务器。为了从原始服务器取得内容&#xff0c;客户端向代理服务器发送一个请求&#xff0c;并且指定目标服务器&#xff0c;之后代理…...