Book Image

Mastering High Performance with Kotlin

Book Image

Mastering High Performance with Kotlin

Overview of this book

The ease with which we write applications has been increasing, but with it comes the need to address their performance. A balancing act between easily implementing complex applications and keeping their performance optimal is a present-day requirement In this book, we explore how to achieve this crucial balance, while developing and deploying applications with Kotlin. The book starts by analyzing various Kotlin specifcations to identify those that have a potentially adverse effect on performance. Then, we move on to monitor techniques that enable us to identify performance bottlenecks and optimize performance metrics. Next, we look at techniques that help to us achieve high performance: memory optimization, concurrency, multi threading, scaling, and caching. We also look at fault tolerance solutions and the importance of logging. We'll also cover best practices of Kotlin programming that will help you to improve the quality of your code base. By the end of the book, you will have gained some insight into various techniques and solutions that will help to create high-performance applications in the Kotlin environment
Table of Contents (12 chapters)

Coroutines

Coroutines are an experimental feature of Kotlin that allow you to write asynchronous code sequentially. Their experimental nature means that this feature is still under development but that we can use it in production. The concept of coroutines is based on suspended computations that don't block a thread.

Coroutines in Kotlin are based on three things:

  • Language-level support (the suspend keyword)
  • Low-level core API from the Kotlin standard library
  • High-level API

Setting up a project

If you use the Maven build system, you should add the following line to the configuration tag:

<arg>-Xcoroutines=enable</arg>

We need this because the coroutines feature has an experimental status now. The configuration...