一个综合小例子, 要严格区分 函数与方法 , 与 java 不一样

/**
* Scala 的值类型有 7 种
* Byte
* Char
* Short
* Int
* Long
* Float
* Double
*/
import scala.collection.mutable.ArrayBuffer
object Demo {
def main(args: Array[String]):Unit = {
val res = add(f);
val sex = "男"
val gender = if("男".equals(sex)) 1 else 0
println(gender)
println(res)
f2(5)
f3(2,3)
println(arr1.toBuffer)
arr2 += 1;
// 追加元组
arr2 += (2,3,4)
// 追加定常数组
arr2 ++= Array(5,6,7)
// 追加变长数组
arr2 ++= ArrayBuffer(8,9,10)
// 在指定位置插入 n 个 元素, n>=1 *args
arr2.insert(0,-3,-2,-1)
// 在指定位置 2 开始移除两个元素
arr2.remove(2,2)
for(i <- 0 until arr2.length ){
println(arr2(i))
}
println("*"*100)
arr2.foreach(println)
println("*"*100)
val v_i = for(i <- (0 to arr2.length).reverse) yield i*10
println(v_i.sum)
map_1.getOrElse("python", -1)
} def add(f:(Int ,Int)=>Int):Int = {
f(3,4)
}
val f = (x:Int, y:Int) => x+y
val f2 = (n:Int) =>{
for (i <- 1 to n){
println(i)
}
}
val f3 = (n:Int, m:Int) =>{
for(i <- 1 to n; j <- 1 until m if i != j){
println(i*10+j)
}
}
val arr1 : Array[Int] = new Array[Int](8)
val arr3 = Array("java","scala","python")
val arr2 = ArrayBuffer[Int]() val map_1 = Map("java"->1,"scala"->2,"python"->3) val arr4 = Array(1,2,3)
arr3.zip(arr4) } // 延迟变量 object SharkTest{ def init():Unit={
println("call init()")
} def main(args: Array[String]) {
lazy val res = init()
for(arg <-args){
println(arg)
}
println("in main...")
println(res) }
} object SharkTest{ def main(args: Array[String]) {
val list1 = List(3,2,1,4,5,8,7,9,6)
val list2 = list1.map(_ * 2)
val list_3 = list1.filter(_ % 2 == 0)
val list_4 = list1.sorted
val list5 = list_4.reverse
val list_6 = list1.grouped(4)
// 将 Iterator转换为 List
val list_7 = list_6.toList
val list_8 = List(List(1,2,3), List(4,5,6), List(7,8,9))
// 将多个 list 压扁
val list_9 = list_8.flatten // 先 按照 空格 分割拆分后 再压平
val list_10 = List("java scala python array")
val list_11 = list_10.flatMap(_.split("\\s+"))
val list_12 = list_10.map(_.split("\\s+")).flatten // 并行计算求和
val arr = Array(1,2,3,4,5,6,7,8,9,10)
// parallel
val res = arr.par.sum
val res2 = arr.par.reduce((x,y) => x+y)
// 有初始值,无特定顺序 则 每次 值不一定 125 135 65
val res3 = arr.par.fold(10)(_+_) // 折叠 , 有初始值 (有特定值) 则 每次值 固定 65
val res4 = arr.par.foldLeft(10)(_+_) // 聚合
val list_13 = List(List(1,2,3), List(3,4,5), List(2), List(0))
val res5 = list_13.flatMap(x=>x).reduce(_+_)
// base = 0
val res6 = list_13.aggregate(0)((base,y)=>base+y.sum,(x,y)=>x+y)
println(res6)
// 求并集
val l1 = List(5,6,4,7)
val l2 = List(1,2,3,4)
val res7 = l1 union l2
// 求交集
val res8 = l1 intersect l2
// 求差集
val res9 = l1 diff l2 }
} ### word count 小例子 object SharkTest{ def main(args: Array[String]) { val lines = List("hello java hello python", "hello scala", "hello scala hello java hello scala")
val words = lines.flatMap(_.split("\\s+"))
val words_pair = words.map(x=>(x,1))
println(words_pair)
val mp = words_pair.groupBy(_._1)
val res = mp.mapValues(l=>l.length)
val res2 = res.toList.sortBy{case(k,v)=>v}
/*
* Map(scala -> 3, java -> 2, hello -> 6, python -> 1)
* */
//mp.reduce((key,value)=>value.length)
// val it = words.groupBy(e=>e)
println(res2.reverse) }
}

