变量定义

scala定义两种变量:

  • var 可变 初始化之后,可以多次被重新赋值
  • val 不可变 一旦被初始化 就不能再赋值。
  1. var firstarg :java.lang.String = "Hello World"
  2. val secondarg :java.lang.String = "Hello dear"

但是由于有简化名的存在可以如下写法

  1. var firstarg :String = "Hello World"

因为 scala 具有类型推断的能力,因此还可以如下写:

  1. var firstarg = "Hello World"

打印输出:

  1. println("Hello World") // 该方法 会自动换行
  2. print("Hello World") // 该方法 不会 自动换行
  3. print(firstarg)
函数定义
  1. def fun(x: Int, y: Int):Int = {
  2. return x + y // 其实这么写是不好的,为什么不好,以后再说
  3. }
  4. /*
  5. def 开始函数的定义
  6. fun 函数名
  7. x:Int 参数,必须要指定类型,默认所有的参数都是 val 也就是 不可变的。
  8. fun(*):Int 函数返回的值的类型 返回类型可以省略,scala可以推断,但是在递归函数例外,必须指定
  9. = 连接函数名和函数体,必须要有,如果没有就是另外一种结果了。
  10. {*} 花括号 包含函数体 如果函数体只包含一条语句,那么{}可以不写
  11. 另外:scala 采用 /*ssss*/ // ssss 两种注释方式
  12. */

综合上面两个省略,函数也可以写成如下:

  1. def fun(x:Int, y:Int) = x + y

函数一旦定义号,就可以通过函数用调用了

  1. fun(1,2)
数组 (Array)

scala 使用 new 方法实例化对象(也叫类实例) ,在实例类的过程中,可以传入值和类型使实例参数化

参数化 指:创建实例的同时完成对它的设置。

  • 使用值 参数化实例,可以把值传给构造器的 括号来实现。
  • 使用类型 参数化实例, 可以把一个或多个类型指定到基础类型后的 括号来实现
  1. val big = new java.math.BigInteger("12345")
  2. val gre = new Array[String](3) //实例化了一个字符串数组,其初始长度为 3
  3. gre(0) = "hello"
  4. gre(1) = "xiao"
  5. gre(2) = "ming"
  6. gre.foreach(println) //查看 gre 的三个元素
  7. val gree: Array[String] = new Array[String](2) //这么写当然也是可以的
  8. //以上二者都不是初始化数组的推荐方式

访问数组内的元素

  1. print(gre(0)) // "hello"

val 说明 gre 是不可变的,但是 gre 内部的元素是 可变的。

  1. gre(0) = "welcom"
  2. print(gre(0)) // "welcom"
  3. gre = Array[String](5) // 会报错 因为它是 val 类型的。

scala 没有传统意义上的操作符,也就没有操作符重载。因为 + - * / 这样的字符,是方法名。

我们1 + 2 实际上是调用了 1+ 方法,然后把2 作为参数传给 + 方法。详细些如下:

  1. 1 + 2 // 我们这样写
  2. 1.+(2) //实际上是如此

也可以解释为什么scala 方位数组内元素用 小括号 而不是 方括号

  1. gre(0) // 我们这样写
  2. gre.apply(0) // 实际上是如此 调用了 apply 方法
  3. gre(0) = "nihao" //我们这样写
  4. gre.update(0,"nihao") // 实际上是这样 调用了update 方法

scala 有这样一个原则

任何对于对象的值参数应用将都被转化为对 apply 方法的调用

更简洁的初始化数组方法:

  1. val numArr = Array("one","two","three")
  2. //该方法创造并返回了新数组的 apply 方法

方法没有副作用是函数式编程的重要理念,计算并返回值应该是方法的唯一目的

所谓 副作用 我的理解是在函数运行中与返回值无关的,只是为了达到某些目的而进行的一些运算。如:

  1. def fun(x:Int):Unit ={ //Unit 表示不返回任何值。
  2. x+1 // 这个函数我们不需要返回任何值,只是为了达到将x 加 1的目的,其实把这个方法放到类里面举例更好,这是副作用
  3. print(x) // 这也是副作用
  4. }
