云社区 博客 博客详情
云社区 博客 博客详情

scala学习笔记(一)

竹叶青 发表于 2020-02-17 18:00:21 02-17 18:00
竹叶青 发表于 2020-02-17 18:00:21 2020/02/17
0
0

【摘要】 最近刚碰到个好机会去用scala,所以从本章开始记录scala的学习笔记,更多是实验就形式来表述和记录。如需转载请附带文章地址1、scala入门准备工作学习环境我是这样搭建的首先选择ubuntu linux 14.04然后安装docker 安装docker教程点这里安装好后docker后,下载scala环境镜像sudo docker pull index.alauda.cn/ttch/sca...

最近刚碰到个好机会去用scala所以从本章开始记录scala的学习笔记更多是实验就形式来表述和记录。如需转载请附带文章地址

1、scala入门准备工作

学习环境我是这样搭建的

首先选择ubuntu linux 14.04

然后安装docker 安装docker教程点这里

安装好后docker后下载scala环境镜像

sudo docker pull index.alauda.cn/ttch/scala

下载好后然后执行如下命令

sudo docker run --rm    \
    -v 本地目录:/scala \    -it index.alauda.cn/ttch/scala bash

可以看到进入了一个bash console下。然后尝试执行scala。这样就进入了控制台程序中。

2、scala学习之旅

scala文法结构参考如下地址点击

阅读了不少scala的书籍和文章几乎没有一个系统结构性讲解scala的。所以这也是写本系列文章的目的

下面简单按照几个结构进行整理和学习

  • scala语法结构

  • 函数式

  • 算子

  • 组合算子

争取能梳理一个系统的文章路径提供快速学习scala本身scala这个语言的学习曲线也十分陡峭)

2.1、 scala语法结构

下面我们从文法角度去逐个使用例子看scala的使用方式和方法。

2.1.1关键词

abstract    case        catch       class       defdo          else        extends     false       finalfinally     for         forSome     if          implicitimport      lazy        macro       match       newnull        object      override    package     privateprotected   return      sealed      super       thisthrow       trait       try         true        typeval         var         while       with        yield_    :    =    =>    <-    <:    <%     >:    #    @

以上是的关键词组成

2.1.2 变量和常量声明的文法结构

那么下面先通过scala的交互命令行来进行基本的实验和讲解。

首先先来实验基本的定义声明那么看看她的文法是什么样的

 Dcl               ::=  ‘val’ ValDcl
                      |  ‘var’ VarDcl
                      |  ‘def’ FunDcl
                      |  ‘type’ {nl} TypeDcl

定义声明分成4部分。

那么首先看下完成val定义文法


方法1

plainid  ::=  upper idrest
            |  varid
            |  op
id       ::=  plainid
            |  ‘`’ stringLiteral ‘`’
ValDcl   ::=  ids ‘:’ Typeids      ::=  id {‘,’ id}

方法2

PatVarDef         ::=  ‘val’ PatDef
                   |  ‘var’ VarDef
PatDef            ::=  Pattern2 {‘,’ Pattern2} [‘:’ Type] ‘=’ Expr

Pattern2          ::=  varid [‘@’ Pattern3]
                  |  Pattern3Pattern3          ::=  SimplePattern
                  |  SimplePattern { id [nl] SimplePattern }
