From a4e4d58988ea7f6521f72f069c7ede7c8de22421 Mon Sep 17 00:00:00 2001 From: tassiLuca Date: Thu, 7 Mar 2024 12:03:14 +0000 Subject: [PATCH] deploy: e61044e3afd86718ea14d14cd1442f44e99a713e --- 404.html | 2 +- categories/index.html | 12 +- docs/01-overview/index.html | 379 ++++++++++++++++++ .../index.html | 32 +- docs/{02-basics => 03-basics}/index.html | 32 +- docs/{03-channels => 04-channels}/index.html | 47 +-- docs/05-conclusions/index.html | 259 ------------ docs/{04-rears => 05-rears}/index.html | 32 +- docs/index.html | 12 +- docs/index.xml | 30 +- ...632819308569c4e791c0763bba4cfc5affa5d.json | 1 - ...39d4c34cf9d6bf009a2124993806d3e50e428.json | 1 + ...7654ec92ace96dfa5464784bf41f620c35ae240.js | 2 +- index.html | 64 +-- index.xml | 30 +- sitemap.xml | 24 +- tags/index.html | 12 +- 17 files changed, 532 insertions(+), 439 deletions(-) create mode 100644 docs/01-overview/index.html rename docs/{01-boundaries => 02-boundaries}/index.html (95%) rename docs/{02-basics => 03-basics}/index.html (98%) rename docs/{03-channels => 04-channels}/index.html (97%) delete mode 100644 docs/05-conclusions/index.html rename docs/{04-rears => 05-rears}/index.html (98%) delete mode 100644 en.search-data.min.8589bd9a74808bf80af66629ef5632819308569c4e791c0763bba4cfc5affa5d.json create mode 100644 en.search-data.min.a12762fe0d0ac0594b436c422d039d4c34cf9d6bf009a2124993806d3e50e428.json rename en.search.min.103fe240c64dfac838151e2076d9e47f9cf5e03187ec7af6348c675d1835a82e.js => en.search.min.3f8b6945cd08ef775004f85d77654ec92ace96dfa5464784bf41f620c35ae240.js (90%) diff --git a/404.html b/404.html index 135790ac..a564f12d 100644 --- a/404.html +++ b/404.html @@ -18,7 +18,7 @@ - + + + + + + +
+ + +
+
+ +
+ + + 01 Overview + + +
+ + + + + + +
+ + + +

+ Overview of the project + # +

+

+ Context + # +

+

In the realm of asynchronous programming, the Scala ecosystem offers a set of solid and widely adopted monadic constructs and libraries to tackle complex tasks functionally with elegance and efficiency, like Monix Tasks and Cats Effecs, enabling a wide range of interesting and useful features, like composable error handling, cancellation mechanisms and structured concurrency that the standard library lacks. +However, they also come with a cost: the pervasiveness of the flatMap operator to compose values makes the code harder to reason about and difficult and awkward to integrate with regular control structures.

+

In the last years, we have been assisting the increase in adoption of continuation and coroutines in modern runtimes, either exploiting some kind of fibers support, like the project Loom with Virtual Threads, or via code generation, like Kotlin Coroutines, aiming to capture the essence of effects more cleanly compared to monads.

+

+ Goals + # +

+

The goal of this project is to explore, mainly focusing on Scala, the direct style, developing a few examples (not too complex) leveraging the new strawman library Gears, comparing it with Kotlin Coroutines and the current implementation of monadic Futures, seeking to analyze aspects such as:

+
    +
  • ergonomics of the two styles;
  • +
  • which of the two approaches has a real advantage in adoption;
  • +
  • pros and cons of the two styles;
  • +
  • any limitations and difficulties encountered in using them.
  • +
+

+ The contribution + # +

+

The project is built around three small examples.

+

The first aims, through the implementation of the core of a small Web service, to introduce the basics of asynchronous programming in direct style, focusing on structured concurrency and cancellation.

+

The second introduces the main communication and synchronization primitive of direct style, channels, and how they can be used to exchange data between concurrent tasks (either Futures or coroutines).

+

In this context, a contribution has been made by proposing the extension of the Scala Gears library with the following two abstractions, currently missing, inspired by those of the Kotlin Coroutines:

+
    +
  • terminable channels, i.e. a channel that can be terminated, but whose values can still be read by consumers after its termination until all values are consumed;
  • +
  • Flows, modeling a cold stream of asynchronously computed values which are particularly useful for implementing asynchronous functions that produce, not just a single, but a sequence of values.
  • +
+

The last example investigates how to implement a reactive-like event-based system using direct style, taking as a use case a small sensor control system in an IoT context that needs to react to events coming from different sensors.

+

To accomplish this, since Scala Gears lacks any kind of transforming operator, some have been introduced on top of channels (taking cues from Reactive frameworks) allowing them to be manipulated functionally.

+

+ Conclusions + # +

+