进入面向对象

/* 一个 源代码文件可以有多个 类与 多个 伴生对象 ,源文件的 名字也不用 与 class 保持一致,pulic 类修饰符 也不用,默认 public*/
class Person {
// 用 val 修饰的变量是只读的,相当于只有 get 方法, 没有 set 方法
val name : String = _
// 用 var 修饰的变量相当于既有 get 方法, 又有 set 方法
var race: String = _
// 用 private 修饰的 变量 属于私有变量 ,仅可在 本类与 伴生对象中 访问
private val id : Int = _
// private 并添加 [this] 限定后 ,这个 变量 就只能在 本类访问, 连伴生对象 都无法访问
private[this] val gender = _ } object Person{ def main(args: Array[String]): Unit ={
val person = new Person() } }

模式匹配

object Demo{
def main(args:Array[String]):Unit={
val arr = Array("zhoudongyu","zhengshuang","guanxiaotong","yangzi")
matchCase(arr)
}
def matchCase(arr:Array[String]):Unit={
val name = arr(2)
println("name: "+name)
name match{
case "zhoudongyu" => println("周冬雨")
case "zhengshuang" => println("郑爽")
case "guanxiaotong" => println("关晓彤")
case "yangzi" => println("杨紫")
case _ => println("unknown")
}
}
} private val func : PartialFunction[Int,String]= {
case 1 => "one"
case 2 => "two"
case 3 => "three"
case _ => "others"
}
private val func2: Int=>String = x => x match{
case 1 => "one"
case 2 => "two"
case 3 => "three"
case _ => "others"
}









柯里化

scala 自带的 隐式转换
在交互式窗口
:implicit -v // 自定义 隐式转换
package day04
class RichFile(file:String) {
def read():String={
Source.fromFile(file).mkString
} object MyFile {
implicit def richFile(file:String) = new RichFile(file)
} import day04.MyFile
val file:String=""
val content:String = MyFile.richFile(file).read()

这个隐式 好难理解

object ImplicitContext{
implicit object OrderingGirl extends Ordering[Girl]{
override def compare(x: Girl, y: Girl): Int = if(x.faceValue > y.faceValue) 1 else -1
}
} class Girl(val name:String, var faceValue:Int){} class Goddess[T: Ordering](val g1:T, val g2:T){
def choose()(implicit ord: Ordering[T]) = if (ord.gt(g1,g2)) g1 else g2
} object Goddess {
def main(args:Array[String]):Unit={
import ImplicitContext.OrderingGirl
val g1 = new Girl("大佬",90)
val g2 = new Girl("小佬",80)
val goddess = new Goddess(g1,g2)
print(goddess.choose().name+"--"+goddess.choose().faceValue)
}
}

附 学习资源

水滴产品团队

面向 Scala 的技术博客

https://scala.cool/

https://scala.cool/tags/从-Java-到-Scala/

https://scala.cool/tags/Scala-类型的类型/

Scala 课堂!

http://twitter.github.io/scala_school/zh_cn/

优秀个人博客

http://hongjiang.info/scala/

Effective Scala

http://twitter.github.io/effectivescala/index-cn.html

官网

https://docs.scala-lang.org/

api

https://docs.scala-lang.org/api/all.html

博学谷

scala 从头越的更多相关文章

  1. jdb调试scala代码的简单介绍

    在linux调试C/C++的代码需要通过gdb,调试java代码呢?那就需要用到jdb工具了.关于jdb的用法在网上大家都可以找到相应的文章,但是对scala进行调试的就比较少了.其实调试的大致流程都 ...

  2. scala练习题1 基础知识

    1, 在scala REPL中输入3. 然后按下tab键,有哪些方法可以被调用? 24个方法可以被调用, 8个基本类型: 基本的操作符, 等:     2,在scala REPL中,计算3的平方根,然 ...

  3. 牛顿法求平方根 scala

