Scala快学笔记(一)
一,基本概念:
1,Scala是一种基于JVM的面向对象和函数式编程语言
2,基本类型:数值类型 -》:Byte,Short,Int,Long,Float,Double和布尔类型:Boolean和字符类型:Char


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)
/*字符串的操作*、
参考文献:
Scala快学笔记(一)的更多相关文章
- Scala快学笔记(二)
一,基本概念 1,映射 Map与HashMap与TreeMap,SotredMap等区别: 1.HashMap键无序,它根据键的HashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度 ...
- Scala快学笔记(三)
一 ,文件操作: 1,读取行:val source=Source.fromFile("fileName","utf-8) 形成一个字符串:source.mkString ...
- [Scala] 快学Scala A3L3
Actor 通过尽可能避免锁和共享状态,actor使得我们能够容易地设计出正确.没有死锁或争用状况的程序. Scala类库提供了一个actor模型的简单实现.AKKA是更高级的actor类库. 19. ...
- [Scala] 快学Scala A2L2
集合 13.1 集合的三大类 所有的集合都扩展Iterable特质.集合的三大集合为Seq, Set, Map Seq是一个有先后次序的值的序列,比如数组或列表.IndexSeq允许我们通过整型下表快 ...
- [Scala] 快学Scala A1L1
基础 1.1 声明值和变量 在Scala中,鼓励使用val; 不需要给出值或变量的类型,这个信息可以从初始化表达式推断出来.在必要的时候,可以指定类型. 在Scala中,仅当同一行代码中存在多条语句时 ...
- 快学Scala习题解答—第一章 基础
1 简介 近期对Scala比较感兴趣,买了本<快学Scala>,感觉不错.比<Programming Scala:Tackle Multi-Core Complexity on th ...
- 《快学Scala》
Robert Peng's Blog - https://mr-dai.github.io/ <快学Scala>Intro与第1章 - https://mr-dai.github.io/S ...
- 快学Scala 第十九课 (trait的abstract override使用)
trait的abstract override使用: 当我看到abstract override介绍的时候也是一脸懵逼,因为快学scala,只介绍了因为TimestampLogger中调用的super ...
- 快学Java NIO 续篇
可以先看Java NIO的整体介绍,这篇接着说以下内容,<快学Java NIO>续篇 FileChannel SocketChannel ServerSocketChannel Java ...
随机推荐
- 常见协议基础知识总结--DHCP协议
DHCP动态主机配置协议,简单点说,就是提供了自动获取ip地址的功能,基于四层的UDP协议: 以下描述此协议的整个工作流程: (1) 客户端发送discovery报文,二三层广播报文,源ip地址全0: ...
- gcc 簡單操作
gcc -c test.c 產出 test.o object file gcc -c test.c -o XXX 產出 XXX object file gcc test.c -o aaa 產出 aaa ...
- linux sun/awt/X11GraphicsEnvironment 找不到错误
转载自:http://blog.csdn.net/bolg_hero/article/details/46594915 在Linux下,我们在用Java的图片包来处理图片时,经常遇到java.lang ...
- JavaScript的7种继承模式
<JavaScript模式>一书中,对于JavaScript的几种继承模式讲解得很清楚,给我提供了很大帮助.总结一下,有如下7种模式. 继承模式1--设置原型(默认模式) 实现方式: // ...
- ubuntu 16.04安装redis群集zz
之前有文章,写明了如何安装redis.这里,进行群集配置. 创建Redis配置目录 /etc/redis: $ sudo mkdir /etc/redis/redis_cluster $cd /etc ...
- 只有5行代码的算法——Floyd算法
Floyd算法用于求一个带权有向图(Wighted Directed Graph)的任意两点距离的算法,运用了动态规划的思想,算法的时间复杂度为O(n^3).具体方法是:设点i到点j的距离为d[i][ ...
- Unity3D实现DoubleClick的一种方法
代码简单粗暴如下: void OnMouseDown() { ) { t2 = DateTime.Now; , , , , )) //时间间隔小于500ms,认为是双击 { // 双击后的操作 } t ...
- xunsearch: 开启后台服务,索引……随笔记录
重启后台服务: cd $prefix ; bin/xs-ctl.sh restart 索引: # 导入 MySQL 数据库的 dbname.tbl_post 表到 demo 项目中,并且平滑重建 ut ...
- CSU 1337 搞笑版费马大定理【优化枚举】
费马大定理:当n>2时,不定方程an+bn=cn没有正整数解.比如a3+b3=c3没有正整数解.为了活跃气氛,我们不妨来个搞笑版:把方程改成a3+b3=c3,这样就有解了,比如a=4, b=9, ...
- HDU2923 Einbahnstrasse (Floyd)
Einbahnstrasse Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...