Reader small image

You're reading from  Kotlin Design Patterns and Best Practices - Third Edition

Product typeBook
Published inApr 2024
PublisherPackt
ISBN-139781805127765
Edition3rd Edition
Right arrow
Author (1)
Alexey Soshin
Alexey Soshin
author image
Alexey Soshin

Alexey Soshin is a software architect with 18 years of experience in the industry. He started exploring Kotlin when Kotlin was still in beta, and since then has been a big enthusiast of the language. He's a conference speaker, published writer, and the author of a video course titled Pragmatic System Design
Read more about Alexey Soshin

Right arrow

Racing

The Racing design pattern is a concurrency pattern that involves running multiple tasks that produce the same type of data concurrently and selecting the result from the task that completes first, discarding the results from the other tasks.

This pattern is useful in scenarios where you want to maximize responsiveness by accepting the result from the fastest task, even if multiple tasks are competing.

In Kotlin, you can implement the Racing pattern using the select function on channels. Here’s an example using two weather sources, preciseWeather and weatherToday, where you fetch weather information from both sources and accept the result from the source that responds first:

runBlocking {
    val winner = select<Pair<String, String>> {
        preciseWeather().onReceive { preciseWeatherResult ->
            preciseWeatherResult
        }
        weatherToday().onReceive { weatherTodayResult ->
            weatherTodayResult
        }
  ...
lock icon
The rest of the page is locked
Previous PageNext Page
You have been reading a chapter from
Kotlin Design Patterns and Best Practices - Third Edition
Published in: Apr 2024Publisher: PacktISBN-13: 9781805127765

Author (1)

author image
Alexey Soshin

Alexey Soshin is a software architect with 18 years of experience in the industry. He started exploring Kotlin when Kotlin was still in beta, and since then has been a big enthusiast of the language. He's a conference speaker, published writer, and the author of a video course titled Pragmatic System Design
Read more about Alexey Soshin