SimplePattern     ::=  ‘_’
                    |  varid
                    |  Literal
                    |  StableId
                    |  StableId ‘(’ [Patterns ‘)’
                    |  StableId ‘(’ [Patterns ‘,’] [varid ‘@’] ‘_’ ‘*’ ‘)’
                    |  ‘(’ [Patterns] ‘)’
                    |  XmlPattern

两种定义常量的方法可以看出一个是需要提供类型

val valname : type = ...

另一种是直接定义常量通过推导的方式得到常量的类型和初始化值。

val valname = ...

假设()为可以存在或者不存在按照语言的结构可以按照这样的理解

val valname (: type) = 推导公式

下面列举一些patVarDef中 val的定义方式有以下几种

1.1

val (abc, bcd) = ("123","123")

结果为

abc: String = 123bcd: String = 123

1.2

val abc = (2,3)

结果为

x: (Int, Int) = (2,3)

1.3

val array@Array(_,test) = Array("hello","hello")

结果为

array: Array[String] = Array(hello, hello)test: String = hello

那么在上面的文法中可以看到可以跟指定 Type

val array@Array(test1:Any,test:String) = Array("hello","hello")

结果为

array: Array[String] = Array(hello, hello)
test1: Any = hellotest: String = hello

1.4

val array@_,array2@_ =( Array("hello","hello"),Array("test","test"))

上面是一个多常量初始化赋值的文法结果如下

array: (Array[String], Array[String]) = (Array(hello, hello),Array(test, test))
array2: (Array[String], Array[String]) = (Array(hello, hello),Array(test, test))

那么左边加上括号是有上面区别呢

 val (array@_,array2@_) =( Array("hello","hello"),Array("test","test"))

结果如下

array: Array[String] = Array(hello, hello)
array2: Array[String] = Array(test, test)

2.1.3 StableId

如果需要了解更多可以点击官方参考 那么上面文法多次提到了StableId,stableId的文法是有如下构成的。

 StableId          ::=  id
                  |  Path ‘.’ id
 id               ::=  plainid
             |  ‘`’ stringLiteral ‘`’
 plainid          ::=  upper idrest
             |  varid
             |  op
varid            ::=  lower idrest
upper            ::=  ‘A’ | … | ‘Z’ | ‘$’ | ‘_’  // and Unicode category Lulower            ::=  ‘a’ | … | ‘z’ // and Unicode category Llidrest           ::=  {letter | digit} [‘_’ op]

那么根据官方参考来看看如下模式如何使用

如下有3种模式

SimplePattern     ::=  StableId
                    |  StableId ‘(’ [Patterns ‘)’
                    |  StableId ‘(’ [Patterns ‘,’] [varid ‘@’] ‘_’ ‘*’ ‘)’

根据上面文法树分支可以得到4种模式

  • Stable Identifier Patterns

    SimplePattern   ::=  StableId
  • Constructor Patterns

    SimplePattern   ::=   ‘(’ [Patterns ‘)’
  • Extractor Patterns

    SimplePattern   ::=   ‘(’ [Patterns ‘)’
  • Pattern Sequences

    SimplePattern ::= StableId ‘(’ [Patterns ‘,’] [varid ‘@’] ‘_’ ‘*’ ‘)’

下面一个个分析其中模式和代码方式这里只从val和var的角度去看待其他模式下的使用方式暂时不作实验记录。

2.1.4 Stable Identifier Patterns

假设有这样一个需求需要声明一个常量a常量A初始化为C现在需要确定C变量是否和B变量值匹配如果不一样则报错。

那么可以这样写 val B , C = "hello"

结果如下

B: String = hello
C: String = hello

赋值代码如下

val a@B = C

结果如下

 a: String = hello

2.1.5 Constructor Patterns

例子1

val a@("hello",1) = ("hello",1)

结果如下

a: (String, Int) = (hello,1)

例子2

val a@("hello","string") = ("hello",1)

结果如下

<console>:8: error: type mismatch;
found   : String("string")
required: Int
   val a@("hello","string") = ("hello",1)
                  ^

从上面可以看出构建常量的匹配初始化校验方式。

2.1.6 Extractor Patterns

官方例子:

val x = (1, 2)val y = x match {  case Pair(i, s) => Pair(s + i, i * i)}

2.1.7 Pattern Sequences

val a@Seq('h','e','l',test @ _*) = Seq('h','e','l','l','o')a: Seq[Char] = List(h, e, l, l, o)test: Seq[Char] = List(l, o)

今天实验就到这了。

本文转载自异步社区

原文链接

https://www.epubit.com/articleDetails?id=NC7E3EF907B200001EFA49F0067AD17C0


登录后可下载附件,请登录或者注册

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件至:huaweicloud.bbs@huawei.com进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容。
评论文章 //点赞 收藏 0
点赞
分享文章到微博
分享文章到朋友圈

评论 (0)


0/1000
评论

登录后可评论,请 登录注册

评论

您还没有写博客的权限!

温馨提示

您确认删除评论吗?

确定
取消
温馨提示

您确认删除评论吗?

删除操作无法恢复,请谨慎操作。

确定
取消
温馨提示

您确认删除博客吗?

确定
取消

确认删除

您确认删除博客吗?

确认删除

您确认删除评论吗?

温馨提示

登录超时或用户已下线,请重新登录!!!

确定
取消