SlideShare uma empresa Scribd logo
1 de 21
Baixar para ler offline
Stepping Up: A Brief Intro to Scala

    Derek Chen-Becker, October 10th, 2009
A little background

    Scala began around 2003, 2.0 in 2006,
    currently at 2.7.5 (stable)

    Created by Martin Odersky (EPFL), of GJ,
    and later Javac v5 fame

    Compiles to 100% Java Bytecode
    
        Generally works flawlessly with Java
    
        Leverages JIT: performance ±5% of Java

    Excellent community (mailing lists, IRC)

    In use at Twitter, Seimens, Xerox, and others
Not quite déjà vu...
Scala combines features from many different
languages to form a unique hybrid:
  
      Scala is pure OO. Everything is an object, even
      primitives
  
      Scala has first-class function objects. Much of
      the library leverages function arguments
  
      Scala has a comprehensive type system and a
      flexible inheritance mechanism
  
      Method names have less restrictions. This allows
      for operator overloading and nice DSLs
  
      Immutability is strongly supported and
      encouraged. This is important for multi-core
Statics and Singletons


    Scala makes a distinction between
    instance and static methods and fields by
    using a separate “object” entity to
    represent the latter

    Objects are VM singletons

    Objects can be used to create custom
    factories and pattern matching extractors
    (more in a moment)
Scala is Succinct
public class Bike {
  private String brand;
  private int gear;

    public Bike(String brand,           class Bike (val brand : String,
                int gear) {                         var gear : Int) {
      this.brand = brand;                 override def toString =
      this.gear = gear;                     "This is a %s in gear %d"
    }                                         .format(brand, gear)
                                        }
    public int getGear() {
      return gear;
    }

    public void setGear(int gear) {
      this.gear = gear;
    }

    public String getBrand() {
      return brand;
    }
    public String toString() {
      return String.format("This is a %s in gear %d", brand, gear);
    }
}
Scala has Case Classes

    Case classes are defined basically like normal
    classes

    By default are immutable (good!)

    Constructor parameters are automatically vals

    Automatically get a companion object with
    apply/unapply, as well as overrides for equals,
    hashCode and toString on the class itself

case class Book(title : String, author : String)

val classic =
  Book("A Tale of Two Cities", "Dickens")

val Book(title,author) = classic
Scala has Case Classes, part 2

    Can inherit from other classes (although inheriting
    from other case classes is being deprecated)

    Can have their own methods just like normal
    classes

class Vehicle(val description : String,
              val topSpeed : Long)

case class Airplane(description : String,
                    topSpeed : Long,
                    var fuel : Double)
    extends Vehicle(description,speed) {
  def takeOff {...}
}
Scala is Functional
Functions in Scala are first-class objects, and
can be passed as arguments, assigned to
variables, etc.

val printLog =
{ msg : String => // or ⇒
    println(System.currentTimeMillis + ":" + msg)
}

