SlideShare une entreprise Scribd logo
1  sur  41
Introducing Scala


       Meetu Maltiar
    Principal Consultant
          Knoldus
Agenda

Starting a Scala project
Scala as a language
Scala Collections
Scala Test
SBT

Build tool for Scala based projects
Scala based frameworks like Akka uses it
SBT build definition uses scala based DSL
Incremental compilation
Works with mixed Scala and Java based projects
SBT: Lets create a project
SBT Installation download jar and create a script
Instructions: xsbt wiki
Descend in directory where you wanna create the project
In terminal type sbt
Once the sbt is started enter following commands
set name := “ScalaKnolx”
set version := “1.0”
set scalaVersion := “2.9.1”
session save
exit


Open build.sbt and have a look!!
SBT: Eclipse IDE
Add Typesafe repo and sbteclipse plugin
In build.sbt
resolvers += "Typesafe Repository" at "http://repo.typesafe.com/typesafe/releases/"

libraryDependencies += "org.scalatest" %% "scalatest" % "1.6.1"

libraryDependencies += "junit" % "junit" % "4.9"

Create project/plugins.sbt and add sbteclipse plugin
addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "2.0.0")

Execute sbt eclipse

It will generate eclipse related configs and now we are ready to import
this project in eclipse!!
Scala Introduction

Scala is a JVM based language

Scala combines FP and OO which makes it a scalable language

Scala has a REPL

Scala is interoperable with Java
Scala is a scripting language
It has a REPL.
Types can be inferred
Less Boilerplate

Scala> var capital = Map(“US” → “Washington”, “France” → “Paris”)

Capital: Map[String, String] = Map(US-> Washington, France->Paris)

Scala> capital += (“japan” → “Tokyo”)

Scala> capital(“France”)

Res2: String = Paris
Scala is OO
Every value is an object
Every operation is method call
Exceptions to this in java like statics and primitives are removed

Scala> (1).hashCode

Res1: Int = 1

Scala> (1).+(2)

Res2: Int = 3
Scala compared to Java
Scala adds                        Scala removes

+ pure object system              - static members

+ operator overloading            - primitive types

+ closures                        - break, continue

+ mixin composition with traits   - special treatment of interfaces


+ existential types               - wildcards

+ abstract types                  - raw types

+ pattern matching                - enums
Scala cheat sheet (1): Definitions
  Scala method definitions     Java method definitions

  def fun(x: Int) = {          Int fun(int x) {
    result                       return result
  }                            }

  def fun = result             (no parameterless methods)

  Scala variable definitions   Java variable definitions

  var x: Int = expression      Int x = expression
  val x: String = expression   final String x = expression
Scala cheat sheet (2): Definitions
 Scala Class and Object                         Java method definitions

 class Sample(x: Int, p: Int) {                 class Sample {
   def instMeth(y: Int): Int = x + y             private final int x;
 }                                               public final int p;

 object Sample {                                    Sample(int x, int p) {
  def staticMeth(x: Int, y: Int): Int = x * y         this.x = x;
 }                                                    this.p = p;
                                                    }

                                                    int instMeth(int y) {
                                                     return x + y;
                                                    }

                                                    static int staticMeth(int x, int y) {
                                                     return x * y;
                                                    }
                                                }
Scala cheat sheet (3): Traits

Scala Trait                          Java Interface

trait T {                            Interface T {
var field = “!”                       Int abstractMth(String x)
                                     }
def abstractMth(x: Int): Int
                                     (no concrete methods)
def concMth(x: String) = x + field   (no fields)
}

Scala mixin composition              Java extension plus implementation

class C extends Super with T         class C extends Super implements T
Scala HOF
Scala is also FP along-with OO
This means that Function is also an Object
They can be passed along as objects

private def higherOrderFunction(f: Int => Int, x:
Int): Int = {
   f(x) + 1
 }
Scala Pattern Match
All that is required is to add case keyword to each class that is to
be pattern matchable

Similar to switch except that Scala compares objects as
expressions
     getInteger(4) match {
       case 4 => println("four")
       case _ => println("not four")
 }

     def getInteger(x: Int): Int = {
     x
 }
Scala Traits
They are fundamental unit of code reuse in Scala

They encapsulates method and field definitions, which can be
reused by mixing them in classes

Unlike class inheritance a class can mix any number of traits

