了解Android studio 初学者零基础推荐(3)
kotlin中的数据类及对象
使用泛型创建可重复使用的类
我们将常在线答题考试,有的考试题型包括判断,或者填空,以及数学题,此外试题内容还包括难易程度:"easy”,"medium","hard",下面我们来定义三种不同类型的问题。
填空题: 答案是由string表示的字词
class FillInTheBlankQuestion(val questionText: String,val answer: String,val difficulty: String
) {}
判断题:答案有boolean表示
class TrueOrFalseQuestion(val questionText: String,val answer: Boolean,val difficulty: String
) {}
数学题:答案是数值Int表示
class NumericQuestion(val questionText: String,val answer: Int,val difficulty: String
) {}
以上的三个类基本都是重复代码,不一样的就是answer的类型,如果没想简化写法怎么办?
kotlin提供了一种称为“泛型类型”的元素,可以让单个属性根据特定用例具有不同的数据类型。
那么啥是泛型数据类型?
为属性创建占位符,在实例化类的时候才指定实际的数据类型。
为类定义通用类型的语法如下:
实例化的时候这样写:
注意:这里的泛型属性传入的值一定要和尖括号的数据类型一致哦
重新修改代码:
class Question<T>(val questionText: String,val answer: T,val difficulty: String
) {}fun main() {val q1 = Question<String>("look ___ my eyes","into","medium")val q2 = Question<Boolean>("Hu Ge looks very cute. True or False", true, "easy")val q3 = Question<Int>("1+1=_",2,"hard")
}
枚举类
枚举类定义:
枚举类常量访问:
enum class Difficulty {EASY, MEDIUM, HARD
}
class Question<T>(val questionText: String,val answer: T,val difficulty: Difficulty
) {}fun main() {val q1 = Question<String>("look ___ my eyes","into",Difficulty.MEDIUM)val q2 = Question<Boolean>("Hu Ge looks very cute. True or False", true, Difficulty.EASY)val q3 = Question<Int>("1+1=_", 2, Difficulty.HARD)
}
数据类
像Question 这样的类,只包含数据,没有用于操作的各种什么方法,像这种类就可以称作数据类,数据类的对象可以使用toString,如何将Question变成数据类呢?那就是在class前加上data关键字。
data class Question<T>(val questionText: String,val answer: T,val difficulty: Difficulty
)
fun main() {val question1 = Question<String>("Quoth the raven ___", "nevermore", Difficulty.MEDIUM)val question2 = Question<Boolean>("The sky is green. True or false", false, Difficulty.EASY)val question3 = Question<Int>("How many days are there between full moons?", 28, Difficulty.HARD)println(question1.toString()) //输出为:Question(questionText=Quoth the raven ___, answer=nevermore, difficulty=MEDIUM)
}
将某个类定义为数据类后,系统会实现以下方法。
equals()
hashCode()
:在使用某些集合类型时,您会看到此方法。toString()
- componentN():
component1()
、component2()
等 copy()
单例对象
给硬件设备做测试的时候,因为要修改配置,这种配置不能多人修改,硬件设备只能一个人使用的情况等。那么如何创建单例对象?
单例对象和创建class十分相似,就是把class 变成object,注意单例对象没有构造函数,因为我们没法直接创建实例,所有属性都要在大括号内定义并被赋予初始值。
object StudentProgress {var total: Int = 10var answered: Int = 3
}
访问单例对象:
fun main() {...println("${StudentProgress.answered} of ${StudentProgress.total} answered.")
}
伴生对象
您可以使用“伴生对象”在另一个类中定义单例对象。伴生对象允许您从类内部访问其属性和方法(如果对象的属性和方法属于相应类的话),从而让语法变得更简洁。
如需声明伴生对象,只需在 object
关键字前面添加 companion
关键字即可。
class Quiz {val question1 = Question<String>("Quoth the raven ___", "nevermore", Difficulty.MEDIUM)val question2 = Question<Boolean>("The sky is green. True or false", false, Difficulty.EASY)val question3 = Question<Int>("How many days are there between full moons?", 28, Difficulty.HARD)companion object StudentProgress {var total: Int = 10var answered: Int = 3}
}fun main() {println("${Quiz.answered} of ${Quiz.total} answered.")
}
扩展属性
如果现在要给Quiz添加一个显示完成情况的属性,我们应该怎么做呢?那就是使用扩展属性,语法如下:
val Quiz.StudentProgress.progressText: Stringget() = "${answered} of ${total} answered"fun main() {println(Quiz.progressText)
}
扩展函数
fun Quiz.StudentProgress.printProgressBar() {repeat(Quiz.answered) { print("▓") }repeat(Quiz.total - Quiz.answered) { print("▒") }println()println(Quiz.progressText)
}
fun main() {Quiz.printProgressBar()
}
使用重写的扩展函数
如果您需要多个类具有相同的额外属性和方法(可能是行为方式不同),就可以使用接口定义这些属性和方法。
接口使用 interface
关键字定义,后跟大驼峰式命名法 (UpperCamelCase) 名称,再跟左大括号和右大括号。在大括号内,您可以定义任何符合接口标准的类必须实现的方法签名或 get-only 属性。
接口是一种协定。系统会声明符合接口规范的类以扩展接口。类可以声明它想用“冒号 (:
) 后跟一个空格,再跟接口名称”的形式来扩展接口。
interface ProgressPrintable {val progressText: Stringfun printProgressBar()
}
在 Quiz
类中,使用 override
关键字添加 printProgressBar()
方法
class Quiz : ProgressPrintable {override val progressText: Stringget() = "${answered} of ${total} answered"override fun printProgressBar() {repeat(Quiz.answered) { print("▓") }repeat(Quiz.total - Quiz.answered) { print("▒") }println()println(progressText)}
}
作用域函数访问类的属性和方法
使用 let()
替换过长的对象名称
向 Quiz
类添加一个名为 printQuiz()
的函数。
fun printQuiz() {println(question1.questionText)println(question1.answer)println(question1.difficulty)println()println(question2.questionText)println(question2.answer)println(question2.difficulty)println()println(question3.questionText)println(question3.answer)println(question3.difficulty)println()
}
使用let以后可以简化为:
fun printQuiz() {println(question1.questionText)println(question1.answer)println(question1.difficulty)println()println(question2.questionText)println(question2.answer)println(question2.difficulty)println()println(question3.questionText)println(question3.answer)println(question3.difficulty)println()
}
使用 apply() 在没有变量的情况下调用对象方法
作用域函数有一项非常棒的功能,那就是即使尚未将某个对象分配到变量,您也可以对此对象调用作用域函数。例如,apply()
函数是一个扩展函数,可通过点表示法调用对象。apply()
函数还会返回对相应对象的引用,以便将其存储在变量中。
- 在创建
Quiz
类的实例时,请在右圆括号后面调用apply()
。您可以在调用apply()
时省略圆括号,并使用尾随 lambda 语法。
val quiz = Quiz().apply {
}
- 将对
printQuiz()
的调用移至 lambda 表达式内。您无需再引用quiz
变量或使用点表示法。
val quiz = Quiz().apply {printQuiz()
}
apply()
函数会返回Quiz
类的实例,但由于您在任何位置都不再使用此实例了,因此请移除quiz
变量。借助apply()
函数,您甚至无需变量即可对Quiz
实例调用方法。
Quiz().apply {printQuiz()
}
集合
集合可以创建Android的常见功能,例如滚动列表,以及解决任意数量数据的实际编程问题。
数组
同一数据类型的一系列值,有序,可以通过索引访问。什么是索引?索引是与数组中的某个元素对应的整数。索引可以指示某个项与数组起始元素之间的距离。这称为“零索引”。数组的第一个元素位于索引 0 处,第二个元素位于索引 1 处,因为它与第一个元素相距一个位置,以此类推。
在设备的内存中,数组中的元素彼此相邻地存储在一起。虽然底层细节不在本 Codelab 的讨论范围之内,但这有两个重要影响:
- 通过索引可以快速地访问数组元素。您可以通过索引访问数组的任何随机元素,并且访问任何其他随机元素预计需要大约相同的时间。因此,有人说数组具有随机访问特性。
- 数组具有固定的大小。这意味着您向数组添加元素时不能超过该数组的大小。如果尝试访问某个数组(包含 100 个元素)中位于索引 100 处的元素,则会引发异常,因为最高索引为 99(请注意,第一个索引为 0,而不是 1)。但是,您可以修改数组中位于相关索引处的值。
- 如果想增加数组的大小只能重新创建这个数组
如需在代码中声明数组,请使用 arrayOf()
函数。
fun main() {val rockPlanets = arrayOf<String>("Mercury", "Venus", "Earth", "Mars")val gasPlanets = arrayOf<String>("Jupiter","Saturn","Uranus","Neptune")val solarSystem = rockPlanets + gasPlanetsprintln(solarSystem[0])
}
列表
列表是有序且可调整大小的集合,通常作为可调整大小的数组实现。当数组达到容量上限时,如果您尝试插入新元素,需要将该数组复制到一个新的较大数组。
使用列表,您还可以在特定索引处(介于其他元素之间)插入新元素。
上图显示了在列表中添加和移除元素的方式。在大多数情况下,无论列表中包含多少个元素,向列表中添加任何元素所需的时间都是相同的。每隔一段时间,如果添加新元素会使数组超出其定义的大小,那么数组元素可能必须移动,以便为新元素腾出空间。列表会为您执行所有这些操作,但在后台,它只是一个在需要时换成新数组的数组。
List
和 MutableList
您在 Kotlin 中遇到的集合类型会实现一个或多个接口。正如您在本单元前面的泛型、对象和扩展 Codelab 中所学到的,接口提供了一组供类实现的标准属性和方法。实现 List
接口的类可为 List
接口的所有属性和方法提供实现。MutableList
也是如此。
List
和 MutableList
有什么用?
List
是一个接口,用于定义与只读有序项集合相关的属性和方法。MutableList
通过定义修改列表的方法(例如添加和移除元素)来扩展List
接口。
这些接口仅指定 List
和/或 MutableList
的属性和方法。每个属性和方法的实现方式均由扩展这些接口的类决定。上述基于数组的实现将是您最常使用(如果不是始终使用)的实现,但 Kotlin 允许其他类扩展 List
和 MutableList
。
listOf()
函数
与 arrayOf()
类似,listOf()
函数将相关项作为形参,但返回 List
,而不是数组。
- 从
main()
中移除现有代码。 - 在
main()
中,通过调用listOf()
创建名为solarSystem
的行星List
。
fun main() {val solarSystem = listOf("Mercury", "Venus", "Earth", "Mars", "Jupiter", "Saturn", "Uranus", "Neptune")
}
List
具有size
属性,用于获取列表中的元素数量。输出solarSystem
列表的size
。
println(solarSystem.size)
- 运行代码。列表的大小应为 8。
8
访问列表中的元素
与数组一样,您可以使用下标语法从 List
访问特定索引处的元素。您可以使用 get()
方法执行相同的操作。下标语法和 get()
方法接受 Int
作为参数,并在该索引处返回相应元素。与 Array
一样,ArrayList
也为零索引,因此第四个元素位于索引 3
处。
- 使用下标语法输出索引
2
处的行星。
println(solarSystem[2])
- 通过对
solarSystem
列表调用get()
,输出索引3
处的元素。
println(solarSystem.get(3))
- 运行代码。索引
2
处的元素为"Earth"
,索引3
处的元素为"Mars"
。
... Earth Mars
除了按索引获取元素之外,您还可以使用 indexOf()
方法搜索特定元素的索引。indexOf()
方法在列表中搜索指定元素(作为实参传入),并返回该元素在第一次出现时的索引。如果该元素未出现在列表中,则返回 -1
。
- 输出对
solarSystem
列表调用indexOf()
并传入"Earth"
的结果。
println(solarSystem.indexOf("Earth"))
- 调用
indexOf()
,传入"Pluto"
,并输出结果。
println(solarSystem.indexOf("Pluto"))
- 运行代码。某个元素与
"Earth"
匹配,因此输出索引2
。没有与"Pluto"
匹配的元素,因此输出-1
。
... 2 -1
使用 for
循环遍历列表元素
在学习函数类型和 lambda 表达式时,您已经了解如何使用 repeat()
函数多次执行代码。
编程中的一项常见任务是对列表中的每个元素执行一次某个任务。Kotlin 包含一个名叫 for
循环的功能,可利用简洁易懂的语法来实现此目的。这通常称为“循环遍历”列表或“遍历”列表。
向列表中添加元素
只有实现 MutableList
接口的类具有在集合中添加、移除和更新元素的功能。如果您一直在跟踪新发现的行星,则可能需要能够经常向列表中添加元素。在创建要向其中添加元素和从中移除元素的列表时,您需要专门调用 mutableListOf()
函数,而不是 listOf()
。
add()
函数有两个版本:
- 第一个
add()
函数具有一个属于列表中元素类型的参数,并将其添加到列表末尾。 add()
的另一个版本有两个参数。第一个参数对应于应该插入新元素的索引。第二个参数是要添加到列表中的元素。
我们来看看实际用例。
- 将
solarSystem
的初始化更改为调用mutableListOf()
,而不是listOf()
。您现在可以调用MutableList
中定义的方法。
val solarSystem = mutableListOf("Mercury", "Venus", "Earth", "Mars", "Jupiter", "Saturn", "Uranus", "Neptune")
- 同样,我们也可能需要将 Pluto 归类为行星。对
solarSystem
调用add()
方法,传入"Pluto"
作为单个参数。
solarSystem.add("Pluto")
- 有些科学家提出一种理论:过去曾有一颗名为 Theia 的行星,该行星后来与地球发生碰撞并形成月球。在索引
3
(介于"Earth"
和"Mars"
之间)处插入"Theia"
。
solarSystem.add(3, "Theia")
更新特定索引处的元素
您可以使用下标语法更新现有元素:
- 将索引
3
处的值更新为"Future Moon"
。
solarSystem[3] = "Future Moon"
- 使用下标语法输出位于索引
3
和9
处的值。
println(solarSystem[3])
println(solarSystem[9])
- 运行代码,验证输出。
Future Moon Pluto
从列表中移除元素
使用 remove()
或 removeAt()
方法可移除元素。您可以通过两种方法移除元素:将该元素传递到 remove()
方法中,或者使用 removeAt()
按索引移除该元素。
我们来看下这两种元素移除方法的实际操作效果。
- 对
solarSystem
调用removeAt()
,并传入索引9
。这应该会从列表中移除"Pluto"
。
solarSystem.removeAt(9)
- 对
solarSystem
调用remove()
,并传入"Future Moon"
作为要移除的元素。此操作应该会搜索此列表,如果找到匹配元素,则会将其移除。
solarSystem.remove("Future Moon")
List
可提供contains()
方法,该方法可在列表中存在某个元素时返回Boolean
。输出为"Pluto"
调用contains()
的结果。
println(solarSystem.contains("Pluto"))
- 更简洁的语法是使用
in
运算符。您可以使用元素、in
运算符和集合来检查该元素是否在列表中。使用in
运算符检查solarSystem
是否包含"Future Moon"
。
println("Future Moon" in solarSystem)
- 运行代码。两个语句都应输出
false
。
... false false
集
集是指没有特定顺序且不允许出现重复值的集合。
在 Kotlin 中使用 MutableSet
在本示例中,我们将使用 MutableSet
来演示如何添加和移除元素。
- 从
main()
中移除现有代码。 - 使用
mutableSetOf()
创建名为solarSystem
的行星Set
。这将返回MutableSet
,其默认实现为LinkedHashSet()
。
val solarSystem = mutableSetOf("Mercury", "Venus", "Earth", "Mars", "Jupiter", "Saturn", "Uranus", "Neptune")
- 使用
size
属性输出该集的大小。
println(solarSystem.size)
- 与
MutableList
类似,MutableSet
具有add()
方法。使用add()
方法将"Pluto"
添加到solarSystem
集。它只需要为所添加的元素使用一个参数。集中的元素未必是有序的,因此没有索引!
solarSystem.add("Pluto")
- 添加相应元素后,输出该集的
size
。
println(solarSystem.size)
contains()
函数接受一个参数,并检查该集中是否包含指定的元素。如果是,则返回 true。否则,它将返回 false。调用contains()
以检查"Pluto"
是否在solarSystem
中。
println(solarSystem.contains("Pluto"))
- 运行代码。大小已增大,
contains()
现在会返回true
。
8 9 true
注意:您也可以使用 in
运算符检查某个元素是否在集合中,例如:"Pluto" in solarSystem
相当于 solarSystem.contains("Pluto")
。
- 如前所述,集不能包含重复项。请尝试重新添加
"Pluto"
。
solarSystem.add("Pluto")
- 再次输出集的大小。
println(solarSystem.size)
- 再次运行您的代码。未添加
"Pluto"
,因为它已包含在集中。这次,大小应该不会增加。
... 9
remove()
函数接受一个参数,并从集中移除指定的元素。
- 使用
remove()
函数移除"Pluto"
。
solarSystem.remove("Pluto")
注意:请记住,集是无序的集合。您无法按索引从集中移除某个值,因为集没有索引。
- 输出集合的大小,并再次调用
contains()
以检查"Pluto"
是否仍在集中。
println(solarSystem.size)
println(solarSystem.contains("Pluto"))
- 运行代码。
"Pluto"
不在集中,大小现在为 8。
... 8 false
映射集合
Map
是由键和值组成的集合。之所以称之为映射,是因为唯一键会映射到其他值。键及其附带的值通常称为 key-value pair
。
映射的键具有唯一性,但映射的值不具有唯一性。两个不同的键可以映射到同一个值。例如,"Mercury"
有 0
颗卫星,"Venus"
也有 0
颗卫星。
通过相应的键访问映射的值通常比在大型列表中(例如使用 indexOf()
)搜索值更快。
您可以使用 mapOf()
或 mutableMapOf()
函数声明映射。映射需要两个泛型类型(以英文逗号隔开),一个用于键,另一个用于值。
如果映射具有初始值,则还可以使用类型推断。要使用初始值填充映射,每个键值对都由以下部分组成:首先是键,后跟 to
运算符,而后是值。每个键值对均以英文逗号隔开。
接下来,我们详细了解一下如何使用映射,以及一些有用的属性和方法。
- 从
main()
中移除现有代码。 - 使用
mutableMapOf()
和如下初始值创建一个名为solarSystem
的映射。
val solarSystem = mutableMapOf("Mercury" to 0,"Venus" to 0,"Earth" to 1,"Mars" to 2,"Jupiter" to 79,"Saturn" to 82,"Uranus" to 27,"Neptune" to 14
)
- 与列表和集一样,
Map
提供包含键值对数量的size
属性。输出solarSystem
映射的大小。
println(solarSystem.size)
- 您可以使用下标语法设置其他键值对。将
"Pluto"
键的值设置为5
。
solarSystem["Pluto"] = 5
- 插入元素后,再次输出大小。
println(solarSystem.size)
- 您可以使用下标语法来获取值。输出键
"Pluto"
的卫星数量。
println(solarSystem["Pluto"])
- 您还可以使用
get()
方法访问值。无论您使用下标语法还是调用get()
,您传入的键都可能不存在于映射中。如果没有键值对,它将返回 null。输出"Theia"
的卫星数量。
println(solarSystem.get("Theia"))
- 运行代码。系统应该会输出 Pluto 的卫星数量。不过,由于 Theia 不在映射中,因此调用
get()
会返回 null。
8 9 5 null
remove()
方法可移除具有指定键的键值对。它也会返回已移除的值,或者如果指定的键不在映射中,则返回 null
。
- 输出调用
remove()
并传入"Pluto"
的结果。
solarSystem.remove("Pluto")
- 若要验证相应项是否已移除,请再次输出大小。
println(solarSystem.size)
- 运行代码。移除该条目后,映射的大小将为 8。
... 8
- 下标语法或
put()
方法也可以修改已存在的键的值。使用下标语法将 Jupiter 的卫星数量更新为 78,并输出新值。
solarSystem["Jupiter"] = 78
println(solarSystem["Jupiter"])
- 运行代码。现有键
"Jupiter"
的值已更新。
... 78
相关文章:

