Like any new technology, Scala and its ecosystem take a while to master and can be frustrating at times. Don't get discouraged! Here are some resources to help.
- Popular IDEs are IntelliJ IDEA with the Scala plugin and Visual Studio Code with the Scala (Metals) extension. If you're unsure which to choose, go with IntelliJ.
- Functional vs Imperative Programming
The core of Functional Programming is thinking about data-flow rather than control-flow. Although, by virtue of editing plain text, you are forced to order your code in a linear sequence of statements, those statements are a thin skin over what you really care about: the shape and structure of the data-flow graph within your program.
- Tour of Scala β A tour of bite-sized introductions to the most frequently used features of Scala intended for newcomers to the language.
- Scala: The Good Parts β Scala allows you to accomplish tasks in different ways. This blog post explains some of the more readable, maintainable approaches.
- Scala Best Practices β Rather than using random examples from Scala projects in the wild, these are meant as an evolving "best" way of doing things.
- π» Scala Exercises β An Open Source project for learning different Scala technologies. Generally relevant are the "Scala Tutorial", "Std Lib", and "Cats" exercises.
- π Scala for the Impatient β An approachable book (384 pages and you can skip the chapters on XML and Parsers) for experienced Java/C++/C# developers who are new to Scala or functional programming. It introduces key Scala concepts and techniques in order to be productive quickly.
Tools/Libraries
- sbt β Scala Build Tool, similar to Gradle for Java.
- Scalafmt β Code formatter, similar to Prettier for JavaScript.
- Scalafix β Refactoring and linting tool, similar to ESLint for JavaScript.
- ScalaTest β Testing tool, similar to JUnit for Java.
- mockito-scala β Test mocking, a Scala-friendly API over Java's Mockito.
- Cats β Short for "category", provides functional programming abstractions. The homepage provides a Jump Start Guide, Type Class and Date Type documentation, and motivations behind the library. β π Scala with Cats β Free e-book available in HTML, PDF, and ePUB formats introducing the Cats library.
- Akka and Akka Streams β A toolkit for building highly concurrent, distributed, and resilient message-driven applications.
- Alpakka β An Akka Streams-based library used to publish and subscribe to SQS, S3, Kafka, etc. with built-in back pressure support.
- Slick β A reactive, functional object-relational mapper (ORM).
Top comments (0)