Unlike Interfaces they can have concrete methods
Scala Collections

Class Person(val name: String, age: Int)

val people: Array[Person]

val(minors, adults) = people partition (_.age < 18)


Three concepts:
  - pattern mach
  - infix method call
  - a function value
Scala way of Collections


De-emphasize destructive updates

Focus on transformers that map collections to collections

Have complete range of persistent collections
Collection Properties
Object-Oriented

Generic: List[T], Map[K, V]

Optionally persistent: scala.collections.immutable

Higher order: methods like foreach, map, filter

Uniform return type principle: operations return same

type as their left operand
Uniform Return Type Principle
scala> val ys = List(1,2,3)
ys: List[Int] = List(1,2,3)

scala> val xs: Seq[Int] = ys
xs: Seq[Int] = List(1,2,3)

scala> xs map(_ + 1)
res0: Seq[Int] = List(2,3,4)

scala> ys map(_ + 1)
res1: List[Int] = List(2,3,4)
Using Collections: Map and Filter
scala> val xs = List(1,2,3)
xs: List[Int] = List(1,2,3)

scala> val ys = xs map (x => x + 1)
xs: List[Int] = List(2,3,4)

scala> val ys = xs map(_ + 1)
ys: List[Int] = List(2,3,4)

scala> val zs = ys filter (_ % 2 == 0)
zs: List[Int] = List(2,4)

scala> val as = ys map (0 to _)
as: List[scala.collection.immutable.Range.Inclusive] =
List(Range(0,1), Range(0,1,2), Range(0,1,2,3))
Using Collections: flatMap and groupBy
scala> val bs = as.flatten
bs: List[Int] = List(0,1,0,1,2,0,1,2,3)

scala> val bs = ys flatMap(0 to _)
bs: List[Int] = List(0,1,0,1,2,0,1,2,3)

scala> val fruit = Vector(“apples”, “oranges”, “ananas”)
fruit: scala.collection.immutable.Vector[java.lang.String] =
Vector(“apples”, “oranges”, “ananas”)

scala> fruit groupBy (_.head)
res2: scala.collection.immutable.Map[char,
scala.collection.immutable.Vector[java.lang.String]] = Map(a->
Vector(apples, ananas), o -> Vector(oranges))
Using Collections: for notation

scala> for(x ← xs) yield x + 1                     // map
res0: Seq[Int] = List(2,3,4)

scala> for(x ← res0 if x % 2 == 0) yield x         // filter
res1: Seq[Int] = List(2,4)

scala> for(x ← xs; y ← 0 to x) yield y             // flatMap
res2: Seq[Int] = List(0, 1, 0, 1, 2, 0, 1, 2, 3)
String also a collection
Even String is a collection that means that we can apply higher
order functions on it

scala> val aString = “hello world”
aString: java.lang.String = hello world

scala> aString map (_.toUpper)
res1: String = HELLO WORLD
Using Maps
scala> val m = Map(1 → “ABC”, 2 → “DEF”, 3 → “GHI”)
m: scala.collection.immutable.Map[Int, java.lang.String] = Map(1 →
ABC, 2 → DEF, 3 → GHI)

scala> m(2)
res1: java.lang.String = DEF

scala> m + (4 → “JKL”)
res2: scala.collection.immutable.Map[Int, java.lang.String] = Map(1
→ ABC, 2 → DEF, 3 → GHI, 4 → JKL)

scala> m map {case (k, v) => (v, k)}
res2: scala.collection.immutable.Map[java.lang.String, Int] =
Map(ABC → 1, DEF → 2, GHI → 3)
Scala Collection Hierarchy

All collection classes are in scala.collection or one of its sub-
packages mutable, immutable and generic

Root collections are in scala.collection define same interface as
immutable collections and mutable collections add some
modification operations to make it mutable

The generic package contains building block for implementing
collections
Scala.Collection Hierarchy
Scala.Collection.Immutable
Overview of Collections
Commonality In Collections
All classes are quite common. For instance every collection can be
created by same uniform syntax
  Set(1, 2, 3)
  Seq(1, 2, 3)
  Traversable(1, 2, 3)
  Map(“x” → 24, “y” → 25)

Applies with specific collection implementations
 List(1, 2, 3)
 HashMap(“x” → 24, “y” → 25)

