zoukankan      html  css  js  c++  java
  • scala学习笔记(1)

    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中很常见

  • 相关阅读:
    触屏版轻量级分页插件jqPagination分享
    30行js让你的rem弹性布局适配所有分辨率(含竖屏适配)
    js适配根字体大小
    返回顶部
    44 | 套路篇:网络性能优化的几个思路(下)
    43 | 套路篇:网络性能优化的几个思路(上)
    42 | 案例篇:如何优化 NAT 性能?(下)
    41 | 案例篇:如何优化 NAT 性能?(上)
    40 | 案例篇:网络请求延迟变大了,我该怎么办?
    python排列组合之itertools模块
  • 原文地址:https://www.cnblogs.com/bigdata-stone/p/9625392.html
Copyright © 2011-2022 走看看