//基本模式匹配
def matchTest(x: Int): String = x match {
case 1 => "one"
case 2 => "two"
case _ => "many"
}
matchTest(3) // many
matchTest(1) // one
//模式守卫(在模式后面加上if 条件)
def matchTest2(x: Int): String = x match {
case i if i==1 => "one"
case i if i>2 => "大于2"
case _ => "many"
}
matchTest2(3) // 大于2
matchTest2(1) // one
//仅匹配类型
def matchTest3(x: Any): String = x match {
case x:Int => "Int"
case x:String => "String"
case _ => "Any"
}
matchTest3(3.0) // Any
matchTest3(1) // Int
//样例类的模式匹配
def matchTest4(x: Student)= x match {
case Student(name,19) => println(name)
case Student("Tom",age) => println(age)
case Student(name,age) => println(name,age)
case _ => println("no matches")
}
matchTest4(Student("Jason",19))
matchTest4(Student("Tom",20))
matchTest4(Student("Jimmy",20))
object MatchDemo extends App {
def matchTest05(x:Student)=x match {
case Student(name,age) if age <20 => println("young")
case Student(name,age) if age >30 => println("old")
case _=>println("else")
}
matchTest05(Student("zhangsan",18))
matchTest05(Student("lisi",25))
matchTest05(Student("wangwu",35))
}
//定义一个普通类
class Student(n:String,a:Int) {
//定义一下成员变量
var name=n
var age=a
}
object Student{
def apply(n: String, a: Int): Student = new Student(n, a)
def unapply(arg: Student): Option[(String, Int)] = {
//实现提取器的逻辑代码
if (arg==null) None else Some(arg.name,arg.age)
}
}
//输出结果
young
else
old
//自定义偏函数
val inc = new PartialFunction[Any, Int] {
def apply(any: Any) = any.asInstanceOf[Int]+1
def isDefinedAt(any: Any) =
if (any.isInstanceOf[Int]) true else false
}
List(1,2,3,"four").collect(inc)
val pf:PartialFunction[Any, Int]={case x:Int=>x+1} //返回一个偏函数
List(1,2,3,"four").collect(pf) //输出List(2,3,4)
@注解名称(注解参数...)
object DeprecationDemo extends App{
@deprecated("deprecation message", "release # which deprecates method")
def hello = "hola"
@throws(classOf[Exception])
def test(){}
}
10.+(1)
——>10+1
case class Vec(val x: Double, val y: Double) {
def +(that: Vec) = new Vec(this.x + that.x, this.y + that.y)
def add(that: Vec) = new Vec(this.x + that.x, this.y + that.y)
}
val vector1 = Vec(1.0, 1.0)
val vector2 = Vec(2.0, 2.0)
val vector3 = vector1 + vector2 // 或者 vector1 add vector2
vector3.x // 3.0
vector3.y // 3.0
//String.matches
"!123".matches("[a-zA-Z0-9]{4}") //false
"34Az".matches("[a-zA-Z0-9]{4}") //true
//模式匹配,Regex实现了提取器
val ZipcodePattern = "([a-zA-Z][0-9][a-zA-Z] [0-9][a-zA-Z][0-9])".r
//使用“.r”方法可使任意字符串变成一个Regex实例
"L3R 6M2" match {
case ZipcodePattern(zc) => println("Valid zip-code: " + zc ) //zc为第1个分组结果,可以匹配多个分组
case zc => println("Invalid zip-code: " + zc )
}
import scala.util.matching.Regex
val numberPattern: Regex = "[0-9]".r
numberPattern.findFirstMatchIn("awesomepassword") match {
case Some(_) => println("Password OK") //匹配成功
case None => println("Password must contain a number") //未匹配
}
识别“name:Jason,age:19,……”中的键值对
import scala.util.matching.Regex
val studentPattern:Regex="([0-9a-zA-Z-#() ]+):([0-9a-zA-Z-#() ]+)".r
val input="name:Jason,age:19,weight:100"
for(patternMatch<-studentPattern.findAllMatchIn(input)){
println(s"key: ${patternMatch.group(1)} value: ${patternMatch.group(2)}")
}
//search
val nums = "[0-9]+".r.findAllIn("123 Main Street Suite 2012")
nums.next // -> 123
nums.next // -> 2012
//replace
"[0-9]+".r.replaceFirstIn("234 Main Street Suite 2034", "567") //234->567
"[0-9]+".r.replaceAllIn("234 Main Street Suite 2034", "567") //234、2034->567
val date = """(\d\d\d\d)-(\d\d)-(\d\d)""".r
"2014-05-23" match {
case date(year, month, day) => println(year,month,day)
}
"2014-05-23" match {
case date(year, _*) => println("The year of the date is " + year)
}
"2014-05-23" match {
case date(_*) => println("It is a date")
}
"INFO 2016-07-25 requestURL:awewaeqweqwe", "INFO 2016-07-25 requestURL:waewqeqwe", "INFO 2016-07-25 requestURL:qweqweqweqwfasdf"
import scala.io.Source
val filePath="D:\\study files\\Scala\\test\\1.txt"
val file: BufferedSource = Source.fromFile(filePath)
val regex = """(\w{4}) (\d{4}-\d{2}-\d{2}) [^:]*:(.*)""".r
for (s<- file.getLines()){
s match {
case regex(level,date,uri)=>println(s"日志级别:$level,日期:$date,uri:$uri")
case _=>println("无匹配")
}
}
object ImplictDemo {
//定义一个隐式类
implicit class Stringinprove(val s:String){
def increment=s.map(x=>(x+1).toChar)
}
}
object TestDemo11{
def main(args: Array[String]): Unit = {
import ImplictDemo._
println("test".increment)
}
}
//输出结果
uftu
object Stringutils {
implicit class StringImprovement(val s:String){//隐式类
def increment=s.map(x=>(x +1).toChar)
}
}
object Main extends App{
import Stringutils._
println("mobin".increment) //输出:npcjo
}
throw new 异常类型
try{
//todo
}catch{
case ex:异常类型=>{ //todo }
……
}finally{
//todo
}
try {
val f=new File("input.txt")
if(!f.canWrite)
throw new Exception("file can't write")
val file=Source.fromFile(f);
for(line<-file.getLines()) println(line)
} catch {
case ex: FileNotFoundException => {
println("Missing file exception")
}
case ex: IOException => {
println("IO Exception")
}
case ex: Exception => {
println(ex.getMessage)
}
} finally {
println("Exiting finally...")
}
def divide(x:Int): Either[String,Int] ={
if(x==0)
Left("除数不能为0")
else
Right(100/x)
}
def test(x:Int)=divide(x) match {
case Left(errMsg)=>println(errMsg)
case Right(result)=>println(result)
}
test(0)
test(1)
scala.util.control.Exception.allCatch.opt("42".toInt) // Some(42)
scala.util.control.Exception.allCatch.opt("42a".toInt) // None
scala.util.control.Exception.allCatch.toTry("42".toInt) // 42
scala.util.control.Exception.allCatch.toTry("42a".toInt) // Failure (e)
scala.util.control.Exception.allCatch.withTry("42".toInt) // Success(42)
scala.util.control.Exception.allCatch.withTry("42a".toInt) // Failure (e)
scala.util.control.Exception.allCatch.either("42".toInt) // Right(42)
scala.util.control.Exception.allCatch.either("42a".toInt) // Left(e)
scala.util.control.Exception.failAsValue(classOf[Exception])(-9999)("42a".toInt)
//定义结构类型
{
def sayHello(name:String):Unit
}
//结构类型作为函数参数
def f(a:{def sayHello():Unit}){a.sayHello}
//函数调用
f(new {def sayHello():Unit={println("hello")}})
trait X1
trait X2
//定义复合类型参数x
def test(x: X1 with X2) = {println("ok")}
//函数调用,实参为匿名对象
test(new X1 with X2)
object A extends X1 with X2
//实参为单例对象
test(A)
六、Scala集成java API
object JavaApiDemo extends App {
//定义一个日期格式
val dateFmt="yyyy-MM-dd"
def today():String={
val sdf = new SimpleDateFormat(dateFmt)
val date = new Date
sdf.format(date)
}
println(today())
val calendar:Calendar = Calendar.getInstance()
val sdf = new SimpleDateFormat(dateFmt)
calendar.roll(Calendar.WEEK_OF_MONTH,1)
private val str:String = sdf.format(calendar.getTime())
println(str)
}