Effective Programming in Scala

Effective Programming in Scala

Cours
en
Anglais
Sous-titres disponibles
49 h
Ce contenu est noté 0 sur 5
Source
  • Sur www.coursera.org
Conditions
  • À son rythme
  • Accès libre
  • Certificat gratuit
Plus d'informations
  • 6 séquences
  • Niveau Intermédiaire
  • Sous-titres en English

Their employees are learning daily with Edflex

  • Safran
  • Air France
  • TotalEnergies
  • Generali
Découvrir Edflex

Détails du cours

Déroulé

WEEK 1 - Getting Started, Basics, Domain Modeling
First, get up and running with Scala on your computer. Then, learn how to write and evaluate basic expressions and definitions. Last, learn how to model a business domain by defining case classes and sealed traits.

WEEK 2 - Standard Library, Loops
Manipulate collections of values by using the generic List data type from the standard library. Then, learn about the other generic data structures provided by the standard library (sets, sequences, and maps), and their respective use cases. All the collection classes have a comprehensive set of high-level operations to transform, filter, and iterate over their elements. Last, you will learn a couple of techniques to implement loops in Scala, and their tradeoffs.

WEEK 3 - Build Tools, Modules
How to write Scala projects larger than a worksheet? Learn how to define an entry point for a Scala project, and discover the tools you can leverage to write, compile, run, and debug your code. Then, use object-oriented programming techniques to break down a complex project into small modular components. Finally, we discuss when to use case classes versus simple classes.

WEEK 4 - Reasoning About Code
The recommendation in Scala is to use immutable data types by default. Indeed, they have desirable properties such as being thread-safe and allowing local reasoning. However, in some cases, mutable variables lead to simpler code, as you will see in the lectures. We then dive into different testing techniques such as unit testing, property-based testing, integration testing, and mocking.

WEEK 5 - Type-Directed Programming
Programs automate repetitive tasks. Sometimes, writing a program is a repetitive task. We look into a unique feature of Scala that lets the compiler write some (repetitive) parts of your programs for you! Based on the expected type of a parameter, the compiler can provide a value for this parameter if it finds an unambiguous candidate value. This technique is often used to automatically generate the serializer and deserializer of a data type, solely based on its definition, for instance.

WEEK 6 - Error Handling, Concurrent Programming
Scala supports a simple low-level mechanism for error handling: exceptions. We discuss the pros and cons of this mechanism, and we show alternative approaches that you can apply when you want to make it explicit in a method signature that it can fail with an error. We then move to a similar topic, input data validation, where we want to construct nice-looking error messages listing all the errors that the user needs to fix. We conclude with a couple of lectures showing how to work with asynchronous computations, and how to leverage the multiple CPUs of a computer by running tasks in parallel. You will see that the same idioms we used for writing data validation rules can also be used to write graphs of parallel computations.

Prérequis

Aucun.

Intervenants

Julien Richard-Foy
Computer Scientist - Scala Center
Julien Richard-Foy makes Scala developers life easier, at Scala Center.

Noel Welsh
Noel Welsh is an experienced technology professional with a deep knowledge of software development, and machine learning. He likes writing books and speaking at conferences about programming.

Éditeur

L'École polytechnique fédérale de Lausanne (EPFL) est une université de recherche située à Lausanne, en Suisse, spécialisée dans les sciences physiques et l'ingénierie.

L'École polytechnique fédérale de Lausanne est l'une des deux écoles polytechniques fédérales suisses. Elle a été fondée par le gouvernement fédéral suisse avec la mission suivante :

former des ingénieurs et des scientifiques au plus haut niveau international
être un centre national d'excellence en science et en technologie
Fournir un centre d'interaction entre la communauté scientifique et l'industrie.
L'EPFL est considérée comme l'une des universités les plus prestigieuses au monde dans le domaine de l'ingénierie et des sciences. Elle est classée 17e au classement général et 10e dans le domaine de l'ingénierie dans le QS World University Rankings 2015 ; 34e au classement général et 12e dans le domaine de l'ingénierie dans le Times Higher Education World University Rankings 2015.

Plateforme

Coursera est une entreprise numérique proposant des formations en ligne ouverte à tous fondée par les professeurs d'informatique Andrew Ng et Daphne Koller de l'université Stanford, située à Mountain View, Californie.

Ce qui la différencie le plus des autres plateformes MOOC, c'est qu'elle travaille qu'avec les meilleures universités et organisations mondiales et diffuse leurs contenus sur le web.

Ce contenu est noté 4.5 sur 5
(aucun avis)
Ce contenu est noté 4.5 sur 5
(aucun avis)
Complétez cette ressource pour donner votre avis