The current implementation of monadic Futures present in the standard library is insufficient to handle modern asynchronous programming in a structured and safe way: it lacks structured concurrency and cancellation mechanism, is not referential transparent and requires to be ugly mixed with direct style constructs to be used appropriately.

+

This leads to the adoption of effectful libraries that offer these and many other powerful abstractions, beautifully wrapped in monadic constructs. +This is the main pro and con of the monadic approach: what makes monads remarkable is their capability to turn statements into programmable values and introduce constructs to transform and compose them functionally in a very elegant (and somehow “magical” for ones who are not familiar with them) way. +Despite this idyllic beauty, monads and effectful libraries require relevant expertise in functional programming to be fully grasped and composed effectively.

+

Direct style frameworks are indeed arising as a more natural and intuitive way to handle concurrency, leveraging an imperative-like programming style that is familiar to all developers.

+

In the JVM ecosystem, the most adopted and known direct-style library is the Kotlin Coroutines, which were introduced in 2018 by modifying the Kotlin language (rather than its runtime, like the project Loom has recently done with Virtual Thread) to support suspending functions. +The main advantages of Kotlin Coroutines are that they provide suspension and cancellation mechanisms that are simple to understand and use, as well as a good ecosystem for channels and Flows. +Despite this, Coroutines are not still perfect: due to their design they partially suffer from the colored functions problem and we need to be aware we can not use the same synchronization concurrency abstractions that we would use in Java with threads (like locks, synchronized, …) cause they are not designed to be used in the coroutines context.

+

Scala Gears is an attempt to bring direct style into the Scala ecosystem. +Its API design is inspired by Kotlin Coroutines and, despite the fact it achieves suspension, unlike Kotlin, leveraging Virtual Threads for JVM and delimited continuation for Scala Native, the majority of constructs can be mapped to the Kotlin Coroutines ones. +Despite being a very young project, it already offers a good set of abstractions for asynchronous programming, although it cannot yet be considered a mature library ready to be used in a production environment:

+
    +
  • some design choices should be addressed: +
      +
    • closing a channel prevents any further reading, precluding the possibility of processing the remaining values (see second example);
    • +
    • Task scheduling behavior has a strange behavior with higher-order functions (see third example);
    • +
    +
  • +
  • missing abstractions: the library is still missing some important abstractions, like the proposed Flows for handling a cold stream of asynchronously computed values and operators for functionally transforming them;
  • +
  • performances: the project has been created for experimenting, thus performances have not been considered a priority so far, even though a comparison in overheads of +the core primitives has been published.
  • +
+

In conclusion, Scala Gears is a promising project that could bring direct-style async programming into the Scala ecosystem, giving, together with boundary and break Scala 3 support, a nice alternative to the current monadic approach, simplifying the way we handle concurrency, making it more natural and intuitive.

+

+ References + # +

+ + + + + + + + + Home + + + + + + + + + + Next: boundary & break + + +
+ + + +
+ +
+ + + + + + + +
+ + + + + + + + +
+ + + +
+ +
+ + + + +
+ + + + +
+ + + + + + + + + + + + + + + + diff --git a/docs/01-boundaries/index.html b/docs/02-boundaries/index.html similarity index 95% rename from docs/01-boundaries/index.html rename to docs/02-boundaries/index.html index 7de841bc..d5148863 100644 --- a/docs/01-boundaries/index.html +++ b/docs/02-boundaries/index.html @@ -11,17 +11,17 @@ - + - + -01 Boundaries | direct-style-experiments +02 Boundaries | direct-style-experiments - + - + - - - - - -
- - -
-
- -
- - - 05 Conclusions - - -
- - - - -
- - - -

- Conclusions and Final Considerations - # -

-

In conclusion, this project analyzed the main direct asynchronous programming abstractions offered by Kotlin’s Coroutines and Scala’s new, still entirely experimental library proposal, Gears. -During the analysis, input was also provided for its possible extension where it was deemed lacking compared to the Kotlin Coroutines framework.

-

Despite being a very young project, created for experimenting with direct style in Scala, it already offers a good set of abstractions for asynchronous programming, and seems to be promising for the future.

-

In general, the direct style is a very interesting approach and it is worth exploring further in the context of asynchronous programming, where it can offer a more natural and intuitive way to handle concurrency with respect to monadic transformations, which require a more complex model to be fully understood and grasped.

- - - - - - - - Home - - -
- - - -
- -
- - - - - - - -
- - - - - - - - -
- - - -
- -
- - - - -
- - -
- - - - - - - - - - - - - - - - diff --git a/docs/04-rears/index.html b/docs/05-rears/index.html similarity index 98% rename from docs/04-rears/index.html rename to docs/05-rears/index.html index bc8d4c19..c285fba1 100644 --- a/docs/04-rears/index.html +++ b/docs/05-rears/index.html @@ -11,17 +11,17 @@ - + - + -04 Rears | direct-style-experiments +05 Rears | direct-style-experiments - + - +