一,基本概念:

1,Scala是一种基于JVM的面向对象和函数式编程语言

2,基本类型:数值类型 -》:Byte,Short,Int,Long,Float,Double和布尔类型:Boolean和字符类型:Char

Java基本数据类型总结

小数如何转为十进制

精度转换造成精度损失

question:用BigInt计算2的2017次方(BigInt(2).pow(1024)),scalaApI使用

3,高级for :

for(i <- "abc";j <- 1 to 3 if j==2) yield  (i+j).tochar
/*result cde note:第一个for结束记得用分号;,yield最后获得的结果和第一个生成器类型一致,如“cde” 和“abc”*/

4,参数变长的函数声明:def Demo(args:Int*):Object={}   如果没有返回值的函数程为过程,形式如 def Demo(s:String){}  此时没有等号,也可以显示用Unit=来声明

4.1,默认参数 def Demo(name:String="a",age:Int="4")={}  可以用val b= new Demo()  默认可以无须设置参数   name默认val

4.2 ,函数,过程:过程没有返回值的函数,无需要=号,方法,相当于非静态方法,即对象方法??(不太确定),函数相当于Java中的静态方法(类方法),要加=号。

5,懒值和方法和val区别:

  1,懒值 初始化被推迟,只有第一次调用时才会得到验证

  2,val 申明时就得到验证

  3,def 每次调用时,都需要进行一次验证

例子:

