網站首頁 編程語言 正文
標準函數
- 標準函數就是在Standard.kt文件中定義的函數,任何Kotlin代碼都可以自由地調用所有的標準函數
- let函數就屬于是一個標準函數,經常配合?.操作符來進行判空處理
with函數
with函數接收兩個參數,第一參數可以是任何類型的對象,第二個參數是一個Lambda表達式
with函數會在Lambda表達式中提供第一個參數的上下文,并使用Lambda表達式的最后一行代碼作為函數的返回值
示例代碼
val res = with(obj) {
//這里是obj對象的上下文
"value"http://這里是with函數的返回值
}
with函數的作用.假如現在有個需求讓吃完所有的水果并且將結果打印出來,代碼可以這樣寫
fun main() {
doSomething()
}
fun doSomething() {
val list = listOf<String>("Apple", "Banana", "Pear")
val sb = StringBuilder()
sb.append("Start eating fruits.\n")
for (fruits in list) {
sb.append(fruits).append("\n")
}
sb.append("Ate all fruits.")
val res = sb.toString()
println(res)
}
利用with函數可以這樣寫,可以看到在Lambda表達式中,都是StringBuilder的上下文,那么就不需要我們通過StringBuilder的實例調用append()方法了,而是直接使用append()方法即可.
fun withTest() {
val list = listOf<String>("Apple", "Banana", "Pear")
val res = with(StringBuilder()) {
append("Start eating fruits.\n")
for (fruits in list) {
append(fruits)
append("\n")
}
append("Ate all fruits.")
toString()//最后一行就是函數的返回值
}
println(res)
}
run函數
- run函數和with函數基本類似,區別就是,run函數不能直接調用,需要在某個對象的基礎上進行調用
- 其次run函數只接受一個Lambda參數,并且在Lambda表達式中提供調用對象的上下文.
- 其他和with函數都是一樣的
- 使用run函數完成上述需求的實例
fun runTest() {
val list = listOf<String>("Apple", "Banana", "Pear")
//將StringBuilder調出來,用來調用run函數
val res = StringBuilder().run {
append("Start eating fruits.\n")
for (fruits in list) {
append(fruits)
append("\n")
}
append("Ate all fruits.")
toString()
}
println(res)
}
apply函數
- apply函數和run函數基本一樣,就是apply函數不能指定返回值,只能返回調用調用者的本身
- apply函數實例
fun applyTest() {
val list = listOf<String>("Apple", "Banana", "Pear")
val res = StringBuilder().apply {
append("Start eating fruits.\n")
for (fruits in list) {
append(fruits)
append("\n")
}
append("Ate all fruits.")
}
println(res.toString())
}
靜態方法
- 靜態方法又叫做類方法,就是說不需要實例,直接用類就可以進行調用,一般會將工具類中的方法設置為靜態方法,方便調用
- 在java當中的靜態方法就是使用static關鍵字修飾的方法
- 但是在kotlin當中沒有直接的靜態方法
單例類
在kotlin當中要是想要定義一個工具類,會比較推薦單例類進行實現
object Util {
fun doAction() {
println("do something")
}
}
雖然單例類中的doAction()方法并不是靜態放啊,但是我們還是可以直接使用Util.doAction()來進行調用
但是單例類的缺點是單例類中的方法都是類似靜態方法這種調用方式,但是我們只需要讓類中的一個方法變成靜態的怎么辦?
companion object
在companion object中定義的方法就可以類似于靜態方法那樣進行調用了
class Util {
//非靜態方法屬性
fun doAction1() {
}
//擁有靜態方法的屬性
companion object {
fun doAction2() {
}
}
}
注解
單例類和companion object都是在語法形式上模仿了靜態方法,實際上不屬于真正的靜態方法
如果我們給單例類或者companion object中的方法加上@JvmStatic注解,那么kotlin編譯器就會將這些方法編譯成為真正的靜態方法
如下
class Util {
//非靜態方法屬性
fun doAction1() {
}
//擁有靜態方法的屬性
companion object {
@JvmStatic
fun doAction2() {
}
}
}
@JvmStatic只能加在單例類或者companion object中的方法
頂層方法
- 頂層方法指的就是沒有定義在任何類中的方法,kotlin編譯器會將所有的頂層方法編譯成為靜態方法
- 因此只要定義了一個頂層方法,那么他肯定是一個靜態方法
原文鏈接:https://blog.csdn.net/weixin_45809829/article/details/128019441
相關推薦
- 2022-08-04 C++中純虛函數的實例詳解_C 語言
- 2022-12-25 Redis中AOF與RDB持久化策略深入分析_Redis
- 2022-04-30 DataGridView自定義單元格表示值、Error圖標顯示的方法介紹_C#教程
- 2022-11-07 CLion開發stm32?使用DSP庫的操作方法_C 語言
- 2022-10-10 python基礎知識之try...except...的詳細用法實例_python
- 2022-09-07 在SQL?Server中使用?Try?Catch?處理異常的示例詳解_MsSql
- 2022-09-28 基于OpenCV(python)的實現文本分割之垂直投影法_python
- 2022-08-02 Python深拷貝淺拷貝圖文示例清晰整理_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支