All these collections get displayed with toString in same way
Trait Traversable
Top of Collection Hierarchy. Its abstract method is foreach:
def foreach[U](f: Elem => U)

Traversable also provides lot of concrete methods they fall in following
categories
Everything is a library
Collections feel that they are language constructs

Language does not contain any collection related constructs
 - no collection types
 - no collection literals
 - no collection operators

Everything is in library

They are extensible
Scala Test

Scala Test is an open source framework for Java platform

With ScalaTest we can test either Scala or Java code

Integrates with popular tools like jUnit, TestNG, Ant, Maven and SBT

Designed to do different styles of testing like Behavior Driven Design for
example
Scala Test Concepts

Three concepts:

Suite: A collection of tests. A test is anything which has a name and can
succeed or fail

Runner: ScalaTest provides a runner application and can run a suite of
tests

Reporter: As the tests are run, events are fired to reporter, it takes care
of presenting results back to user
Scala Test Is Customizable
                  Suite
                 <<trait>>

 def expectedTestCount(Filter: Int)
 def testNames: Set[String]
 def tags: Map[String, Set[String]]
 def nestedSuites: List[Suite]
 def run(Option[String], Reporter, …)
 def runNestedSuites(Reporter, …)
 def runTests(Option[String]), Reporter
 def runTest(Reporter, …)
 def withFixture(NoArgTest)
Scala Test: under the hood
When you run a Test in Scala Test you basically invoke
run(Option[String], Reporter, …) on Suite object
It then calls runNestedSuites(Reporter, …)
And it calls runTests(Option[String], Reporter, …)

runNestedSuites(Reporter, …):
Invokes nestedSuites(): List[Suite] to get a list of nested suites

runTests(Option[String], Reporter, …) will call def testNames:
Set[String] to get set of test names to run. For each test it calls
runTest(Reporter, …) It wraps the test code as a Function object with a
name and passes it to the withFixture(NoArgTest) which actually runs the
test
Pick a core Trait
Mixin other Traits
Scala Test: Available Traits
Suite
FunSuite
Spec
FlatSpec
WordSpec
FeatureSpec
Assertions
ShouldMatchers
MustMatchers
Suite


Traits approach to writing tests. Create classes extending Suite
and define test methods

Test methods have names testXXXX. All methods must be public

Scala Test provides === operator. It is defined in Trait Assertions.
Allows the failure report to include both right and left values
FunSuite


For writing Functional Tests use FunSuite Fun => functional

“test” is a method defined in FunSuite Trait. Test name goes in
parentheses and test body goes in curly braces

The test code in curly braces is passed as a by-name parameter to
“test” method which registers for later execution
Assignment
Lets map the world. We have Continents and Countries

Make a Collection hierarchy to hold the above information

Write method on the collection hierarchy to get countries of a
continent

Write method on the collection hierarchy to get continent for a
country

Write tests using FunSuite to test the methods created above

Contenu connexe

Tendances

The Scala Programming Language
The Scala Programming LanguageThe Scala Programming Language
The Scala Programming Languageleague
 
Introduction à Scala - Michel Schinz - January 2010
Introduction à Scala - Michel Schinz - January 2010Introduction à Scala - Michel Schinz - January 2010
Introduction à Scala - Michel Schinz - January 2010JUG Lausanne
 
Pragmatic Real-World Scala (short version)
Pragmatic Real-World Scala (short version)Pragmatic Real-World Scala (short version)
Pragmatic Real-World Scala (short version)Jonas Bonér
 
scalaliftoff2009.pdf
scalaliftoff2009.pdfscalaliftoff2009.pdf
scalaliftoff2009.pdfHiroshi Ono
 
Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...
Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...
Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...Sanjeev_Knoldus
 
First-Class Patterns
First-Class PatternsFirst-Class Patterns
First-Class PatternsJohn De Goes
 
Procedure Typing for Scala
Procedure Typing for ScalaProcedure Typing for Scala
Procedure Typing for Scalaakuklev
 
Scala - en bedre og mere effektiv Java?
Scala - en bedre og mere effektiv Java?Scala - en bedre og mere effektiv Java?
Scala - en bedre og mere effektiv Java?Jesper Kamstrup Linnet
 
Metaprogramming in Scala 2.10, Eugene Burmako,
Metaprogramming  in Scala 2.10, Eugene Burmako, Metaprogramming  in Scala 2.10, Eugene Burmako,
Metaprogramming in Scala 2.10, Eugene Burmako, Vasil Remeniuk
 