    你任说1个整数x,我任猜它的平方根为y,如果不对或精度不够准确,那我令y = (y+x/y)/2.如此循环反复下去,y就会无限逼近x的平方根.scala代码牛顿智商太高了println( sqr(10 ...

  4. Scala集合和Java集合对应转换关系

    作者:Syn良子 出处:http://www.cnblogs.com/cssdongl 转载请注明出处 用Scala编码的时候,经常会遇到scala集合和Java集合互相转换的case,特意mark一 ...

  5. Scala化规则引擎

    1. 引言 什么是规则引擎 一个业务规则包含一组条件和在此条件下执行的操作,它们表示业务规则应用程序的一段业务逻辑.业务规则通常应该由业务分析人员和策略管理者开发和修改,但有些复杂的业务规则也可以由技 ...

  6. Scala快速概览

    IDEA工具安装及scala基本操作 目录 一. 1. 2. 3. 4. 二. 1. 2. 3. 三. 1. 2. 3. 4. 5. 6. 7. 四. 1. (1) (2) (3) (4) (5) ( ...

  7. Scala Macros - scalamela 1.x,inline-meta annotations

    在上期讨论中我们介绍了Scala Macros,它可以说是工具库编程人员不可或缺的编程手段,可以实现编译器在编译源代码时对源代码进行的修改.扩展和替换,如此可以对用户屏蔽工具库复杂的内部细节,使他们可 ...

  8. Scala Macros - 元编程 Metaprogramming with Def Macros

    Scala Macros对scala函数库编程人员来说是一项不可或缺的编程工具,可以通过它来解决一些用普通编程或者类层次编程(type level programming)都无法解决的问题,这是因为S ...

  9. Scala Reflection - Mirrors,ClassTag,TypeTag and WeakTypeTag

    反射reflection是程序对自身的检查.验证甚至代码修改功能.反射可以通过它的Reify功能来实时自动构建生成静态的Scala实例如:类(class).方法(method).表达式(express ...

随机推荐

  1. 第八周课程总结 & 实验报告(六)

    第八周课程总结 一.包装类 介绍 装箱与拆箱 应用 二.异常 基本概念 基本格式 异常类的继承结构 throws关键字 throw关键字 Exception类和RuntimeException类 自定 ...

  2. 作业要求20191010-9 alpha week 1/2 Scrum立会报告+燃尽图 07

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2019fall/homework/8752 一.小组情况组长:贺敬文组员:彭思雨 王志文 位军营 杨萍队名:胜 ...

  3. Python遍历列表删除多个元素或者重复元素

    在遍历list的时候,删除符合条件的数据,结果不符合预期   num_list = [1, 2, 2, 2, 3] print(num_list) for item in num_list: if i ...

  4. leetcode-easy-listnode-141 Linked List Cycle

    mycode  98.22% # Definition for singly-linked list. # class ListNode(object): # def __init__(self, x ...

  5. 小程序的autocomplete

    1.别做单个组件的autocomplete了,很坑,牵扯的坑太多,最后碰到原生组件canvas会让人欲哭无泪 2.单个组件的路走不通,走新页面吧,点击input框,进入到下个页面,搜所后选择,点击完成 ...

  6. 《Java编程思想》读书笔记<一>

    第二章 一切皆对象 java是面向对象的语言. 1.我们怎么操作对象? 每种语言都有自己的操纵内存中元素的方式,java使用引用操作内存中元素(对象).引用可以独立存在,例如:String s:表示创 ...

  7. 在Tomcat中配置MySQL数据源

    打开context.xml文件,路劲为:apache-tomcat-7.0.61\conf,添加如下代码: <Resource auth="Container" driver ...

  8. Centos 7 安装tomcat并部署jar实录

    本文目的 纯属记录,以备后查. 1.安装JAVA JDK 安装jdk略. 配置JDK,打开/etc/profile文件,在最后添加如下代码: JAVA_HOME=/usr/java/jdk1..0_2 ...

  9. apache禁止php解析--安全

    #禁止解析php <Directory "/data/www/data/"> php_admin_flag engine off <filesmatch &quo ...

  10. delphi application 和 form 主窗体 都是窗口

    application     也是一个窗体,  和一般窗体不一样. 主窗体 是一个窗体. 然后这两个窗体,分别计算pid   获得结果竟然一样. 另外句柄是动态,全部都不一样.每一次都不一样.