zoukankan      html  css  js  c++  java
  • scala学习(idea编译过程https://blog.csdn.net/guiying712/article/details/68947747)

    scala官网

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

    菜鸟教程学习

    http://www.runoob.com/scala/scala-basic-syntax.html

    w3school

    https://www.w3cschool.cn/scala/85pl1jc9.html

    查看scala的返回值类型,可以使用  表达式.var  回车即可查看

     idea里设置scala语言的table跨格数

     

    当new类时,类中除了方法不执行其他都执行

    object相当于java中的单例,定义的都是静态

    class可以传参传参就有了默认的构造语句,this方法

    重写构造时,第一行要先调用默认的构造

    object不可以传参,apply方法

    伴生类好的伴生对象

    Scala里面如何使用break和continue

     

     

    格式化快捷键

    ctrl+shift+alt+L

    scala REPL

     

     

    可以直接在类加载里面写输出,而不需要放在方法里,而方法调用object里的属性,因为是类单例,可以直接调用

    apply方法相当于构造方法的重载

     

    注意点:
    l 建议类名首字母大写 ,方法首字母小写,类和方法命名建议符合驼峰命名法。
    l scala 中的object是单例对象,相当于java中的工具类,可以看成是定义静态的方法的类。object不可以传参数。另:Trait不可以传参数
    l scala中的class类默认可以传参数,默认的传参数就是默认的构造函数。
    重写构造函数的时候,必须要调用默认的构造函数。
    l class 类属性自带getter ,setter方法。
    l 使用object时,不用new,使用class时要new ,并且new的时候,class中除了方法不执行,其他都执行。
    l 如果在同一个文件中,object对象和class类的名称相同,则这个对象就是这个类的伴生对象,这个类就是这个对象的伴生类。可以互相访问私有变量。

     

    foreach操作

     

     冒号是代表返回值 =>代表指向=代表等同于

     

    _是占位符

    上述(1,2)(3,4)实质是前两者为函数本身的内容即a和b,后两者3,4是返回函数的的输入即v1和v2 而(Int,Int)=>Int的最后Int是返回函数的返回值

    下面的(a,b)=>{a+b}是给函数f赋予函数执行体

    上述的例子:即

    把f函数给构造出来,并在(a:Int,b:Int)=>{a*b} 的时候把f函数给构造成为两数相乘的函数传入

     柯理化函数http://www.runoob.com/scala/currying-functions.html

    菜鸟教程数组

     

     当字符串进行数组或者list,set等下面运算时,是加到后面,不是加到数组里面

    val arr1=arr.+("hello")

    此时hello是单独放在arr数组外面的后面,而不是数组里面后面

    记住,可变长,或者var

    var或者mutable其中一个存在,即是可变的

    x._1和x._2分别代表map的键和值,

    遍历keys的时候

    map.keys返回的map的iterable迭代器类型

    如果map或者list或者数组等里面有不同种类的数值时,类型为Any

    个人觉得是相反的,++是map2加入map1,而++:是map1加入map2

    因最后的例子输出结果是map1覆盖了map2即如图,因map覆盖特性,觉得例子中++:是map1加入map2

    count和filter例子输出结果为

    即count是把满足条件的个数输出,返回值为Int,filter是把满足条件的键值对输出

    返回布尔值,

    过滤查找值为200的并输出

    python中元组不可修改用()表示,列表可修改用[]表示,字典是用{}表示

    即必须tuple所带参数和tuple内参数个数相同,且不能超过22

    上面为元组嵌套,t._1._2意思为tuple2元组里的第一个内容元组的第二个值,即元组(1,2)的第二个值2

    下面增加

    输出

     更改重写的方法

    p3p4输出为

    因为先匹配到Int,所以后续的1,2,3,4不会看,因为3是浮点型,继续往下,所以是3

    因此我们若想要先输出1,2,3,4再判别,则可以将Int的判别放在后面

     

     

     

     

    之所以先启动1,是因为1是接受者,要先启动接受者,避免启动发送者,没有接受者报错

     

    用占位符替代,完成一行代码的,这种操作要记得

    基本语法

    Scala 基本语法需要注意以下几点:

      • 区分大小写 -  Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义。

      • 类名 - 对于所有的类名的第一个字母要大写。
        如果需要使用几个单词来构成一个类的名称,每个单词的第一个字母要大写。

        示例:class MyFirstScalaClass

      • 方法名称 - 所有的方法名称的第一个字母用小写。
        如果若干单词被用于构成方法的名称,则每个单词的第一个字母应大写。

        示例:def myMethodName()

      • 程序文件名 - 程序文件的名称应该与对象名称完全匹配(新版本不需要了,但建议保留这种习惯)。
        保存文件时,应该保存它使用的对象名称(记住Scala是区分大小写),并追加".scala"为文件扩展名。 (如果文件名和对象名称不匹配,程序将无法编译)。

        示例: 假设"HelloWorld"是对象的名称。那么该文件应保存为'HelloWorld.scala"

      • def main(args: Array[String]) - Scala程序从main()方法开始处理,这是每一个Scala程序的强制程序入口部分

    标识符

    Scala 可以使用两种形式的标志符,字符数字和符号。

    字符数字使用字母或是下划线开头,后面可以接字母或是数字,符号"$"在 Scala 中也看作为字母。然而以"$"开头的标识符为保留的 Scala 编译器产生的标志符使用,应用程序应该避免使用"$"开始的标识符,以免造成冲突。

    Scala 的命名规则采用和 Java 类似的 camel 命名规则,首字符小写,比如 toString。类名的首字符还是使用大写。此外也应该避免使用以下划线结尾的标志符以避免冲突。符号标志符包含一个或多个符号,如+,:,? 等,比如:

    + ++ ::: < ?> :->

    Scala 内部实现时会使用转义的标志符,比如:-> 使用 $colon$minus$greater 来表示这个符号。因此如果你需要在 Java 代码中访问:->方法,你需要使用 Scala 的内部名称 $colon$minus$greater。

    混合标志符由字符数字标志符后面跟着一个或多个符号组成,比如 unary_+ 为 Scala 对+方法的内部实现时的名称。字面量标志符为使用"定义的字符串,比如 `x` `yield`。

    你可以在"之间使用任何有效的 Scala 标志符,Scala 将它们解释为一个 Scala 标志符,一个典型的使用为 Thread 的 yield 方法, 在 Scala 中你不能使用 Thread.yield()是因为 yield 为 Scala 中的关键字, 你必须使用 Thread.`yield`()来使用这个方法。

    数据类型是因为在运行时占用内存,所以数据类型是可以分开,使得效率提高

    Anyvel          所有值类型的超类

     

    输出全部1到10

     

  • 相关阅读:
    美国航天局的十大编码戒律(转)
    大型数据库应用解决方案总结
    IOCP模型
    SSH 连接慢的解决方案详解
    指针(详解)【转】
    有关推挽输出、开漏输出、复用开漏输出、复用推挽输出以及上拉输入、下拉输入、浮空输入、模拟输入区别【转】
    USB入门开发的八个问题&USB枚举『转』
    浅谈 STM32 硬件I2C的使用 (中断方式 无DMA 无最高优先级)(转)
    KEIL Code RO-data RW-data ZI-data 【转】
    262K Color
  • 原文地址:https://www.cnblogs.com/pursue339/p/10570840.html
Copyright © 2011-2022 走看看