8 包和引入
8.1 编写示例程序,展示为什么
package com.horstmann.impatient
不同于
package com
package horstmann
package impatient
分别使用package的效果如下
package com {
class T1() {}
package horstmann {
class T2(t: T1) {}
package impatient {
class T3(t1: T1, t2: T2) {}
}
}
}
子包里的类可以使用父包里的类。但是第一种方式不可以
package com.horstmann.impatient{
class T4(t1:T1,t3:T3) //无法找到T1
}
8.2 编写一段让你的Scala朋友们感到困惑的代码,使用一个不在顶部的com包
这样可以吗?
package com {
class T1() {}
package horstmann {
class T2(t: T1) {}
package impatient {
class T3(t1: T1, t2: T2) {}
}
}
}
import com._
class TT(t1:T1){
}
8.3 编写一个包random,加入函数nextInt():Int,nextDouble():Double,setSeed(seed:Int):Unit。生成随机数的算法采用线性同余生成器:
后值 = (前值 * a + b)mod 2^n
其中,a = 1664525,b=1013904223,n = 32,前值的初始值为seed
package random{
package object random{
var seed:Int = _
val a = BigDecimal(1664525)
val b = BigDecimal(1013904223)
val n = 32
def nextInt():Int={
val temp = (seed * a + b) % BigDecimal(2).pow(n)
seed = temp.toInt
seed
}
def nextDouble():Double={
val temp = (seed * a + b) % BigDecimal(2).pow(n)
seed = temp.toInt
temp.toDouble
}
}
}
package test {
import random.random
object Test extends App {
random.seed = 4
println(random.nextDouble())
println(random.nextDouble())
println(random.nextDouble())
println(random.nextDouble())
println(random.nextInt())
println(random.nextInt())
println(random.nextInt())
println(random.nextInt())
}
}
8.4 在你看来Scala的设计者为什么要提供package object语法而不是简单的让你将函数和变量添加到包中呢?
JVM不支持。。。
8.5 private[com] def giveRaise(rate:Double)的含义是什么?有用吗?
除了com包可访问,其他包都不能访问。
8.6 编写一段程序,将Java哈希映射中的所有元素拷贝到Scala哈希映射。用引入语句重命名这两个类。
import java.util.{HashMap => JavaHashMap}
import scala.collection.mutable.HashMap
object Test extends App{
val map = new JavaHashMap[String,String]()
map.put("1","a")
map.put("2","b")
map.put("3","c")
val smap = new HashMap[String,String]()
for(key <- map.keySet().toArray){
smap += (key.toString -> map.get(key))
}
println(smap.mkString)
}
8.7 在前一个练习中,将所有引入语句移动到尽可能小的作用域里
object Test extends App{
import java.util.{HashMap => JavaHashMap}
val map = new JavaHashMap[String,String]()
map.put("1","a")
map.put("2","b")
map.put("3","c")
import scala.collection.mutable.HashMap
val smap = new HashMap[String,String]()
for(key <- map.keySet().toArray){
smap += (key.toString -> map.get(key))
}
println(smap.mkString)
}
8.8 以下代码的作用是什么?这是个好主意吗?
import java._
import javax._
导入java和javax下的所有类。而java和javax下是没有类的。所以此代码无用
8.9 编写一段程序,引入java.lang.System类,从user.name系统属性读取用户名,从Console对象读取一个密码,如果密码不是"secret",则在标准错误流中打印一个消息;如果密码是"secret",则在标准输出流中打印一个问候消息。不要使用任何其他引入,也不要使用任何限定词(带句点的那种)
import java.lang.System
object Test extends App{
var password = Console.readLine()
if (password equals "secret") System.out.println("Hello " + System.getProperty("user.name"))
else System.err.println("password error!")
}
8.10 除了StringBuilder,还有哪些java.lang的成员是被scala包覆盖的?
直接比对java.lang下的类和scala包下的类即可
Blog Url:http://www.ivanpig.com/blog/?p=472
分享到:
相关推荐
描述中提到的三份文档——"快学scala第一章习题答案.doc"、"快学scala第二章习题答案.doc"、"快学scala第三章习题答案.doc"——暗示了这份学习资料是按照章节结构编排的,每个章节都有对应的习题和详尽的答案。...
读书笔记:《快学Scala》课后习题解答
快学scala的习题和答案,对学习scala有巨大帮助,可以好好学习scala,在学习的过程中可以边看边练习~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
快学scala 完整清晰版 大数据spark 主要的编程语言 快学scala 完整清晰版 大数据spark 主要的编程语言
这个"快学Scala"的课后习题答案和源码将涵盖以上提到的大部分知识点,通过实际操作和练习,你可以深入理解Scala的各个方面。解压文件后,可以直接导入到IDE(如IntelliJ IDEA或Scala IDE),按照章节顺序逐步学习,...
"快学Scala答案总汇"很显然是一个针对Scala初学者或正在学习Scala的人提供的资源,包含了对课程或书籍中习题的解答,帮助读者更好地理解和掌握Scala的核心概念。 1. **基础语法**:Scala的基础语法与Java有诸多不同...
"快学Scala"系列教程可能涵盖了语言基础、类与对象、高阶函数、模式匹配、类型系统、Actor模型以及 Akka 框架等内容。课后习题是学习过程中巩固知识的重要环节,这里我们将深入探讨这些习题答案集合中的关键知识点。...
这个“快学Scala 课后习题答案集合-中文版”涵盖了Scala学习中的关键知识点,包括注解(第十五章)和高级类型(第十八章)等主题。下面将对这些主题进行详细的解释。 **注解(Annotations)** 在Scala中,注解是一种元...
这个"快学Scala课后习题答案集合"资源将帮助学习者核对自己的解答,理解错误之处,并加深对Scala语言特性的认识。通过对比答案,学习者可以发现自己的不足,从而针对性地加强学习。无论是在基础概念还是在高级特性上...
《快学Scala》是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力。由于Scala运行于JVM之上,因此它...
**快学Scala中文版**是一本面向初学者和有一定编程经验的人士的教材,旨在帮助读者快速掌握Scala这一强大的函数式编程语言。该书通过深入浅出的方式,讲解了Scala的基础概念、语法特性以及高级应用,是学习Scala的...
"快学Scala 中文版"是一本专为初学者设计的 Scala 入门书籍,它以清晰易懂的方式介绍了 Scala 的核心概念和技术。 在本书中,读者将首先了解到 Scala 的基本语法,包括变量声明、数据类型(如基本类型、引用类型、...
花了5元订制的快学Scala pdf电子书! Scala是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的最佳特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力...
快学Scala
快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰
"快学Scala2带书签、源码"是一个针对初学者和有一定经验的开发者的资源包,旨在帮助他们快速掌握Scala语言的第二版。** 在《快学Scala》第二版这本著作中,作者通过简洁易懂的讲解,深入浅出地介绍了Scala的基础...
通过阅读《快学 Scala(第二版)》,读者不仅可以学习Scala的基本语法和高级特性,还能了解到如何在大数据处理领域(如Spark)和流处理(如Kafka)中有效地运用这些知识。书中的例子和练习将帮助读者快速掌握这些技能...
"快学Scala中文版"是一本为初学者设计的教程,旨在帮助读者快速理解和掌握Scala语言的基础知识。 本书首先会介绍Scala的基础概念,包括变量、常量、数据类型以及控制流语句。在Scala中,变量声明使用`var`关键字,...