List("one", "two", "three").foreach(printLog)
Scala is Functional, Part 2
Functions (and Scala's type system) allow you
to do things like define new control structures
in a type-safe way:
// Structural typing allows any type with a “close” method
def using[A <: { def close() : Unit }, B]
    (resource : A )
    (f : A => B) : B =
  try {
    f(resource)
  } finally {
    resource.close
  }

val firstLine =
  using(new BufferedReader(new FileReader("/etc/hosts"))) {
    reader => reader.readLine
  }
Scala has Closures
Closures capture variables in the scope of their
definition. These are ideal for callbacks, among
other things.

// Note that this example is not thread-safe
def logAndAdd(name : String) = {
  var counter = 0

    val logFunc = { msg : String =>
      println(name + "-" + counter + ":" + msg)
      counter += 1
    }

    logFunc
}
Scala is Higher Level
In particular, collections support complex
operations directly:
case class User(name : String, age : Int)
val people = List(User("Fred", 35), User("Barney", 32),...)

val sorted = people.sort(_.age < _.age).take(5)

// The same as :
val sorted =
  people.sort({(a,b) => a.age < b.age}).take(5)

val under30 = sorted.takeWhile(_.age < 30)

val youngest5 = sorted.take(5)

val oldest5 = sorted.takeRight(5).reverse
Scala has For-Comprehensions
For-comprehensions provide an elegant
construct for tying multiple sources and
criteria together to extract information:
val prefixes = List("/tmp", "/work",
                    System.getProperty("user.home"))

val suffixes = List("txt", "xml", "html")

def locateFiles(name : String) : List[String] =
  for (prefix <- prefixes;
       suffix <- suffixes;
       filename <-
         Some("%s/%s.%s".format(prefix, name, suffix))
           if (new File(filename)).exists)
    yield filename
Scala does Pattern Matching

    Like the “switch” statement on steroids

    Incredibly powerful for expressing
    conditional logic

    Cases are tested in order
def matchIt (in : Any) = in match {
  case 1 | 14 | "test" => {...}
  case x : Int => {...}
  case x : Double if x > 42.0 => {...}
  case Vehicle(description, _) => {...}
  case <head>{ stuff }</head> => {...}
  case _ => {...}
}
Scala does Custom Matching

    My favorite Scala example (more in the
    handout)
// Regexps in Scala define a custom unapply to match on groups
val colonSplit = """(w+):(w+)""".r

// It's easy to define your own as well
object IntVal {
  def unapply(in : String) =
    try { Some(in.toInt) } catch { case _ => None }
}

def parts (in : String) = in match {
// Matching allows nested use of extractors (here we want Ints)
  case colonSplit(IntVal(number), value) if number == 14 => {...}
  case colonSplit(IntVal(number), value) => {...}
  case colonSplit(key, value) => {...}
  case _ => {...}
}
Scala has Traits

    At their most basic, traits are 1-to-1 with Java
    interfaces

    Support concrete implementations of methods

    Support both concrete and abstract
    implementations of vals and vars

trait Named {
  val version = "1.0.0"

    val name : String

    def printName { println(name) }
}
Scala Enforces Trait Composition

    Traits can restrict which classes and traits
    they can be mixed into

    Traits can also define what “this” means
trait CreepyPerson extends Named {
  self : Person =>

    override def printName {
      println("Creepy! " + name +
              ", size = " + this._size)
    }
}

class A extends CreepyPerson {} // Error!
Scala Mixes In Traits

    Classes can have multiple traits mixed in,
    but can still only extend one superclass

    Disambiguation of method calls is done via
    a process called “Linearization”. Basically,
    right-to-left
trait Messageable { def msg (msg : String) }

trait Emailable extends Messageable {...}

trait SMSable extends Messageable {...}

class iPhone extends SMSable
  with Emailable {...}
Scala has Native XML
 
     XML literals are part of Scala's syntax
 
     Xpath-like expressions and pattern
     matching supported for extraction
val simpleFragment =
  <entries>
    <entry><name>Fred</name></entry>
    <entry><name>Barney</name></entry>
  </entries>

(simpleFragment  "name").toList.map(_.text)

simpleFragment.child.foreach({
   case <entry><name>{name}</name></entry> => println(name);
   case _ =>
})
Scala has Native XML, Part 2

    Values can be embedded in XML literals
    via braces.

    Interpretation of values is via toString,
    although scala.xml.{PCData,Unparsed} can
    do special handling
// <name>Fred&amp;Barney</name>
val embedFragment =
  <name>{ "Fred&Barney" }</name>

val noEscapes = // <name>Betty&Wilma</name>
  <name>{ Unparsed("Betty&Wilma") }</name>
Conclusion


    Scala lets you write less boilerplate and
    concentrate on the logic

    Interoperates very well with the existing
    Java ecosystem

    IDE support is still not where it needs to be,
    but it's functional

    Odersky, et. al, are committed to long-term
    growth and stability
Further Reading


    http://www.scala-lang.org/

    http://scala.sygneca.com/

    Books:
    
        Programming in Scala by Odersky, Venners &
        Spoon
    
        Beginning Scala by David Pollak
    
        Programming Scala by Wampler & Payne (online)
    
        Programming Scala by Venkat Subramaniam
    
        Steps in Scala by Loverdos & Syropolous
    
        The Definitive Guide to Lift (shameless plug)

Mais conteúdo relacionado

Mais procurados

Scala at HUJI PL Seminar 2008
Scala at HUJI PL Seminar 2008Scala at HUJI PL Seminar 2008
Scala at HUJI PL Seminar 2008
Yardena Meymann
 
scalaliftoff2009.pdf
scalaliftoff2009.pdfscalaliftoff2009.pdf
scalaliftoff2009.pdf
Hiroshi Ono
 
Procedure Typing for Scala
Procedure Typing for ScalaProcedure Typing for Scala
Procedure Typing for Scala
akuklev
 

Mais procurados (16)

All about scala
All about scalaAll about scala
All about scala
 
Scala Intro
Scala IntroScala Intro
Scala Intro
 
Scala introduction
Scala introductionScala introduction
Scala introduction
 
Scala at HUJI PL Seminar 2008
Scala at HUJI PL Seminar 2008Scala at HUJI PL Seminar 2008
Scala at HUJI PL Seminar 2008
 
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 @ TechMeetup Edinburgh
Scala @ TechMeetup EdinburghScala @ TechMeetup Edinburgh
Scala @ TechMeetup Edinburgh
 
scalaliftoff2009.pdf
scalaliftoff2009.pdfscalaliftoff2009.pdf
scalaliftoff2009.pdf
 
Scala on Android
Scala on AndroidScala on Android
Scala on Android
 
Scaladroids: Developing Android Apps with Scala
Scaladroids: Developing Android Apps with ScalaScaladroids: Developing Android Apps with Scala
Scaladroids: Developing Android Apps with Scala
 
camel-scala.pdf
camel-scala.pdfcamel-scala.pdf
camel-scala.pdf
 
An Introduction to Scala for Java Developers
An Introduction to Scala for Java DevelopersAn Introduction to Scala for Java Developers
An Introduction to Scala for Java Developers
 
Scala vs Java 8 in a Java 8 World
Scala vs Java 8 in a Java 8 WorldScala vs Java 8 in a Java 8 World
Scala vs Java 8 in a Java 8 World
 
1.2 scala basics
1.2 scala basics1.2 scala basics
1.2 scala basics
 
Procedure Typing for Scala
Procedure Typing for ScalaProcedure Typing for Scala
Procedure Typing for Scala
 
A Brief Intro to Scala
A Brief Intro to ScalaA Brief Intro to Scala
A Brief Intro to Scala
 
Scala test
Scala testScala test
Scala test
 

Semelhante a Stepping Up : A Brief Intro to Scala

Scala overview
Scala overviewScala overview
Scala overview
Steve Min
 
Intro to scala
Intro to scalaIntro to scala
Intro to scala
Joe Zulli
 
BCS SPA 2010 - An Introduction to Scala for Java Developers
BCS SPA 2010 - An Introduction to Scala for Java DevelopersBCS SPA 2010 - An Introduction to Scala for Java Developers
BCS SPA 2010 - An Introduction to Scala for Java Developers
Miles Sabin
 
Miles Sabin Introduction To Scala For Java Developers
Miles Sabin Introduction To Scala For Java DevelopersMiles Sabin Introduction To Scala For Java Developers
Miles Sabin Introduction To Scala For Java Developers
Skills Matter
 

Semelhante a Stepping Up : A Brief Intro to Scala (20)

Qcon2011 functions rockpresentation_scala
Qcon2011 functions rockpresentation_scalaQcon2011 functions rockpresentation_scala
Qcon2011 functions rockpresentation_scala
 
Scala in a nutshell by venkat
Scala in a nutshell by venkatScala in a nutshell by venkat
Scala in a nutshell by venkat
 
The Scala Programming Language
The Scala Programming LanguageThe Scala Programming Language
The Scala Programming Language
 
Scala Talk at FOSDEM 2009
Scala Talk at FOSDEM 2009Scala Talk at FOSDEM 2009
Scala Talk at FOSDEM 2009
 
Scala
ScalaScala
Scala
 
Oop2010 Scala Presentation Stal
Oop2010 Scala Presentation StalOop2010 Scala Presentation Stal
Oop2010 Scala Presentation Stal
 
Scala presentationjune112011
Scala presentationjune112011Scala presentationjune112011
Scala presentationjune112011
 
Scala intro for Java devs 20150324
Scala intro for Java devs 20150324Scala intro for Java devs 20150324
Scala intro for Java devs 20150324
 
Scala - core features
Scala - core featuresScala - core features
Scala - core features
 
Scala overview
Scala overviewScala overview
Scala overview
 
A Scala tutorial
A Scala tutorialA Scala tutorial
A Scala tutorial
 
Getting Started With Scala
Getting Started With ScalaGetting Started With Scala
Getting Started With Scala
 
Scala in Places API
Scala in Places APIScala in Places API
Scala in Places API
 
Intro to scala
Intro to scalaIntro to scala
Intro to scala
 
BCS SPA 2010 - An Introduction to Scala for Java Developers
BCS SPA 2010 - An Introduction to Scala for Java DevelopersBCS SPA 2010 - An Introduction to Scala for Java Developers
BCS SPA 2010 - An Introduction to Scala for Java Developers
 
A Brief, but Dense, Intro to Scala
A Brief, but Dense, Intro to ScalaA Brief, but Dense, Intro to Scala
A Brief, but Dense, Intro to Scala
 
Scala uma poderosa linguagem para a jvm
Scala   uma poderosa linguagem para a jvmScala   uma poderosa linguagem para a jvm
Scala uma poderosa linguagem para a jvm
 
A Brief Introduction to Scala for Java Developers
A Brief Introduction to Scala for Java DevelopersA Brief Introduction to Scala for Java Developers
A Brief Introduction to Scala for Java Developers
 
Miles Sabin Introduction To Scala For Java Developers
Miles Sabin Introduction To Scala For Java DevelopersMiles Sabin Introduction To Scala For Java Developers
Miles Sabin Introduction To Scala For Java Developers
 
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?
 

Último

Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
WSO2
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
?#DUbAI#??##{{(☎️+971_581248768%)**%*]'#abortion pills for sale in dubai@
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 

Último (20)

ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)
 
Exploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with MilvusExploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with Milvus
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWEREMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdfRising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptx
 
Mcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Mcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot ModelMcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot Model
Mcleodganj Call Girls 🥰 8617370543 Service Offer VIP Hot Model
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectors
 
Platformless Horizons for Digital Adaptability
Platformless Horizons for Digital AdaptabilityPlatformless Horizons for Digital Adaptability
Platformless Horizons for Digital Adaptability
 
DBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor PresentationDBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor Presentation
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of Terraform
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 

Stepping Up : A Brief Intro to Scala

  • 1. Stepping Up: A Brief Intro to Scala Derek Chen-Becker, October 10th, 2009
  • 2. A little background  Scala began around 2003, 2.0 in 2006, currently at 2.7.5 (stable)  Created by Martin Odersky (EPFL), of GJ, and later Javac v5 fame  Compiles to 100% Java Bytecode  Generally works flawlessly with Java  Leverages JIT: performance ±5% of Java  Excellent community (mailing lists, IRC)  In use at Twitter, Seimens, Xerox, and others
  • 3. Not quite déjà vu... Scala combines features from many different languages to form a unique hybrid:  Scala is pure OO. Everything is an object, even primitives  Scala has first-class function objects. Much of the library leverages function arguments  Scala has a comprehensive type system and a flexible inheritance mechanism  Method names have less restrictions. This allows for operator overloading and nice DSLs  Immutability is strongly supported and encouraged. This is important for multi-core
  • 4. Statics and Singletons  Scala makes a distinction between instance and static methods and fields by using a separate “object” entity to represent the latter  Objects are VM singletons  Objects can be used to create custom factories and pattern matching extractors (more in a moment)
  • 5. Scala is Succinct public class Bike { private String brand; private int gear; public Bike(String brand, class Bike (val brand : String, int gear) { var gear : Int) { this.brand = brand; override def toString = this.gear = gear; "This is a %s in gear %d" } .format(brand, gear) } public int getGear() { return gear; } public void setGear(int gear) { this.gear = gear; } public String getBrand() { return brand; } public String toString() { return String.format("This is a %s in gear %d", brand, gear); } }
  • 6. Scala has Case Classes  Case classes are defined basically like normal classes  By default are immutable (good!)  Constructor parameters are automatically vals  Automatically get a companion object with apply/unapply, as well as overrides for equals, hashCode and toString on the class itself case class Book(title : String, author : String) val classic = Book("A Tale of Two Cities", "Dickens") val Book(title,author) = classic
  • 7. Scala has Case Classes, part 2  Can inherit from other classes (although inheriting from other case classes is being deprecated)  Can have their own methods just like normal classes class Vehicle(val description : String, val topSpeed : Long) case class Airplane(description : String, topSpeed : Long, var fuel : Double) extends Vehicle(description,speed) { def takeOff {...} }
  • 8. Scala is Functional Functions in Scala are first-class objects, and can be passed as arguments, assigned to variables, etc. val printLog = { msg : String => // or ⇒ println(System.currentTimeMillis + ":" + msg) } List("one", "two", "three").foreach(printLog)
  • 9. Scala is Functional, Part 2 Functions (and Scala's type system) allow you to do things like define new control structures in a type-safe way: // Structural typing allows any type with a “close” method def using[A <: { def close() : Unit }, B] (resource : A ) (f : A => B) : B = try { f(resource) } finally { resource.close } val firstLine = using(new BufferedReader(new FileReader("/etc/hosts"))) { reader => reader.readLine }
  • 10. Scala has Closures Closures capture variables in the scope of their definition. These are ideal for callbacks, among other things. // Note that this example is not thread-safe def logAndAdd(name : String) = { var counter = 0 val logFunc = { msg : String => println(name + "-" + counter + ":" + msg) counter += 1 } logFunc }
  • 11. Scala is Higher Level In particular, collections support complex operations directly: case class User(name : String, age : Int) val people = List(User("Fred", 35), User("Barney", 32),...) val sorted = people.sort(_.age < _.age).take(5) // The same as : val sorted = people.sort({(a,b) => a.age < b.age}).take(5) val under30 = sorted.takeWhile(_.age < 30) val youngest5 = sorted.take(5) val oldest5 = sorted.takeRight(5).reverse
  • 12. Scala has For-Comprehensions For-comprehensions provide an elegant construct for tying multiple sources and criteria together to extract information: val prefixes = List("/tmp", "/work", System.getProperty("user.home")) val suffixes = List("txt", "xml", "html") def locateFiles(name : String) : List[String] = for (prefix <- prefixes; suffix <- suffixes; filename <- Some("%s/%s.%s".format(prefix, name, suffix)) if (new File(filename)).exists) yield filename
  • 13. Scala does Pattern Matching  Like the “switch” statement on steroids  Incredibly powerful for expressing conditional logic  Cases are tested in order def matchIt (in : Any) = in match { case 1 | 14 | "test" => {...} case x : Int => {...} case x : Double if x > 42.0 => {...} case Vehicle(description, _) => {...} case <head>{ stuff }</head> => {...} case _ => {...} }
  • 14. Scala does Custom Matching  My favorite Scala example (more in the handout) // Regexps in Scala define a custom unapply to match on groups val colonSplit = """(w+):(w+)""".r // It's easy to define your own as well object IntVal { def unapply(in : String) = try { Some(in.toInt) } catch { case _ => None } } def parts (in : String) = in match { // Matching allows nested use of extractors (here we want Ints) case colonSplit(IntVal(number), value) if number == 14 => {...} case colonSplit(IntVal(number), value) => {...} case colonSplit(key, value) => {...} case _ => {...} }
  • 15. Scala has Traits  At their most basic, traits are 1-to-1 with Java interfaces  Support concrete implementations of methods  Support both concrete and abstract implementations of vals and vars trait Named { val version = "1.0.0" val name : String def printName { println(name) } }
  • 16. Scala Enforces Trait Composition  Traits can restrict which classes and traits they can be mixed into  Traits can also define what “this” means trait CreepyPerson extends Named { self : Person => override def printName { println("Creepy! " + name + ", size = " + this._size) } } class A extends CreepyPerson {} // Error!
  • 17. Scala Mixes In Traits  Classes can have multiple traits mixed in, but can still only extend one superclass  Disambiguation of method calls is done via a process called “Linearization”. Basically, right-to-left trait Messageable { def msg (msg : String) } trait Emailable extends Messageable {...} trait SMSable extends Messageable {...} class iPhone extends SMSable with Emailable {...}
  • 18. Scala has Native XML  XML literals are part of Scala's syntax  Xpath-like expressions and pattern matching supported for extraction val simpleFragment = <entries> <entry><name>Fred</name></entry> <entry><name>Barney</name></entry> </entries> (simpleFragment "name").toList.map(_.text) simpleFragment.child.foreach({ case <entry><name>{name}</name></entry> => println(name); case _ => })
  • 19. Scala has Native XML, Part 2  Values can be embedded in XML literals via braces.  Interpretation of values is via toString, although scala.xml.{PCData,Unparsed} can do special handling // <name>Fred&amp;Barney</name> val embedFragment = <name>{ "Fred&Barney" }</name> val noEscapes = // <name>Betty&Wilma</name> <name>{ Unparsed("Betty&Wilma") }</name>
  • 20. Conclusion  Scala lets you write less boilerplate and concentrate on the logic  Interoperates very well with the existing Java ecosystem  IDE support is still not where it needs to be, but it's functional  Odersky, et. al, are committed to long-term growth and stability
  • 21. Further Reading  http://www.scala-lang.org/  http://scala.sygneca.com/  Books:  Programming in Scala by Odersky, Venners & Spoon  Beginning Scala by David Pollak  Programming Scala by Wampler & Payne (online)  Programming Scala by Venkat Subramaniam  Steps in Scala by Loverdos & Syropolous  The Definitive Guide to Lift (shameless plug)