了解Android studio 初学者零基础推荐(3)
kotlin中的数据类及对象 使用泛型创建可重复使用的类 我们将常在线答题考试,有的考试题型包括判断,或者填空,以及数学题,此外试题内容还包括难易程度:"easy”,"medium","hard",…...

Spring 定时器和异步线程池 实践指南
前言:Spring:异步线程池和定时器 原理篇 一、Spring Scheduler 1. 创建一个 SpringBoot项目,在启动类上添加 EnableScheduling 注解,表示开启定时任务。 2. 创建SchedulerService,在方法上面启用Scheduled 注解 在方…...

零基础设计模式——创建型模式 - 生成器模式
第二部分:创建型模式 - 生成器模式 (Builder Pattern) 前面我们学习了单例、工厂方法和抽象工厂模式,它们都关注如何创建对象。生成器模式(也常被称为建造者模式)是另一种创建型模式,它专注于将一个复杂对象的构建过程…...

MD编辑器推荐【Obsidian】含下载安装和实用教程
为什么推荐 Obsidian ? 免费 (Typora 开始收费了)Typora 实现的功能,它都有!代码块可一键复制 文件目录支持文件夹 大纲支持折叠、搜索 特色功能 – 白板 特色功能 – 关系图谱 下载 https://pan.baidu.com/s/1I1fSly…...
LLama-Factory 遇到的问题
目录 一、LLama-Factory安装 二、LLama-Factory 遇到的问题 (一)包不兼容问题 (二)使用文件路径,加载模型 一、LLama-Factory安装 参考官网介绍:https://github.com/hiyouga/LLaMA-Factory 二、LLama…...
I-CON: A UNIFYING FRAMEWORK FOR REPRESENTATION LEARNING
I-con:表示学习的统一框架 基本信息 ICLR 2025 博客贡献人 田心 作者 Shaden Alshammari, John Hershey, Axel Feldmann, William T. Freeman, Mark Hamilton 关键词 I-Con框架,表征学习,损失函数统一框架 摘要 随着表征学习领域的快速发展,各类…...

