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

Kotlin 中 companion object 扩展函数详解

companion object 的扩展函数是 Kotlin 中一个强大但稍显复杂的特性,它允许你为类的伴随对象添加新的函数。下面我会通过清晰的示例和解释帮助你理解这个概念。

基本概念

扩展函数允许你为已有的类添加新函数,而无需继承或修改原始类。当这个扩展函数是针对 companion object 时,它就成为了一种"类级别"的扩展。

基本语法

class MyClass {companion object  // 可以命名为 Companion 或其它名称,也可以不命名
}// 为 MyClass 的 companion object 添加扩展函数
fun MyClass.Companion.sayHello() {println("Hello from companion extension")
}

为什么需要这种扩展?

  1. 为已有类添加静态工具方法(类似 Java 的静态方法)

  2. 保持代码组织性(相关函数集中在一起)

  3. 无法修改原始类时添加功能

详细示例

示例1:基础使用

class Logger {companion object  // 空的 companion object
}// 为 Logger 的 companion object 添加扩展函数
fun Logger.Companion.debug(message: String) {println("[DEBUG] $message")
}// 使用
fun main() {Logger.debug("This is a debug message")// 输出: [DEBUG] This is a debug message
}

示例2:带 receiver 的扩展

class Config {companion object
}fun Config.Companion.load(configFile: String): Map<String, String> {println("Loading config from $configFile")return mapOf("key" to "value") // 模拟加载配置
}// 使用
fun main() {val config = Config.load("app.conf")println(config) // 输出: {key=value}
}

高级用法

为第三方类添加扩展

// 假设这是一个第三方库中的类,我们不能修改它
class ThirdPartyClass {companion object
}// 我们可以为它添加扩展
fun ThirdPartyClass.Companion.newFeature() {println("Added new feature to third party class")
}

结合泛型使用

class Box<T> {companion object
}fun <T> Box.Companion.create(value: T): Box<T> {println("Creating box with $value")return Box<T>()
}// 使用
fun main() {val stringBox = Box.create("Hello")val intBox = Box.create(42)
}

与普通扩展函数的区别

特性普通扩展函数companion object 扩展函数
定义方式fun ClassName.func()fun ClassName.Companion.func()
调用方式实例上调用类名上直接调用
访问权限可以访问实例成员只能访问 companion object 成员
使用场景增强实例功能添加类级别工具方法

实际应用场景

工具类函数

class StringUtils {companion object
}fun StringUtils.Companion.isValidEmail(email: String): Boolean {return email.contains("@")
}// 使用
StringUtils.isValidEmail("test@example.com")

DSL 构建

class HTML {companion object
}fun HTML.Companion.div(block: Div.() -> Unit): Div {val div = Div()div.block()return div
}

库的扩展

// 为 Android 的 Toast 添加扩展
fun Toast.Companion.showShort(context: Context, message: String) {Toast.makeText(context, message, Toast.LENGTH_SHORT).show()
}// 使用
Toast.showShort(context, "Hello")

注意事项

companion object 必须存在

class NoCompanion // 没有 companion object// 这会编译错误
fun NoCompanion.Companion.extension() {} 

命名 companion object

class Named {companion object Factory
}// 必须使用正确的名称
fun Named.Factory.extension() {}

优先级: 

  • 如果 companion object 本身有同名方法,会优先调用成员方法
  • 扩展函数不会覆盖已有方法

通过理解这些概念和示例,你应该能够掌握如何为 companion object 创建和使用扩展函数了。这种技术特别适合在保持代码整洁的同时为类添加实用功能。

http://www.xdnf.cn/news/10585.html

相关文章:

  • Java连接Redis和基础操作命令
  • 【Linux】Ubuntu 20.04 英文系统显示中文字体异常
  • 什么是线程上下文切换?
  • 【SpringBoot】| 接口架构风格—RESTful
  • 概率统计:AI大模型的数学支柱
  • Linux--进程概念
  • 【redis实战篇】第七天
  • 03- javascript的运行原理
  • 启动metastore时报错MetaException(message:Version information not found in metastore
  • 海底三维可视化平台
  • 使用Python进行函数作画
  • azure devops 系列 - 常用的task
  • C++面向对象编程:类与对象详解
  • CppCon 2014 学习:(Costless)Software Abstractions for Parallel Architectures
  • 已有的前端项目打包到tauri运行(windows)
  • Python应用range函数初解pro
  • arc3.2语言sort的时候报错:(sort < `(2 9 3 7 5 1)) 需要写成这种:(sort > (pair (list 3 2)))
  • EXCEL--累加,获取大于某个值的第一个数
  • DeepSeek模型高级应用:提示工程与Few-shot学习实战指南
  • 【深度学习-Day 21】框架入门:神经网络模型构建核心指南 (Keras PyTorch)
  • MySQL中的字符串分割函数
  • Python 训练营打卡 Day 33-神经网络
  • tex中的表格4:自动表格宽度自动换行tabularx宏包
  • 结构化控制语言(SCL) 与梯形图(LAD)相互转换的步骤指南
  • CppCon 2014 学习:EFFICIENCY PERFORMANCE ALGORITHMS DATA STRUCTURES
  • Linux中的System V通信标准-共享内存、消息队列以及信号量
  • 工作流引擎-18-开源审批流项目之 plumdo-work 工作流,表单,报表结合的多模块系统
  • isp中的 ISO代表什么意思
  • 【机器学习基础】机器学习入门核心算法:多分类与多标签分类算法
  • Vue3(watch,watchEffect,标签中ref的使用,TS,props,生命周期)