val  file=scala.io.Source.fromFile("/usr/one.txt")
/*result \usr\one.txt (系统找不到指定的路径。)*/
lazy file1 =scala.io.Source.fromFile("/usr/one.txt")
/*result
file: scala.io.BufferedSource = <lazy>
*/
def file2 =scala.io.Source.fromFile("/usr/one.txt")
/*result
//file:scala.io.BufferedSource
file1
file2
//java.io.FileNotFoundException: \usr\one.txt (系统找不到指定的路径。)

6,异常:try{}catch{}finally{}

7,块以最后一个返回,空块返回Unit

8,注意点x=y=4这样不合法的,特例:x:Unit,y:Int,x=y=5

9,var t:Long=1   "String".foreach(t*=_.toLong)

10,练习 递归求字符串的Unicode乘积之和

def product(s:String):Long={
if(s.length==1) s.charAt(0).toLong
else s.take(1).charAt(0).toLong*product(s.drop(1))
} //第10题
def mi(x:Double,n:Int):Double={
if (n==0) 1
else if(n<0)
1/mi(x,-n)
else if(n>0 && n%2==0)
mi(x,n/2)*mi(x,n/2)
else
mi(x,n-1)*x
}

10,sorted(true):升序,sorted(false):为降序(从上往下)

11,多维数组:val arr=Array.ofDim[Double](3,4)

12,课后习题:

//交换数组相邻的元素 3.2
def changeArr(arr:Array[Int]):Array[Int]={
for (i <- 0 until arr.length if( i%2==0)) {
val temp= arr(i)
arr(i)=arr(i+1)
arr(i+1)=temp
}
arr
}
/*异常,会出现数组越界,修改为 for (i <-0 until (arr.length-1,2)*/
val tmp=java.util.TimeZone.getAvailableIDs()
val tmp2=for (i <- tmp if(i.startsWith("America"))) yield { i.drop("America".length)}
scala.util.Sorting.quickSort(tmp2)
/*字符串的操作*、

参考文献:

  1,课后习题答案

Scala快学笔记(一)的更多相关文章

  1. Scala快学笔记(二)

    一,基本概念 1,映射 Map与HashMap与TreeMap,SotredMap等区别: 1.HashMap键无序,它根据键的HashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度 ...

  2. Scala快学笔记(三)

    一 ,文件操作: 1,读取行:val source=Source.fromFile("fileName","utf-8)  形成一个字符串:source.mkString ...

  3. [Scala] 快学Scala A3L3

    Actor 通过尽可能避免锁和共享状态,actor使得我们能够容易地设计出正确.没有死锁或争用状况的程序. Scala类库提供了一个actor模型的简单实现.AKKA是更高级的actor类库. 19. ...

  4. [Scala] 快学Scala A2L2

    集合 13.1 集合的三大类 所有的集合都扩展Iterable特质.集合的三大集合为Seq, Set, Map Seq是一个有先后次序的值的序列,比如数组或列表.IndexSeq允许我们通过整型下表快 ...

  5. [Scala] 快学Scala A1L1

    基础 1.1 声明值和变量 在Scala中,鼓励使用val; 不需要给出值或变量的类型,这个信息可以从初始化表达式推断出来.在必要的时候,可以指定类型. 在Scala中,仅当同一行代码中存在多条语句时 ...

  6. 快学Scala习题解答—第一章 基础

    1 简介 近期对Scala比较感兴趣,买了本<快学Scala>,感觉不错.比<Programming Scala:Tackle Multi-Core Complexity on th ...

  7. 《快学Scala》

    Robert Peng's Blog - https://mr-dai.github.io/ <快学Scala>Intro与第1章 - https://mr-dai.github.io/S ...

  8. 快学Scala 第十九课 (trait的abstract override使用)

    trait的abstract override使用: 当我看到abstract override介绍的时候也是一脸懵逼,因为快学scala,只介绍了因为TimestampLogger中调用的super ...

  9. 快学Java NIO 续篇

    可以先看Java NIO的整体介绍,这篇接着说以下内容,<快学Java NIO>续篇 FileChannel SocketChannel ServerSocketChannel Java ...

随机推荐

  1. Chubby lock service for distributed system

    Chubby lock service在分布式系统中的应用 Chubby lock service在分布式系统中提供粗粒度的锁服务, 以及可靠的存储. 相比高性能, 设计的重点在于高可靠性和高可用性. ...

  2. JQ面向对象

    静态方法:某种类型才有的方法,这个方法干的事情只有类型本身有关,不受具体实例对象的影响,在C#语言中,它用static表示,VB中用share表示,而在jq中我们一般用$或者JQuery表示JQ类型, ...

  3. niceScroll在ie11和edge浏览器上面滚动时抖动问题

    niceScroll 是一个很好的jquery插件,相信很多人都用过,我们项目中使用的是3.7.6版本的,一般我们在开发的时候都是使用的火狐或者是谷歌浏览器,使用 niceScroll 没有什么问题, ...

  4. python中的闭包与装饰器

    #原创,转载请留言联系 装饰器的本质就是闭包,所以想知道装饰器是什么,首先要理解一下什么是闭包. 闭包 1. 外部函数返回内部函数的引用.2. 内部函数使用外部函数的变量或者参数. def outer ...

  5. yii2框架获取刚插入数据库的id (原创)

    $insert_id = $UserModel->attributes['id'];

  6. UVA 10341.Solve It-二分查找

    二分查找 二分查找又称折半查找,优点是比较次数少,查找速度快,平均性能好:其缺点是要求待查表为有序表,且插入删除困难.因此,折半查找方法适用于不经常变动而查找频繁的有序列表.首先,假设表中元素是按升序 ...

  7. (10)python 特殊方法

    一.构造方法 在类中定义构造函数 >>> class a: def __init__(self): self.age=42 >>> f=a() >>&g ...

  8. POJ 3264 Balanced Lineup 【线段树/区间最值差】

    Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 62103 Accepted: 29005 Cas ...

  9. 线段树+差分【p1438】无聊的数列

    Description 维护一个数列{a[i]},支持两种操作: 1.1 L R K D:给出一个长度等于R-L+1的等差数列,首项为K,公差为D,并将它对应加到a[L]~a[R]的每一个数上.即:令 ...

  10. oracle 替换其中部分内容

    update TABLE_NAME set field =REPLACE(field ,substr(field ,0,1) ,'P') where field is not null ;