scala

-------------------------

  java语言脚本化

  1.安装scala-2.12.1.msi

  2.进入到scala的命令行

  3.Tab键会有补全的功能

1.scala程序并不是一个解释器,实际上,你输入的内容会很快的被编译成字节码文件,然后这段字节码文件会提交给java虚拟机进行相关的运行。

2.声明值和变量:除了直接使用res0、res1等这些名称之外,也可以自己进行相关的定义。

  scala>val answer = 8*5+2

  通过val定义的值实际上是一个常量,不能改变他的内容

  scala>answer =0  //这个地方会报错

  如果要声明值是可变的量,可以用var

  var counter = 0

  counter = 1 ;  //这里定义了一个可以改变的var

  在必要的时候可以指定值的类型

  val greeting:String =null  //这个地方我们要注意,在Scala中变量或者函数的类型总是写在变量或者函数名称的后面

  val greeting:Any="hello"  //当我们在java和scala之间进行切换的时候,经常敲出String greeting,这个时候要手动修改称为greeting:String

  val xmax,ymax=100  //将xmax和ymax设为100

  var greeting,message:String=null  //greeting和message都是字符串,被初始化为null

3.常用的数据类型:

  Scala的7种数据类型:Byte,Char,Short,Int,Long,Float和Double这七种数据类型以及一个Boolean类型,但是与java不相同的是,这些类型都是类

  1.toString()  //将数字1转换成为字符串

  1.to(10)    //得到1到10之间的数字

  1.toString  等价于 1.toString() 等价于1 toString

  在Scala中不需要包装类型。在基本数据类型和包装类型之间的转换的工作是Scala编译器的工作。

  Scala用底层的java.lang.String类来表示字符串,但是它是通过StringOps类给字符串追加了很多的操作。

  "Hello".intersect("world")  //输出"lo",在这个方法中,java.lang.String对象被隐式的转换成了一个StringOps对象,接着StringOps类的intersect方法被应用

  同样的,Scala还提供了RichInt、RichDouble,RichChar等,他们分别提供了他们可怜的堂兄弟们-Int,Double,Char等所不具备的快捷方法。我们前面用到的to方法就是RichInt类中的方法。

  1.to(10) 中,Int值1首先转换成RichInt,然后再应用to方法。

  操作符重载_$

  scala>1 +2  等价于  scala>1.+(2)

  scala>1 to 10 <===>1.to(10)    //

   a+b 等价于a.+(b)

   1 tostring() 等价于 1.toString()

  即a 方法 b 可以简写为a.方法b

  1.to(10)可以写成 1 to 10

  Scala并不提供++和--操作符,如果需要的话我们可以使用+=1或者-=1

  Scala>var a =100

  a+=2    //得到a=2

  Scala>counter+=1  //将counter递增---->Scala没有++操作

  val x:BigInt = 1234567890

4.函数的调用和方法

 (1)Scala提供数学函数,在使用这些函数之前,需要导入相关的包import scala.math._

  sqrt(2)  //我们在导入包的时候,直接使用import scala.math._  在Scala中,_是通配符,类似于java中的*

  pow(2,4)  //得出16

  scala>min(1,2)  //注意:这里调用scala函数,需要先导入scala的包,scala>import scala.math._   这个地方下划线表示的是通配符  

 

Apply:当声明一个变量的时候,后面可以直接带一个小括号,括号里面可以传参或者也可以不传参

------------------------------------

  (1)eg : scala>"hello".apply(1)<===>等价于   "hello"(1)  //这两种表示方式得到的都是e,后面这种形式是前面的一种快捷方式,apply()方法是提取第几个元素

    //如:如果s是一个字符串,那么s(i)就是该字符串的第i个字符,而在java中经常这样写s.charAt(i)<===>s(i)

    eg:"hello".apply(4)<===>"hello"(4)

  (2)如果去看BigInt的伴生文档,就会看到让字符串或者数字转换为BigInt对象的apply方法。

    BigInt("1234567890")  语句等价于BigInt.apply("1234567890")    //这个地方也是通过apply方法来进行相关的定义

  (3)Array(1,4,9,16)    //最后返回一个数组,这就是伴生对象的apply方法,在Scala中很常见

