1.      
Scala is functional language. Functions in Scala
are similar to objects in Java.
2.      
Idiom of Scala is less use of For loop, instead
operations are supplied as collections, and those operations are carried out
using methods of those collections
3.      
Scala encourages immutable data.
4.      
Immutable data items can be declared using
prefix “val”, similarly mutable data items can be declared using prefix “var”
5.      
Expressions are units of code that return a
value. Statements are units of code that do not return a value. Expressions can
be chained but statements cannot be chained.
6.      
Scala favors expression over statements
7.      
Any that evaluates to a value is an expression
for example string “Hello Word” is an expressions similarly list object like
List(“1”,”2”,”a”,”b”) is an expression
8.      
When you assign a expression it become
statements for example “val t_list = List(“1”,”2”,”a”,”b”)” is a statement does
not evaluate to a value. Similarly, statements like printing to screen, writing
to file are statements
9.      
Expressions can be passed into functions
10.  
Multiple expressions can be enclosed into {},
this is called expression block. Last expression in the block serves as return
value. Expression blocks can be nested. Expression blocks are nothing but
anonymous functions, can have both statements and expressions within block.
11.  
If/else, for loop, pattern matching like case or
switch are expressions in scala.. these are statements in Java. That is these
can be chained in Scala
12.  
Functions can be passed in as parameter to other
functions and also functions can return functions. Functions can be stored in a
variable or a value.
13.  
Type inference in scala is done using 3 classes
Any, AnyVal, AnyRef. Any is a type that is used for expressions combinations of
value type like Int, Double, Char, Boolean 
and reference types like Lists
14.  
Variables can be used in string interpolation
like s”$var1+$var2 is $va3 . i.e. var3 is addition of var1 and var2”
15.  
If/else blocks can be used just like other
languages
16.  
For loop can be written as statements or
expressions. If for loops are written like other languages then it’s a
statement but if we prefix for block with “yield” keyword then it will become
expression and result a List reference type
17.  
 While
loops can not be written as expressions in Scala
18.  
Pattern matching is similar to SWITCH/CASE but
there is no fall through i.e. only one case will be match therefore break
statement not required
a.      
Val dayofweek = “Sat”
b.      
Val matchday = dayofweek match {
c.      
                                                         Case
“Sat” => “Saturday”
d.      
                                                          Case
“sun” => “notstatuday”
e.      
                                                         }
19.  
Functions vrs methods
a.      
Functions are objects and expression blocks that
can be parameterized
b.      
Methods on other hand not objects but can be
parameterized
c.      
Methods must be associated with class but
functions can be independent
d.      
Method example
                                                              
i.     
def getArea(radius:Double):Double =
                                                            
ii.     
{
                                                          
iii.     
    val PI
= 3.4
                                                          
iv.     
    PI *
radius * radius
                                                            
v.     
}
                                                          
vi.     
This above method takes input “radius” or type
Double and returns Double
e.      
Functions Example
                                                              
i.     
val getArea = (radius:Double) =>
                                                            
ii.     
{
                                                          
iii.     
   val PI
=3.4
                                                          
iv.     
   PI *
radius * raidus
                                                            
v.     
} :Double
                                                          
vi.     
This above function takes input “radius” or type
Double and returns Double
f.       
We can convert method to function as below
                                                              
i.     
val getvalFunc: (Double) => Double  = getArea
                                                            
ii.     
or val getvalFunc = getArea (_) 
                                                          
iii.     
_ is a place hold indicating take same type input
and return same type as of method.. but place holder does not work for closure
where method returns function type but explicit conversion works on closures
also
20.  
First Order Functions or higher order functions
a.      
A function can be stored in a variable or a
value
b.      
The return value of a function can be a function
c.      
A parameter of a function can be a function
21.  
Closures
a.      
Closures retain the scope of inner function
variable even after outer function execution is completed
22.  
Collections
a.      
Tuples
                                                              
i.     
Not iterables in Scala.. these are orders
collection of items 
b.      
Lists
                                                              
i.     
val listval = List(“a”,”A”,”ac”)
                                                            
ii.     
val listval = “a” :: “A” :: “ac” :: Nil
c.      
Maps
                                                              
i.     
Key value pairs.. defined using “A”=>”va”
syntax..
                                                            
ii.     
These are List of Tuples
d.      
Options
                                                              
i.     
Used for error handling
                                                            
ii.     
Option with combination of “None” can be used to
return None when return type can be returned from function.. example division
by zero can return None as it can not return Int or Double 
e.      
Arrays
                                                              
i.     
val arranmae = Array(“a”,”A”,”ac”)
                                                            
ii.     
same as List but items (not length) are mutable
23.  
Higher order methods
a.      
MAP, FOREACH, FILTER
                                                              
i.     
Act on one element at a time
b.      
SCAN , FOLD, REDUCE
                                                              
i.     
Act on multiple items at a time
 
No comments:
Post a Comment