Compose笔记(十三)--事件总线

这一节了解一下Compose中的事件总线,在Jetpack Compose里,官方没有直接提供事件总线,但可以借助第三方库或者自定义实现来达成事件总线的功能,进而在不同的 Compose 控件间同步数据。

自定义事件总线

Kotlin 复制代码
import androidx.compose.runtime.*
import androidx.compose.material3.Button
import androidx.compose.material3.Text
import java.util.*

object EventBus {
    private val listeners = mutableListOf<(Any) -> Unit>()

    fun register(listener: (Any) -> Unit) {
        listeners.add(listener)
    }

    fun unregister(listener: (Any) -> Unit) {
        listeners.remove(listener)
    }

    fun post(event: Any) {
        listeners.forEach { it(event) }
    }
}

@Composable
fun SenderComponent() {
    Button(onClick = {
        EventBus.post("New data from sender")
    }) {
        Text(text = "Send Data")
    }
}

@Composable
fun ReceiverComponent() {
    var receivedData by remember { mutableStateOf("No data received") }

    DisposableEffect(Unit) {
        val listener: (Any) -> Unit = { event ->
            if (event is String) {
                receivedData = event
            }
        }
        EventBus.register(listener)
        onDispose {
            EventBus.unregister(listener)
        }
    }

    Text(text = receivedData)
}

@Composable
fun EventBusExample() {
    SenderComponent()
    ReceiverComponent()
}    

分析:EventBus 对象管理事件的注册、注销和发布。register 方法用于添加监听器,unregister 方法用于移除监听器,post 方法用于发布事件。

优点

简单易实现:自定义事件总线的实现方式比较基础,不需要引入额外的依赖库。可以根据自己的需求,用简单的集合和回调机制来实现一个基本的事件总线,对于小型项目或者简单的通信需求来说,实现成本较低。

灵活性高:可以完全按照自己的需求来设计事件总线的接口和功能。例如,你可以自定义事件的优先级、过滤规则等,满足一些特殊的业务需求。

缺点

缺乏响应式编程特性:自定义事件总线通常是基于回调机制实现的,不具备 Kotlin Flow 那样的响应式编程能力。在处理异步数据流、背压等复杂场景时,需要自己手动实现很多逻辑,增加了开发的复杂度。

使用 Kotlin Flow 实现事件总线

Kotlin 复制代码
import androidx.compose.runtime.*
import androidx.compose.material3.Button
import androidx.compose.material3.Text
import kotlinx.coroutines.flow.MutableSharedFlow
import kotlinx.coroutines.flow.SharedFlow

object FlowEventBus {
    private val eventFlow = MutableSharedFlow<Any>()
    val events: SharedFlow<Any> = eventFlow

    suspend fun post(event: Any) {
        eventFlow.emit(event)
    }
}

@Composable
fun FlowSenderComponent() {
    val scope = rememberCoroutineScope()
    Button(onClick = {
        scope.launch {
            FlowEventBus.post("New data from flow sender")
        }
    }) {
        Text(text = "Send Data with Flow")
    }
}

@Composable
fun FlowReceiverComponent() {
    var receivedData by remember { mutableStateOf("No data received") }
    val scope = rememberCoroutineScope()

    LaunchedEffect(Unit) {
        FlowEventBus.events.collect { event ->
            if (event is String) {
                receivedData = event
            }
        }
    }

    Text(text = receivedData)
}

@Composable
fun FlowEventBusExample() {
    FlowSenderComponent()
    FlowReceiverComponent()
}  

优点

响应式编程:Kotlin Flow 是 Kotlin 协程中的响应式编程库,具有强大的异步数据流处理能力。使用 Kotlin Flow 实现事件总线可以方便地处理异步事件、背压、过滤、转换等操作,使代码更加简洁和易于维护。

类型安全:Kotlin Flow 是类型安全的,编译器可以在编译时检查类型错误,减少运行时错误的发生。这使得代码更加健壮,易于调试和维护。

与协程集成:Kotlin Flow 与 Kotlin 协程紧密集成,可以方便地在协程中使用。在处理异步事件时,可以充分利用协程的特性,如挂起、恢复等,提高代码的性能和可读性。

缺点

学习成本高:Kotlin Flow 是一个相对复杂的库,需要一定的时间来学习和掌握其使用方法。对于初学者来说,可能会觉得难以理解和使用。

引入额外依赖:如果项目中原本没有使用 Kotlin Flow,引入它会增加项目的依赖和代码量。

简而言之,若项目规模较小、通信需求简单,更适合使用自定义事件总线。若项目需要处理复杂的异步数据流、对代码的可维护性和可扩展性要求较高,那么使用 Kotlin Flow 实现事件总线是更好的选择。

相关推荐
LinXunFeng4 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
alexhilton5 天前
使用Android Archive进行打包
android·kotlin·android jetpack
Junerver8 天前
我写了一个 Compose Multiplatform 组件库,你可能会用到
kotlin·android jetpack
闪闪发亮的小星星9 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq9 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波9 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.9 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余9 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.9 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央9 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习