Introduction to parallel and distributed computation with spark
Introduction to parallel and distributed computation with sparkIntroduction to parallel and distributed computation with spark
Introduction to parallel and distributed computation with sparkAngelo Leto
 
High Wizardry in the Land of Scala
High Wizardry in the Land of ScalaHigh Wizardry in the Land of Scala
High Wizardry in the Land of Scaladjspiewak
 

Tendances (17)

An introduction to scala
An introduction to scalaAn introduction to scala
An introduction to scala
 
The Scala Programming Language
The Scala Programming LanguageThe Scala Programming Language
The Scala Programming Language
 
Introduction à Scala - Michel Schinz - January 2010
Introduction à Scala - Michel Schinz - January 2010Introduction à Scala - Michel Schinz - January 2010
Introduction à Scala - Michel Schinz - January 2010
 
Pragmatic Real-World Scala (short version)
Pragmatic Real-World Scala (short version)Pragmatic Real-World Scala (short version)
Pragmatic Real-World Scala (short version)
 
Scala collections
Scala collectionsScala collections
Scala collections
 
scalaliftoff2009.pdf
scalaliftoff2009.pdfscalaliftoff2009.pdf
scalaliftoff2009.pdf
 
Google06
Google06Google06
Google06
 
Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...
Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...
Scala traits training by Sanjeev Kumar @Kick Start Scala traits & Play, organ...
 
Suit case class
Suit case classSuit case class
Suit case class
 
camel-scala.pdf
camel-scala.pdfcamel-scala.pdf
camel-scala.pdf
 
First-Class Patterns
First-Class PatternsFirst-Class Patterns
First-Class Patterns
 
Procedure Typing for Scala
Procedure Typing for ScalaProcedure Typing for Scala
Procedure Typing for Scala
 
Scala - en bedre og mere effektiv Java?
Scala - en bedre og mere effektiv Java?Scala - en bedre og mere effektiv Java?
Scala - en bedre og mere effektiv Java?
 
Metaprogramming in Scala 2.10, Eugene Burmako,
Metaprogramming  in Scala 2.10, Eugene Burmako, Metaprogramming  in Scala 2.10, Eugene Burmako,
Metaprogramming in Scala 2.10, Eugene Burmako,
 
Introduction to parallel and distributed computation with spark
Introduction to parallel and distributed computation with sparkIntroduction to parallel and distributed computation with spark
Introduction to parallel and distributed computation with spark
 
Practical cats
Practical catsPractical cats
Practical cats
 
High Wizardry in the Land of Scala
High Wizardry in the Land of ScalaHigh Wizardry in the Land of Scala
High Wizardry in the Land of Scala
 

Similaire à Introducing scala

Principles of functional progrmming in scala
Principles of functional progrmming in scalaPrinciples of functional progrmming in scala
Principles of functional progrmming in scalaehsoon
 
Getting Started With Scala
Getting Started With ScalaGetting Started With Scala
Getting Started With ScalaMeetu Maltiar
 
(How) can we benefit from adopting scala?
(How) can we benefit from adopting scala?(How) can we benefit from adopting scala?
(How) can we benefit from adopting scala?Tomasz Wrobel
 
Scala at GenevaJUG by Iulian Dragos
Scala at GenevaJUG by Iulian DragosScala at GenevaJUG by Iulian Dragos
Scala at GenevaJUG by Iulian DragosGenevaJUG
 
1.2 scala basics
1.2 scala basics1.2 scala basics
1.2 scala basicswpgreenway
 
Scala or functional programming from a python developer's perspective
Scala or functional programming from a python developer's perspectiveScala or functional programming from a python developer's perspective
Scala or functional programming from a python developer's perspectivegabalese
 
Introduction to Scala
Introduction to ScalaIntroduction to Scala
Introduction to ScalaBrian Hsu
 
Type Classes in Scala and Haskell
Type Classes in Scala and HaskellType Classes in Scala and Haskell
Type Classes in Scala and HaskellHermann Hueck
 
Introduction to scala
Introduction to scalaIntroduction to scala
Introduction to scalaMichel Perez
 
Functional Programming With Scala
Functional Programming With ScalaFunctional Programming With Scala
Functional Programming With ScalaKnoldus Inc.
 