scala学习笔记(1)的更多相关文章

  1. 基于.net的分布式系统限流组件 C# DataGridView绑定List对象时,利用BindingList来实现增删查改 .net中ThreadPool与Task的认识总结 C# 排序技术研究与对比 基于.net的通用内存缓存模型组件 Scala学习笔记:重要语法特性

    基于.net的分布式系统限流组件   在互联网应用中,流量洪峰是常有的事情.在应对流量洪峰时,通用的处理模式一般有排队.限流,这样可以非常直接有效的保护系统,防止系统被打爆.另外,通过限流技术手段,可 ...

  2. Scala学习笔记及与Java不同之处总结-从Java开发者角度

    Scala与Java具有很多相似之处,但又有很多不同.这里主要从一个Java开发者的角度,总结在使用Scala的过程中所面临的一些思维转变. 这里仅仅是总结了部分两种语言在开发过程中的不同,以后会陆续 ...

  3. Scala学习笔记之:tuple、array、Map

    [TOC] 本文<快学Scala>的笔记 tuple学习笔记 tuple的定义 对偶是元组(tuple)的最简单形态--元组是不同类型的值的聚集. 元组的值是通过将单个值包含在圆括号中构成 ...

  4. 机器学习(三)--- scala学习笔记

    Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...

  5. 【大数据】Scala学习笔记

    第 1 章 scala的概述1 1.1 学习sdala的原因 1 1.2 Scala语言诞生小故事 1 1.3 Scala 和 Java  以及 jvm 的关系分析图 2 1.4 Scala语言的特点 ...

  6. 原创:Scala学习笔记(不断更新)

    Scala是一种函数式语言和面向对象语言结合的新语言,本笔记中就零散记下学习scala的一些心得,主要侧重函数式编程方面. 1. 以递归为核心控制结构. 实现循环处理的方式有三种:goto,for/w ...

  7. scala 学习笔记(04) OOP(上)主从构造器/私有属性/伴生对象(单例静态类)/apply方法/嵌套类

    一.主从构造器 java中构造函数没有主.从之分,只有构造器重载,但在scala中,每个类都有一个主构造器,在定义class时,如果啥也没写,默认有一个xxx()的主构造器 class Person ...

  8. scala 学习笔记(03) 参数缺省值、不定个数参数、类的属性(Property)、泛型初步

    继续学习,这一篇主要是通过scala来吐槽java的,同样是jvm上的语言,差距咋就这么大呢? 作为一个有.NET开发经验的程序员,当初刚接触java时,相信很多人对java语言有以下不爽(只列了极小 ...

  9. scala学习笔记

    一 入门 为了增加编程趣味和技能,学习新语言,体会函数式编程和简易的并发管理模型,了解日渐活跃的Spark,尝试下Scala.Scala = Scalable language,作者是Martin O ...

  10. Scala学习笔记1(安装)

    到 官网下载scala tar包  http://www.scala-lang.org/download/ mac Finder里双击解压. 改名成scala 进命令行, mv ~/Downloads ...

随机推荐

  1. python学习之路(4)

    使用list和tuple Python内置的一种数据类型是列表:list.list是一种有序的集合,可以随时添加和删除其中的元素. 比如,列出班里所有同学的名字,就可以用一个list表示: >& ...

  2. python学习之路(20)

    装饰器 由于函数也是一个对象,而且函数对象可以被赋值给变量,所以,通过变量也能调用该函数. >>> def now(): print('2019.0519') >>> ...

  3. XML文件报错dubbo:XX解决方法

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  4. UVa 699 The Falling Leaves(递归建树)

    UVa 699 The Falling Leaves(递归建树) 假设一棵二叉树也会落叶  而且叶子只会垂直下落   每个节点保存的值为那个节点上的叶子数   求所有叶子全部下落后   地面从左到右每 ...

  5. Lognormal Distribution对数正态分布

    python机器学习-乳腺癌细胞挖掘(博主亲自录制视频) https://study.163.com/course/introduction.htm?courseId=1005269003&u ...

  6. weka数据导入

    每一行代表一条数据,用逗号分开属性,最后一列为分类标签 将后缀名改为csv,用excel打开,为每一列加上属性名称,直接导入weka即可

  7. 职位-IT:软件设计师

    ylbtech-职位-IT:软件设计师 软件设计师是指能根据软件开发项目管理和软件工程的要求,按照系统总体设计规格说明书进行软件设计,编写程序设计规格说明书等相应的文档的实用性人才.还能够组织和指导程 ...

  8. demo-website配置记录

    demo-website环境配置, 主要是下载flask相关的模块: 1. python安装的是2.7版本. 2. pip install flask pip install flask-httpau ...

  9. [Cinder] 存储 Qos

    目录 文章目录 目录 前言 操作步骤 参考文章 前言 Cinder 支持 front-end 和 back-end 两种类型的存储 QoS,前者由 Hypervisor 端实现(e.g. 通过 Lib ...

  10. 戴尔服务器IDRAC命令配置IP地址

    在工作中我们可能会遇到,在配置管理卡的时候,由于疏忽,把网关配置错误(但是你肯定的是IP没有错),导致不能正常连接管理卡,这是有两个办法,第一:你去机房,进行查看进行修改,第二:你登陆交换机,从交换机 ...