Missashe线代题型总结
Missashe线性代数考研题型总结 说明:这篇笔记用于博主对"线代"常考题型进行总结,99%为真题,大概可能应该会逐步更新解题思路。有目录可直接检索。 第一章 行列式 1 具体行列式计算 1)么字型 2015 数一 2016 数一三…...
蓝桥杯13届 卡牌
问题描述 这天, 小明在整理他的卡牌。 他一共有 n 种卡牌, 第 i 种卡牌上印有正整数数 i(i∈[1,n]), 且第 i 种卡牌 现有 ai 张。 而如果有 n 张卡牌, 其中每种卡牌各一张, 那么这 n 张卡牌可以被称为一 套牌。小明为了凑出尽可能多套牌, 拿出了 m 张空白牌, 他可以在上面…...

安卓开发用到的设计模式(1)创建型模式
安卓开发用到的设计模式(1)创建型模式 文章目录 安卓开发用到的设计模式(1)创建型模式1. 单例模式(Singleton Pattern)2. 工厂模式(Factory Pattern)3. 抽象工厂模式(Abs…...
【PalladiumZ2 使用专栏 3 -- 信号值的获取与设置 及 memory dump 与 memory load】
文章目录 Overviewforce 命令语法value 命令语法memory loadmemory dump Overview 在调试问题的时,有时需要将某些信号强制设置为某个值,或者某几个信号强制设置为某个值,这里就要用到 force 命令。 force 命令语法 force -h force <na…...
flutter dart 函数语法
以下是 Dart 语言中函数语法的 详细实例说明,涵盖了所有常用写法 基本语法参数类型(必选、可选、命名、默认值)匿名函数、箭头函数高阶函数(函数作为参数/返回值)异步函数(async / await) 1. …...
课外活动:大语言模型Claude的技术解析 与 自动化测试框架领域应用实践
大语言模型Claude的技术解析与测试领域应用实践 一、Claude模型的核心优势解析 1.1 关键技术特性对比 维度Claude 3 OpusGPT-4 Turbo核心优势上下文窗口200K tokens128K tokens长文档处理能力提升56%逻辑推理准确率92.3% (GSM8K数据集)89.7%复杂场景稳定性更强代码生成速度7…...

线程的一些基本知识
前言 最近在学习线程,线程与进程是面试中可能常考的问题,我总结了线程的一些知识。分享给大家,希望可以帮组到大家。 线程知识总结(包含与进程的区别) 结语 希望可以帮助到有需要的人,bye~~...

【Python打卡Day30】模块与包的导入@浙大疏锦行
#一、导入官方库 我们复盘下学习python的逻辑,所谓学习python就是学习python常见的基础语法学习你所处理任务需要用到的第三方库 所以你用到什么学什么库即可。学习python本身就是个伪命题,就像你说学习科目一样,你没说清晰你学习的具体科目…...

26考研|高等代数:λ-矩阵
前言 本章知识点较为简单,是作为工具性的一章,在学习过程中,要注意区分行列式因子、不变因子以及初等因子,同时还要对若尔当标准型的计算应该足够熟悉,尤其是复矩阵的若尔当标准型计算是十分重要的。 课本重点回顾 …...

我店模式系统开发打造本地生活生态商圈
在当今快节奏的商业环境中,商家们面临着越来越多的挑战,包括市场竞争加剧、消费者需求多样化以及运营效率的提高等。为了应对这些挑战,越来越多的商家开始寻求信息化解决方案,以提升运营效率和客户体验。我的店模式系统平台应运而…...

数据库练习(3)
简单选择题要点: 1.锁协议: 数据库原理及应用(高级篇)01——封锁协议(图文并解,超详细,一看就会)_数据库锁协议-CSDN博客https://blog.csdn.net/qq_44236958/article/details/105790970 2.tablespace和datafile 一个tablespace可以有一个或多…...

OpenGL ES 基本基本使用、绘制基本2D图形
OpenGL ES 绘制基础图形 OpenGL ES基本概念 OpenGL ES (Embedded-System) 是专为嵌入式设备(如手机、平板、VR 设备)设计的图形 API,是 OpenGL 的轻量级版本。 |下面是一个Android使用 OpenGL ES的基本框架 MainActivity 设置一…...
spark调度系统核心组件SparkContext、DAGSchedul、TaskScheduler、Taskset介绍
目录 1. SparkContext2.DAGScheduler3. TaskScheduler4. 协作关系5 TaskSet的定义6. 组件关系说明Spark调度系统的核心组件主要有SparkContext、DAGScheduler和TaskScheduler SparkContext介绍 1. SparkContext 1、资源申请: SparkContext是Spark应用程序与集群管理器(如St…...

BU9792驱动段式LCD
1、C文件,需要自己添加软件iic或硬件iic驱动,该驱动在我的别的文章内有。亲测bu9792是正常驱动的(只用到了前14个SEG),说实话有点懵了。后面的ICSET有个P2根据不同的SEG地址要置1或0,读的时候最高位也是0?读命令寄存器…...
Springboot通过SSE实现实时消息返回
Server-Sent Events(SSE)是一种从服务器向客户端推送实时消息的技术。相较于WebSocket,SSE更为简单,适用于大多数实时消息场景。本文将深入探讨如何使用Spring Boot通过SSE实现实时消息返回。 一、什么是SSE SSE是一种允许服务器…...
SD-WAN技术详解:如何优化网络性能与QoS实现?(附QoS策略、链路聚合、网络架构对比)
随着企业数字化转型的快速推进,传统WAN架构逐渐难以满足企业在性能、成本和服务质量(QoS)方面的要求。尤其是企业关键业务应用(例如语音通话、高清视频会议、企业核心业务系统)对网络性能的要求越来越高。SD-WAN&#…...

力扣-将x减到0的最小操作数
1.题目描述 2.题目链接 1658. 将 x 减到 0 的最小操作数 - 力扣(LeetCode) 3.题目分析 1)正面求解困难 题目要求我们每次都从最左边或者最右边取一个数,使x-元素的值,并在数组中移除该元素。最后返回的最小操作数…...
Web前端开发: 什么是JavaScript?
什么是JavaScript? JavaScript 是一种广泛应用于网页开发的脚本语言,主要用于为网站添加交互性和动态功能。 1. 核心作用 前端开发:控制网页行为,例如点击按钮弹出提示、表单验证、动态加载内容等。 后端开发:通过 No…...

三、【数据建模篇】:用 Django Models 构建测试平台核心数据
【数据建模篇】:用 Django Models 构建测试平台核心数据 前言我们要设计哪些核心数据?准备工作:创建 Django App开始设计数据模型 (Models)1. 通用基础模型 (可选但推荐)2. 项目模型 (Project)3. 模块模型 (Module)4. 测试用例模型 (TestCase…...
【JAVA】比较器Comparator与自然排序(28)
JAVA 核心知识点详细解释 Java中比较器Comparator的概念和使用方法 概念 Comparator 是 Java 中的一个函数式接口,位于 java.util 包下。它用于定义对象之间的比较规则,允许我们根据自定义的逻辑对对象进行排序。与对象的自然排序(实现 Comparable 接口)不同,Comparat…...

shp2pgsql 导入 Shp 到 PostGIS 空间数据库
前言 ❝ shp2pgsql是PostGIS自带的命令行工具,用于将Shapefile文件声称SQL脚本导入到PostGIS空间数据库。 1. 安装 PostGIS 通过Application Stack Builder或者下载单独的PostGIS包进行安装。而shp2pgsql则是与PostGIS工具集成在一起,无需单独下载。该命…...

word设置如“第xx页 共xx页”格式的页码
问题1: 为word文档设置如“第xx页 共xx页”格式的页码。 解决方法: 1、鼠标双击页脚位置进入页脚编辑模式; 2、在页脚处输入“第 页 共 页”内容并居中; 3、将光标放在“第 页”之间并插入“Page”,执行操作“…...

DL00912-基于自监督深度聚类的高光谱目标检测含数据集
在科研的道路上,数据的获取与分析无疑是成功的关键。对于从事高光谱数据研究的你,我们为您带来了一款革命性的工具——基于自监督深度聚类的高光谱目标检测系统。 完整代码数据集见文末 这款系统通过最先进的自监督学习技术,结合深度聚类算…...
PostgreSQL架构
目录 一、PostgreSQL核心特性与优势 1.PostgreSQL简介 2.PostgreSQL的核心特点 (1)开源与自由 (2)高度符合SQL标准 (3)丰富的数据类型 (4)事务与并发控制 (5&…...