Real Time Big Data Management
Real Time Big Data ManagementReal Time Big Data Management
Real Time Big Data ManagementAlbert Bifet
 
2014 holden - databricks umd scala crash course
2014   holden - databricks umd scala crash course2014   holden - databricks umd scala crash course
2014 holden - databricks umd scala crash courseHolden Karau
 

Similaire à Introducing scala (20)

Principles of functional progrmming in scala
Principles of functional progrmming in scalaPrinciples of functional progrmming in scala
Principles of functional progrmming in scala
 
Getting Started With Scala
Getting Started With ScalaGetting Started With Scala
Getting Started With Scala
 
(How) can we benefit from adopting scala?
(How) can we benefit from adopting scala?(How) can we benefit from adopting scala?
(How) can we benefit from adopting scala?
 
Scala at GenevaJUG by Iulian Dragos
Scala at GenevaJUG by Iulian DragosScala at GenevaJUG by Iulian Dragos
Scala at GenevaJUG by Iulian Dragos
 
Meet scala
Meet scalaMeet scala
Meet scala
 
1.2 scala basics
1.2 scala basics1.2 scala basics
1.2 scala basics
 
Scala Collections
Scala CollectionsScala Collections
Scala Collections
 
Scala or functional programming from a python developer's perspective
Scala or functional programming from a python developer's perspectiveScala or functional programming from a python developer's perspective
Scala or functional programming from a python developer's perspective
 
1.2 scala basics
1.2 scala basics1.2 scala basics
1.2 scala basics
 
Scala introduction
Scala introductionScala introduction
Scala introduction
 
Introduction to Scala
Introduction to ScalaIntroduction to Scala
Introduction to Scala
 
Scala Introduction
Scala IntroductionScala Introduction
Scala Introduction
 
Type Classes in Scala and Haskell
Type Classes in Scala and HaskellType Classes in Scala and Haskell
Type Classes in Scala and Haskell
 
Scala
ScalaScala
Scala
 
C# programming
C# programming C# programming
C# programming
 
Introduction to scala
Introduction to scalaIntroduction to scala
Introduction to scala
 
Spark workshop
Spark workshopSpark workshop
Spark workshop
 
Functional Programming With Scala
Functional Programming With ScalaFunctional Programming With Scala
Functional Programming With Scala
 
Real Time Big Data Management
Real Time Big Data ManagementReal Time Big Data Management
Real Time Big Data Management
 
2014 holden - databricks umd scala crash course
2014   holden - databricks umd scala crash course2014   holden - databricks umd scala crash course
2014 holden - databricks umd scala crash course
 

Plus de Meetu Maltiar

Plus de Meetu Maltiar (6)

Introducing Akka
Introducing AkkaIntroducing Akka
Introducing Akka
 
Fitnesse With Scala
Fitnesse With ScalaFitnesse With Scala
Fitnesse With Scala
 
Akka 2.0 Reloaded
Akka 2.0 ReloadedAkka 2.0 Reloaded
Akka 2.0 Reloaded
 
Scala categorytheory
Scala categorytheoryScala categorytheory
Scala categorytheory
 
Scala test
Scala testScala test
Scala test
 
Easy ORMness with Objectify-Appengine
Easy ORMness with Objectify-AppengineEasy ORMness with Objectify-Appengine
Easy ORMness with Objectify-Appengine
 

Dernier

Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Patryk Bandurski
 
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek SchlawackFwdays
 
Powerpoint exploring the locations used in television show Time Clash
Powerpoint exploring the locations used in television show Time ClashPowerpoint exploring the locations used in television show Time Clash
Powerpoint exploring the locations used in television show Time Clashcharlottematthew16
 
Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 365Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 3652toLead Limited
 
Commit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easyCommit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easyAlfredo García Lavilla
 
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Wonjun Hwang
 
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationBeyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationSafe Software
 
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024BookNet Canada
 
Leverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage Cost
Leverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage CostLeverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage Cost
Leverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage CostZilliz
 
My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024The Digital Insurer
 
SAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptxSAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptxNavinnSomaal
 
Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!Manik S Magar
 
Streamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project SetupStreamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project SetupFlorian Wilhelm
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Enterprise Knowledge
 
Artificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxArtificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxhariprasad279825
 
