一,基本概念:

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. 常见协议基础知识总结--DHCP协议

    DHCP动态主机配置协议,简单点说,就是提供了自动获取ip地址的功能,基于四层的UDP协议: 以下描述此协议的整个工作流程: (1) 客户端发送discovery报文,二三层广播报文,源ip地址全0: ...

  2. gcc 簡單操作

    gcc -c test.c 產出 test.o object file gcc -c test.c -o XXX 產出 XXX object file gcc test.c -o aaa 產出 aaa ...

  3. linux sun/awt/X11GraphicsEnvironment 找不到错误

    转载自:http://blog.csdn.net/bolg_hero/article/details/46594915 在Linux下,我们在用Java的图片包来处理图片时,经常遇到java.lang ...

  4. JavaScript的7种继承模式

    <JavaScript模式>一书中,对于JavaScript的几种继承模式讲解得很清楚,给我提供了很大帮助.总结一下,有如下7种模式. 继承模式1--设置原型(默认模式) 实现方式: // ...

  5. ubuntu 16.04安装redis群集zz

    之前有文章,写明了如何安装redis.这里,进行群集配置. 创建Redis配置目录 /etc/redis: $ sudo mkdir /etc/redis/redis_cluster $cd /etc ...

  6. 只有5行代码的算法——Floyd算法

    Floyd算法用于求一个带权有向图(Wighted Directed Graph)的任意两点距离的算法,运用了动态规划的思想,算法的时间复杂度为O(n^3).具体方法是:设点i到点j的距离为d[i][ ...

  7. Unity3D实现DoubleClick的一种方法

    代码简单粗暴如下: void OnMouseDown() { ) { t2 = DateTime.Now; , , , , )) //时间间隔小于500ms,认为是双击 { // 双击后的操作 } t ...

  8. xunsearch: 开启后台服务,索引……随笔记录

    重启后台服务: cd $prefix ; bin/xs-ctl.sh restart 索引: # 导入 MySQL 数据库的 dbname.tbl_post 表到 demo 项目中,并且平滑重建 ut ...

  9. CSU 1337 搞笑版费马大定理【优化枚举】

    费马大定理:当n>2时,不定方程an+bn=cn没有正整数解.比如a3+b3=c3没有正整数解.为了活跃气氛,我们不妨来个搞笑版:把方程改成a3+b3=c3,这样就有解了,比如a=4, b=9, ...

  10. HDU2923 Einbahnstrasse (Floyd)

    Einbahnstrasse Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...