Book Image

Hands-On Design Patterns with Kotlin

By : Alexey Soshin
Book Image

Hands-On Design Patterns with Kotlin

By: Alexey Soshin

Overview of this book

Design patterns enable you as a developer to speed up the development process by providing you with proven development paradigms. Reusing design patterns helps prevent complex issues that can cause major problems, improves your code base, promotes code reuse, and makes an architecture more robust. The mission of this book is to ease the adoption of design patterns in Kotlin and provide good practices for programmers. The book begins by showing you the practical aspects of smarter coding in Kotlin, explaining the basic Kotlin syntax and the impact of design patterns. From there, the book provides an in-depth explanation of the classical design patterns of creational, structural, and behavioral families, before heading into functional programming. It then takes you through reactive and concurrent patterns, teaching you about using streams, threads, and coroutines to write better code along the way By the end of the book, you will be able to efficiently address common problems faced while developing applications and be comfortable working on scalable and maintainable projects of any size.
Table of Contents (13 chapters)

Flat family

Say you have a list of other lists. You probably got it from different database queries, or maybe from different configuration files:

val listOfLists = listOf(listOf(1, 2),
listOf(3, 4, 5), listOf(6, 7, 8))

// [[1, 2], [3, 4, 5], [6, 7, 8]]

And you want to turn them into a single list such as the following:

[1, 2, 3, 4, 5, 6, 7, 8]

One way to merge those lists is to write some imperative code:

val results = mutableListOf<Int>()

for (l in listOfLists) {
results.addAll(l)
}

But calling flatten() will do the same for you:

listOfLists.flatten()

You can also control what happens with those results using flatMap():

println(listOfLists.flatMap {
it.asReversed()
})

Note that in this case, it refers to one of the sublists.

You can also decide to use flatMap() for type conversions:

println(listOfLists.flatMap {
it.map { it.toDouble() }
// ^ ^
// (1)...