The Future of Software Development - Devin AI Innovative Approach.pdf
The Future of Software Development - Devin AI Innovative Approach.pdfThe Future of Software Development - Devin AI Innovative Approach.pdf
The Future of Software Development - Devin AI Innovative Approach.pdfSeasiaInfotech2
 
DevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenDevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenHervé Boutemy
 
WordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your BrandWordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your Brandgvaughan
 
Developer Data Modeling Mistakes: From Postgres to NoSQL
Developer Data Modeling Mistakes: From Postgres to NoSQLDeveloper Data Modeling Mistakes: From Postgres to NoSQL
Developer Data Modeling Mistakes: From Postgres to NoSQLScyllaDB
 
"ML in Production",Oleksandr Bagan
"ML in Production",Oleksandr Bagan"ML in Production",Oleksandr Bagan
"ML in Production",Oleksandr BaganFwdays
 

Dernier (20)

Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
 
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
 
Powerpoint exploring the locations used in television show Time Clash
Powerpoint exploring the locations used in television show Time ClashPowerpoint exploring the locations used in television show Time Clash
Powerpoint exploring the locations used in television show Time Clash
 
Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 365Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 365
 
Commit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easyCommit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easy
 
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
 
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationBeyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
 
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
 
Leverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage Cost
Leverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage CostLeverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage Cost
Leverage Zilliz Serverless - Up to 50X Saving for Your Vector Storage Cost
 
My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024
 
SAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptxSAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptx
 
Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!
 
Streamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project SetupStreamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project Setup
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024
 
Artificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxArtificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptx
 
The Future of Software Development - Devin AI Innovative Approach.pdf
The Future of Software Development - Devin AI Innovative Approach.pdfThe Future of Software Development - Devin AI Innovative Approach.pdf
The Future of Software Development - Devin AI Innovative Approach.pdf
 
DevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenDevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache Maven
 
WordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your BrandWordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your Brand
 
Developer Data Modeling Mistakes: From Postgres to NoSQL
Developer Data Modeling Mistakes: From Postgres to NoSQLDeveloper Data Modeling Mistakes: From Postgres to NoSQL
Developer Data Modeling Mistakes: From Postgres to NoSQL
 
"ML in Production",Oleksandr Bagan
"ML in Production",Oleksandr Bagan"ML in Production",Oleksandr Bagan
"ML in Production",Oleksandr Bagan
 

