Scala

Join the Scala Track
Scala combines object-oriented and functional programming in one concise, high-level language. Scala's static types help avoid bugs in complex applications, and its JVM and JavaScript runtimes let you build high-performance systems with easy access to huge ecosystems of libraries.
Join the Scala Track
Track mentors

17 Mentors

Our mentors are friendly, experienced Scala developers who will help teach you new techniques and tricks.
Track students

8,571 Students

Join thousands of students who have enjoyed learning and improving their skills by taking this track.
Track exercises

91 Exercises

Hundreds of hours have gone into making these exercises fun, useful, and challenging to help you enjoy learning.

About Scala

object HelloWorld {
  def hello() = "Hello, World!"
}

Scala combines object-oriented and functional programming in one concise, high-level language. Scala's static types help avoid bugs in complex applications, and its JVM and JavaScript runtimes let you build high-performance systems with easy access to huge ecosystems of libraries.

  • Features
    • JVM Interoperability - Scala runs on the JVM, so Java and Scala stacks can be mixed for seamless integration.
    • Type Inference - Scala is statically typed. However, Scala provides type inference to ease the burden of an advanced type system.
    • Object Oriented - Scala is a pure object-oriented language in the sense that every value is an object. Data types and behaviors of objects are described by classes and traits. Class abstractions are extended by subclassing and by a flexible mixin-based composition mechanism to avoid the problems of multiple inheritance.
    • Functional - Scala is also a functional language in the sense that every function is a value. Scala provides a lightweight syntax for defining anonymous functions, it supports higher-order functions, it allows functions to be nested, and supports currying. Scala’s case classes and its built-in support for pattern matching model algebraic types used in many functional programming languages. Singleton objects provide a convenient way to group functions that aren’t members of a class.
    • Concurrency & Distribution - Use data-parallel operations on collections, use actors for concurrency and distribution, or futures for asynchronous programming.
Join the Scala track

A tremendous learning opportunity to explore the depth of your own knowledge

Exercism is fantastic in learning new languages but that is not the extent of it. If you are a "more experienced" programmer you may have encountered impostor syndrome: the idea you don't really know what you think you know. Exercism lets you solve problems and put them in the space of open feedback which is a tremendous learning opportunity to explore the depth of your own knowledge. Even if you have been programming in a language for awhile it is worth checking into Exercism to see where you stand with current implementation practices.

Relaxed. Encouraging. Supportive.

Meet the Scala Track mentors

Once you join the Scala language track, you will receive support and feedback from our team of mentors. Here are the bios of a few of the mentors of this track.

Avatar of Sergey Fedotov

Sergey Fedotov GitHub

Game Unity3d and Java developer.
Avatar of Rajesh Pitty

Rajesh Pitty https://github.com/rajeshpg

a passionately curious scala functional programmer
Avatar of Rutger Claes

Rutger Claes https://github.com/rutgerclaes

I really like working in Scala. It allows me to come up with elegant, functional code that is also concise and type safe.
Avatar of Leo Benkel

Leo Benkel leobenkel.com

I am an experienced developer and research scientist that is passionate about Sciences and Technologies. I love working with teams that want to create the 'possible' out of the 'improbable' while leveraging my creative mind and prototyping/research skills. Simply, I love exploring where no-one has ever been before.
Avatar of Jacqueline Outka

Jacqueline Outka https://github.com/outkaj

I find Scala to be both a beautiful and useable language. I like that you can use clear and concise functional paradigms, while still enjoying the benefits of object orientation and JVM interoperability.
Avatar of Max Leuthäuser

Max Leuthäuser GitHub

Software Engineer and IT Consultant. Scala Enthusiast.
Fun. Challenging. Interesting

Community-sourced Scala exercises

These are a few of the 91 exercises on the Scala track. You can see all the exercises here.

Linked List
medium
generics
lists
optional values
Palindrome Products
medium
algorithms
optional values
sets
strings
tuples
math
House
medium
algorithms
strings
text formatting
Grains
easy
optional values
Clock
easy
structural equality
time
Hamming
easy
filtering
optional values
strings
Passionate. Knowledgeable. Creative.

Meet the Scala Track maintainers

The Scala Maintainers are the brains behind the Scala Track. They spend their spare time creating interesting and challenging exercises that we can all learn from. We are incredibly grateful for their hard work. Here are the bios of a few of the maintainers of this track.

Avatar of Erik Schierboom

Erik Schierboom My blog

This maintainer has not added their bio yet.
Avatar of Ric Emery

Ric Emery

This maintainer has not added their bio yet.

Get started with the Scala track. As with everything on Exercism, it's 100% free!

Join the Scala Track