Update 1: Porting code examples to Scala 2.10.1 - support for String Interpolation.
Continue with the Basics by Example; today's version of the post written in Scala Enjoy!
I was thinking in changing the name of this post to "Scala - OO Basics by Example" because I guess its confusing the fact that Scala is more a Functional Programming language than an Imperative one, even if both paradigms are well supported by the language. At the end I decided to leave it like that, I just want to make clear that you will not find any "Functional Basics" on this post ;) ... As I did with my previous F# post.
You can copy and paste the code below in your favorite IDE/Editor and start playing and learning with it. This little "working" program will teach you the basics of the Programming Language.
There are some "comments" on the code added just to tell you what are or how are some features called. In case you want to review the theory, you can read my previous post, where I give a definition of each of the concepts mentioned on the code. You can find it here: http://carlosqt.blogspot.com/2010/08/new-series-languages-basics-by-example.html
Greetings Program - Verbose
// Scala Basics
package com.series
import scala._
import java.util.Calendar
// Constructor
// Fields or Attributes
class Greet(private var _message:String = "",
private var _name:String = "",
private var _loopMessage:Int = 0) {
//Properties
def Message = _message
def Message_= (value:String):Unit = _message = Capitalize(value)
def Name = _name
def Name_= (value:String):Unit = _name = Capitalize(value)
def LoopMessage = _loopMessage
def LoopMessage_= (value:Int):Unit = _loopMessage = value
// Overloaded Constructor
def this() = { this("","",0) }
// Method 1
private def Capitalize(value:String):String = {
if (value.length >= 1)
value.capitalize
else
""
}
// Method 2
def Salute() = {
// "for" statement
for (i <- 1 to _loopMessage) {
println(s"${_message} ${_name}!")
}
}
// Overloaded Method 2.1
def Salute(message:String, name:String, loopMessage:Int) = {
// "while" statement
var i:Int = 0
while (i < loopMessage) {
println(s"${Capitalize(message)} ${Capitalize(name)}!")
i += 1
}
}
// Overloaded Method 2.2
def Salute(name:String) = {
// "switch/case" statement is not supported
// using match statement instead
val dtNow:Calendar = Calendar.getInstance()
val t:Int = dtNow.get(Calendar.HOUR_OF_DAY)
t match {
case 6|7|8|9|10|11 => _message = "good morning,"
case 12|13|14|15|16|17 => _message = "good afternoon,"
case 18|19|20|21|22 => _message = "good evening,"
case 23|0|1|2|3|4|5 => _message = "good night,"
case _ => _message = "huh?"
}
println(s"${Capitalize(_message)} ${Capitalize(name)}!")
}
}
// Console Program
object Program {
def main(args: Array[String]): Unit = {
// Define object of type Greet and Instantiate Greet. Call Constructor
val g:Greet = new Greet
// Call Set Properties
g.Message = "hello"
g.Name = "world"
g.LoopMessage = 5
// Call Method 2
g.Salute()
// Call Overloaded Method 2.1 and Get Properties
g.Salute(g.Message, "scala", g.LoopMessage)
// Call Overloaded Method 2.2
g.Salute("carlos")
}
}
Greetings Program - Minimal
import java.util.Calendar
// Constructor
// Fields or Attributes
class Greet(private var _message:String = "",
private var _name:String = "",
private var _loopMessage:Int = 0) {
//Properties
def Message = _message
def Message_= (value:String):Unit = _message = Capitalize(value)
def Name = _name
def Name_= (value:String):Unit = _name = Capitalize(value)
def LoopMessage = _loopMessage
def LoopMessage_= (value:Int):Unit = _loopMessage = value
// Overloaded Constructor
def this() = this("","",0)
// Method 1
private def Capitalize(value:String) = {
if (value.length >= 1)
value.capitalize
else
""
}
// Method 2
def Salute() = {
// "for" statement
for (i <- 1 to _loopMessage) {
println(s"${_message} ${_name}!")
}
}
// Overloaded Method 2.1
def Salute(message:String, name:String, loopMessage:Int) = {
// "while" statement
var i = 0
while (i < loopMessage) {
println(s"${Capitalize(message)} ${Capitalize(name)}!")
i += 1
}
}
// Overloaded Method 2.2
def Salute(name:String) = {
// "switch/case" statement is not supported
// using match statement instead
val dtNow = Calendar.getInstance
val t = dtNow.get(Calendar.HOUR_OF_DAY)
t match {
case 6|7|8|9|10|11 => _message = "good morning,"
case 12|13|14|15|16|17 => _message = "good afternoon,"
case 18|19|20|21|22 => _message = "good evening,"
case 23|0|1|2|3|4|5 => _message = "good night,"
case _ => _message = "huh?"
}
println(s"${Capitalize(_message)} ${Capitalize(name)}!")
}
}
// Console Program
object Program {
def main(args: Array[String]) = {
// Define object of type Greet and Instantiate Greet. Call Constructor
val g = new Greet
// Call Set Properties
g.Message = "hello"
g.Name = "world"
g.LoopMessage = 5
// Call Method 2
g.Salute()
// Call Overloaded Method 2.1 and Get Properties
g.Salute(g.Message, "scala", g.LoopMessage)
// Call Overloaded Method 2.2
g.Salute("carlos")
}
}
And the Output is:

No comments:
Post a Comment