Introducing scala

  • 1. Introducing Scala Meetu Maltiar Principal Consultant Knoldus
  • 2. Agenda Starting a Scala project Scala as a language Scala Collections Scala Test
  • 3. SBT Build tool for Scala based projects Scala based frameworks like Akka uses it SBT build definition uses scala based DSL Incremental compilation Works with mixed Scala and Java based projects
  • 4. SBT: Lets create a project SBT Installation download jar and create a script Instructions: xsbt wiki Descend in directory where you wanna create the project In terminal type sbt Once the sbt is started enter following commands set name := “ScalaKnolx” set version := “1.0” set scalaVersion := “2.9.1” session save exit Open build.sbt and have a look!!
  • 5. SBT: Eclipse IDE Add Typesafe repo and sbteclipse plugin In build.sbt resolvers += "Typesafe Repository" at "http://repo.typesafe.com/typesafe/releases/" libraryDependencies += "org.scalatest" %% "scalatest" % "1.6.1" libraryDependencies += "junit" % "junit" % "4.9" Create project/plugins.sbt and add sbteclipse plugin addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "2.0.0") Execute sbt eclipse It will generate eclipse related configs and now we are ready to import this project in eclipse!!
  • 6. Scala Introduction Scala is a JVM based language Scala combines FP and OO which makes it a scalable language Scala has a REPL Scala is interoperable with Java
  • 7. Scala is a scripting language It has a REPL. Types can be inferred Less Boilerplate Scala> var capital = Map(“US” → “Washington”, “France” → “Paris”) Capital: Map[String, String] = Map(US-> Washington, France->Paris) Scala> capital += (“japan” → “Tokyo”) Scala> capital(“France”) Res2: String = Paris
  • 8. Scala is OO Every value is an object Every operation is method call Exceptions to this in java like statics and primitives are removed Scala> (1).hashCode Res1: Int = 1 Scala> (1).+(2) Res2: Int = 3
  • 9. Scala compared to Java Scala adds Scala removes + pure object system - static members + operator overloading - primitive types + closures - break, continue + mixin composition with traits - special treatment of interfaces + existential types - wildcards + abstract types - raw types + pattern matching - enums
  • 10. Scala cheat sheet (1): Definitions Scala method definitions Java method definitions def fun(x: Int) = { Int fun(int x) { result return result } } def fun = result (no parameterless methods) Scala variable definitions Java variable definitions var x: Int = expression Int x = expression val x: String = expression final String x = expression
  • 11. Scala cheat sheet (2): Definitions Scala Class and Object Java method definitions class Sample(x: Int, p: Int) { class Sample { def instMeth(y: Int): Int = x + y private final int x; } public final int p; object Sample { Sample(int x, int p) { def staticMeth(x: Int, y: Int): Int = x * y this.x = x; } this.p = p; } int instMeth(int y) { return x + y; } static int staticMeth(int x, int y) { return x * y; } }
  • 12. Scala cheat sheet (3): Traits Scala Trait Java Interface trait T { Interface T { var field = “!” Int abstractMth(String x) } def abstractMth(x: Int): Int (no concrete methods) def concMth(x: String) = x + field (no fields) } Scala mixin composition Java extension plus implementation class C extends Super with T class C extends Super implements T
  • 13. Scala HOF Scala is also FP along-with OO This means that Function is also an Object They can be passed along as objects private def higherOrderFunction(f: Int => Int, x: Int): Int = { f(x) + 1 }
  • 14. Scala Pattern Match All that is required is to add case keyword to each class that is to be pattern matchable Similar to switch except that Scala compares objects as expressions getInteger(4) match { case 4 => println("four") case _ => println("not four") } def getInteger(x: Int): Int = { x }
  • 15. Scala Traits They are fundamental unit of code reuse in Scala They encapsulates method and field definitions, which can be reused by mixing them in classes Unlike class inheritance a class can mix any number of traits Unlike Interfaces they can have concrete methods
  • 16. Scala Collections Class Person(val name: String, age: Int) val people: Array[Person] val(minors, adults) = people partition (_.age < 18) Three concepts: - pattern mach - infix method call - a function value
  • 17. Scala way of Collections De-emphasize destructive updates Focus on transformers that map collections to collections Have complete range of persistent collections
  • 18. Collection Properties Object-Oriented Generic: List[T], Map[K, V] Optionally persistent: scala.collections.immutable Higher order: methods like foreach, map, filter Uniform return type principle: operations return same type as their left operand
  • 19. Uniform Return Type Principle scala> val ys = List(1,2,3) ys: List[Int] = List(1,2,3) scala> val xs: Seq[Int] = ys xs: Seq[Int] = List(1,2,3) scala> xs map(_ + 1) res0: Seq[Int] = List(2,3,4) scala> ys map(_ + 1) res1: List[Int] = List(2,3,4)
  • 20. Using Collections: Map and Filter scala> val xs = List(1,2,3) xs: List[Int] = List(1,2,3) scala> val ys = xs map (x => x + 1) xs: List[Int] = List(2,3,4) scala> val ys = xs map(_ + 1) ys: List[Int] = List(2,3,4) scala> val zs = ys filter (_ % 2 == 0) zs: List[Int] = List(2,4) scala> val as = ys map (0 to _) as: List[scala.collection.immutable.Range.Inclusive] = List(Range(0,1), Range(0,1,2), Range(0,1,2,3))
  • 21. Using Collections: flatMap and groupBy scala> val bs = as.flatten bs: List[Int] = List(0,1,0,1,2,0,1,2,3) scala> val bs = ys flatMap(0 to _) bs: List[Int] = List(0,1,0,1,2,0,1,2,3) scala> val fruit = Vector(“apples”, “oranges”, “ananas”) fruit: scala.collection.immutable.Vector[java.lang.String] = Vector(“apples”, “oranges”, “ananas”) scala> fruit groupBy (_.head) res2: scala.collection.immutable.Map[char, scala.collection.immutable.Vector[java.lang.String]] = Map(a-> Vector(apples, ananas), o -> Vector(oranges))
  • 22. Using Collections: for notation scala> for(x ← xs) yield x + 1 // map res0: Seq[Int] = List(2,3,4) scala> for(x ← res0 if x % 2 == 0) yield x // filter res1: Seq[Int] = List(2,4) scala> for(x ← xs; y ← 0 to x) yield y // flatMap res2: Seq[Int] = List(0, 1, 0, 1, 2, 0, 1, 2, 3)
  • 23. String also a collection Even String is a collection that means that we can apply higher order functions on it scala> val aString = “hello world” aString: java.lang.String = hello world scala> aString map (_.toUpper) res1: String = HELLO WORLD
  • 24. Using Maps scala> val m = Map(1 → “ABC”, 2 → “DEF”, 3 → “GHI”) m: scala.collection.immutable.Map[Int, java.lang.String] = Map(1 → ABC, 2 → DEF, 3 → GHI) scala> m(2) res1: java.lang.String = DEF scala> m + (4 → “JKL”) res2: scala.collection.immutable.Map[Int, java.lang.String] = Map(1 → ABC, 2 → DEF, 3 → GHI, 4 → JKL) scala> m map {case (k, v) => (v, k)} res2: scala.collection.immutable.Map[java.lang.String, Int] = Map(ABC → 1, DEF → 2, GHI → 3)
  • 25. Scala Collection Hierarchy All collection classes are in scala.collection or one of its sub- packages mutable, immutable and generic Root collections are in scala.collection define same interface as immutable collections and mutable collections add some modification operations to make it mutable The generic package contains building block for implementing collections
  • 29. Commonality In Collections All classes are quite common. For instance every collection can be created by same uniform syntax Set(1, 2, 3) Seq(1, 2, 3) Traversable(1, 2, 3) Map(“x” → 24, “y” → 25) Applies with specific collection implementations List(1, 2, 3) HashMap(“x” → 24, “y” → 25) All these collections get displayed with toString in same way
  • 30. Trait Traversable Top of Collection Hierarchy. Its abstract method is foreach: def foreach[U](f: Elem => U) Traversable also provides lot of concrete methods they fall in following categories
  • 31. Everything is a library Collections feel that they are language constructs Language does not contain any collection related constructs - no collection types - no collection literals - no collection operators Everything is in library They are extensible
  • 32. Scala Test Scala Test is an open source framework for Java platform With ScalaTest we can test either Scala or Java code Integrates with popular tools like jUnit, TestNG, Ant, Maven and SBT Designed to do different styles of testing like Behavior Driven Design for example
  • 33. Scala Test Concepts Three concepts: Suite: A collection of tests. A test is anything which has a name and can succeed or fail Runner: ScalaTest provides a runner application and can run a suite of tests Reporter: As the tests are run, events are fired to reporter, it takes care of presenting results back to user
  • 34. Scala Test Is Customizable Suite <<trait>> def expectedTestCount(Filter: Int) def testNames: Set[String] def tags: Map[String, Set[String]] def nestedSuites: List[Suite] def run(Option[String], Reporter, …) def runNestedSuites(Reporter, …) def runTests(Option[String]), Reporter def runTest(Reporter, …) def withFixture(NoArgTest)
  • 35. Scala Test: under the hood When you run a Test in Scala Test you basically invoke run(Option[String], Reporter, …) on Suite object It then calls runNestedSuites(Reporter, …) And it calls runTests(Option[String], Reporter, …) runNestedSuites(Reporter, …): Invokes nestedSuites(): List[Suite] to get a list of nested suites runTests(Option[String], Reporter, …) will call def testNames: Set[String] to get set of test names to run. For each test it calls runTest(Reporter, …) It wraps the test code as a Function object with a name and passes it to the withFixture(NoArgTest) which actually runs the test
  • 36. Pick a core Trait
  • 38. Scala Test: Available Traits Suite FunSuite Spec FlatSpec WordSpec FeatureSpec Assertions ShouldMatchers MustMatchers
  • 39. Suite Traits approach to writing tests. Create classes extending Suite and define test methods Test methods have names testXXXX. All methods must be public Scala Test provides === operator. It is defined in Trait Assertions. Allows the failure report to include both right and left values
  • 40. FunSuite For writing Functional Tests use FunSuite Fun => functional “test” is a method defined in FunSuite Trait. Test name goes in parentheses and test body goes in curly braces The test code in curly braces is passed as a by-name parameter to “test” method which registers for later execution
  • 41. Assignment Lets map the world. We have Continents and Countries Make a Collection hierarchy to hold the above information Write method on the collection hierarchy to get countries of a continent Write method on the collection hierarchy to get continent for a country Write tests using FunSuite to test the methods created above