Julien Richard-Foy
We are excited to announce that our new MOOC “Effective Programming in Scala” is now
live on Coursera! We are also happy to share that most of our existing courses have already
been updated to Scala 3.
Effective Programming in Scala
The Effective Programming in Scala course aims to teach non-Scala programmers everything
they need to become professional Scala 3 programmers in six weeks. This course shows you how
to embrace both functional programming and object-oriented programming in a simple and
practical way to write software at scale. It explains how to achieve typical programming
tasks in Scala, such as modeling business domains, breaking down complex problems into
simpler problems, manipulating data, or running parallel tasks. Throughout the course, you
will also learn the best practices for writing high-quality Scala code that scales to large
applications, how to handle errors, how to write tests, and how to leverage a productive
development environment.
The course features six auto-graded programming assignments, which have been designed to
be both fun and close to real-world programs. Topics covered by the assignments include
graphical animations, web applications, property-based testing, generic programming,
and parallel data processing.
Each week contains several video lectures of ~10 minutes each. Lectures are focused on
a specific skill or concept, and they are generally followed by a quiz so that you
can immediately assess your understanding of the lesson.
The syllabus is organized as follows:
- week 1: basics of the language, and how to model business
domains with sealed traits and case classes, - week 2: manipulate collections of data with the standard library,
and write business logic, - week 3: tooling around the Scala language (IDE, build tools,
debuggers), organize large programs into modules, - week 4: reason about code, write unit tests, property-based tests, and
integration tests in Scala, - week 5: contextual abstractions (aka “implicits” in Scala 2),
- week 6: error handling, data validation, and concurrent programming.
The course has been co-designed by myself (Julien Richard-Foy) and Noel Welsh.
Noel Welsh has a long experience in teaching Scala, both in the industry and
within the Scala Bridge project.
Check out this video for more details about the course Effective Programming in Scala:
Other Scala Courses
The Scala Center and Martin Odersky have also been working hard to update all our
existing courses to Scala 3 (except the courses that use Spark, which still use
Scala 2.12).
This is a huge effort, and some parts are still in progress. Here is the current
status, at the time this blog is written:
We will update our Spark courses to Scala 3 as soon as there is a stable release of
Spark that supports Scala 3.
The Scala Specialization always points to the latest version of the courses (we
will roll out the Scala 3 versions in the coming weeks).
Nevertheless, in case you want to access the Scala 2 version of the courses, they
are still available here:
التعليقات