Code: PRG900
Duur in dagen: 3
Download: Open Rooster.pdf
Download: Infosheet
€ 1499

Cursus Scala Programmeren

29-01 t/m 31-01-2018
26-03 t/m 28-03-2018
28-05 t/m 30-05-2018
30-07 t/m 01-08-2018
24-09 t/m 26-09-2018
Uw startdatum
Regio:

Doelgroep Cursus Scala Programmerenp

Cursus Scala Programmeren Deze cursus is bestemd voor Java, C# en andere developers die willen leren programmeren in Scala of die de mogelijkheden van Scala willen onderzoeken.

Voorkennis Cursus Scala

Om aan deze cursus te kunnen deelnemen is kennis en ervaring met een object georiënteerde programmeertaal zoals Java of C# vereist.

Uitvoering Training Scala Programmeren

De theorie wordt behandeld aan de hand van presentatie slides. Demo’s worden gebruikt om de concepten te verduidelijken. De theorie wordt afgewisseld met oefeningen. Er wordt gebruik gemaakt van een moderne IDE. De cursustijden zijn van 9.30 tot 16.30.

Certificering Scala Programmeren

De deelnemers krijgen na het goed doorlopen van de cursus een officieel certificaat Scala Programmeren.

Inhoud Cursus Scala Programmeren

In de cursus Scala Programmeren worden de syntax en mogelijkheden van de Scala programmeertaal besproken. Scala combineert de kracht van object georiënteerd en functioneel programmeren en maakt het mogelijk om met aanzienlijk minder code een vergelijkbare functionaliteit te leveren als Java of C#. Aandacht wordt besteed aan de data types, variabelen, control structures en packages van Scala, de mogelijkheden om Scala uit te breiden en het gebruik van Scala Frameworks zoals het Lift Web Framework en het Play Framework. Speciale aandacht gaat uit naar de functionele aspecten van Scala zoals first-class functions, higher order functions en de verschillende manieren van parameter overdracht in Scala. Ook andere typische taal elementen van Scala komen aan de orde zoals closures en deferred execution. Vervolgens wordt stil gestaan bij collection types zoals lists, maps en tuples en hun respectievelijke higher order functions. Ook de object georiënteerde aspecten van Scala zoals inheritance, constructors companion objects en overriding worden besproken. Hierbij wordt ook stil gestaan bij de ondersteuning van duck typing. Uitgebreid wordt stil gestaan bij het concept van Scala Traits and het gebruik van mixins. Een aparte module is gewijd aan hoe Scala omgaat met XML en JSON data. Tot slot wordt aandacht besteed aan concurrency in Scala met het Akka Framework met Actors en Mailboxes en asynchrone communicatie.

Module 1 : Scala Intro

Module 2 : Language Syntax

Module 3 : Functions and Closures

Introducing Scala
Basic Syntax
Scala Concepts
Semicolons
Scala Keywords
Scala Characteristics
Comments in Scala
Interactive Shell
Compiling Scala
Scala HelloWorld
Variables and Constants
Java versus Scala
Scala versus Java
Scala Resources
Variables
Variable Scopes
Scala Data Types
Scala Type Hierarchy
If and Else Statements
Multiple Selection
For Loop
For Yield Filtering
While Loops
Breakable Blocks
Formatted Strings
Scala Arrays
Processing Arrays
Multidimensional Arrays
Ranges
Scala Operators
Reserved Symbols
Scala Functions
Void Functions
Call by Value
Call by Name
Named Parameters
Variable Arguments
Default Parameters
Recursive Functions
Nested Functions
Methods versus Functions
Anonymous Functions
First Class Functions
Higher Order Functions
Partially Applied Functions
Currying Functions
Simple Closure

Module 4 : Collections

Module 5 : Classes and Traits

Module 6 : Pattern Matching

Scala Collections
Scala Collection Hierarchy
Scala Lists
Nills and Cons
Head and Tail
List Concatenation
List Fill andTabulate
Scala Sets
Concatenation Min and Max
Intersections and Unions
Scala Maps
Maps Concatenation
Keys and Values
Scala Tuples
Tuple Access
Scala Options
GetOrElse
Scala Object Orientation
Scala Classes
Preventing State Change
Object Singleton
Constructors
Visibility of Constructor Fields
Companion Objects
Inheritance
Abstract Classes
Traits
Partial Trait Implementation
Abstract Members
Mixins
Implicit Classes
Scala JavaBeans
Unit returning Expressions
Dealing with Any
Match Expression
Example Match Expressions
Matching using case Classes
Match with Variables
Match with Sequences
Extended Wildcard _*
Scala versus Java
Pattern Matching in Assignments
Match with Types
Matching on Tuples
Pattern Matching with Option

Module 7 : Data Access

Module 8 : Scala Concurrency

Unit returning Expressions
Dealing with Any
Match Expression
Example Match Expressions
Matching using case Classes
Match with Variables
Match with Sequences
Extended Wildcard _*
Scala versus Java
Pattern Matching in Assignments
Match with Types
Matching on Tuples
Pattern Matching with Option
Concurrent Programming
Akka Framework
Actors in Akka
Hello Akka World
ActorSystem
Actor Hierarchy
Actor Information
Supervision
Supervision Strategies
Top Level Supervisors
OneForOneStrategy
Location Transparency
Akka Guidelines

Kantooradres:
SpiralTrain BV

Gebouw "De Sijnsmeester"
Standerdmolen 8 – 1.11
3995 AA Houten

IP Computer Training Centrum
Diemerhof 32-36
1112 XN Diemen

020 7600027
http://www.ip-computer-training-centrum.nl

Compu Act Opleidingen
Slinge 303
3085 ER Rotterdam

023 - 551 3409
www.computertraining.nl

Trainspot
Kleine Singel 33
3572 CG Utrecht

030 - 737 05 81
http://www.trainspot.nl

IP Computer Training Centrum
Leenderweg 292
5644 AE Eindhoven

040 - 256 65 20
http://www.ip-computer-training-centrum.nl