列表

数组和列表都是同类对象序列。不同的是:数组是可变的。而列表可变

对列表的修改,其实是生成了一个新的列表

  1. val a = Array("hello","ni","hao")
  2. val b = List("hello","ni","hao")
  3. a(0) = "welcom" // print(a(0)) 为 “welcom”
  4. b(0) = "welcom" //会报错
  5. b = List("haha") //这样也不可以

scala-学习 1的更多相关文章

  1. Scala学习资源

    Scala学习资源: Scala官方网站:http://www.scala-lang.org/ Scala github:https://github.com/scala/scala Twitter ...

  2. 【Todo】【读书笔记】大数据Spark企业级实战版 & Scala学习

    下了这本<大数据Spark企业级实战版>, 另外还有一本<Spark大数据处理:技术.应用与性能优化(全)> 先看前一篇. 根据书里的前言里面,对于阅读顺序的建议.先看最后的S ...

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

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

  4. 【Scala】Scala学习资料

    Scala学习资料 java 树形 分类器_百度搜索 决策树分类器-Java实现 - CSDN博客 KNN分类器-Java实现 - CSDN博客 学习:java设计模式—分类 - 飞翔荷兰人 - 博客 ...

  5. Scala学习网址

    scala学习网址为:https://twitter.github.io/scala_school/zh_cn https://www.zhihu.com/question/26707124

  6. Spark之Scala学习

    1. Scala集合学习: http://blog.csdn.net/lyrebing/article/details/20362227 2. scala实现kmeans算法 http://www.t ...

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

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

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

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

  9. Scala学习(一)

    最近在学习Scala,总结了一下比较基础的知识. 一.Scala简介 1.Scalable Language,是一门多范式的编程语言,是一种纯面向对象的语言,每个值都是对象. 2.特点:①Scalab ...

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

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

随机推荐

  1. 共享设置及ftp设置

    第一部分 共享设置 一.添加编译选项 network---file transfer---aria2                                                   ...

  2. Keepalived stable tarball

    Keepalived stable tarball Keepalived for Linux - Version 1.3.5 - March 19, 2017 Keepalived for Linux ...

  3. 大数据应用之HBase数据插入性能优化之多线程并行插入测试案例

    一.引言: 上篇文章提起关于HBase插入性能优化设计到的五个参数,从参数配置的角度给大家提供了一个性能测试环境的实验代码.根据网友的反馈,基于单线程的模式实现的数据插入毕竟有限.通过个人实测,在我的 ...

  4. css调用方式的方法

    1.内部样式表(位于 <head> 标签内部) <html><style>.box{display:inline}p { color: rgb(255,0,0); ...

  5. selenium APi

    1.查看浏览器的名字方法:name实例:drvier.name 2.删除浏览器所以的cookies方法:delete_all_cookies()实例:driver.delete_all_cookies ...

  6. 用几分钟了解R语言入门知识

    第一篇——用几分钟了解R语言入门知识 第二篇——用几分钟了解R语言入门知识(续) 关于数据分析学习笔记的计划(以及目录)

  7. xcode编译失败

    iPhone自动化需要使用WDA.经过一段时间,再次编译,会出现WDA编译失败的问题,提示 The operation couldn't be completed. Unable to log in ...

  8. 每秒查询率QPS

    每秒查询率QPS是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准,在因特网上,作为域名系统服务器的机器的性能经常用每秒查询率来衡量. 原理:每天80%的访问集中在20%的时间里,这20%时 ...

  9. [UE4]C++静态局部变量

    void testFunc() { ; // this only runs ONCE, even on // subsequent calls to testFunc()! cout << ...

  10. Web 跨域请求

    在前端开发过程中,难免和服务端产生数据交互.一般情况我们的请求分为这么几种情况:   1. 只关注发送,不关注接收  2.不仅要发送,还要关注服务端返回的信息       a.  同域请求      ...