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习题、答案、详细解答 快学scala第一章习题答案.doc 快学scala第二章习题答案.doc 快学scala第三章习题答案.doc ......
快学scala的习题和答案,对学习scala有巨大帮助,可以好好学习scala,在学习的过程中可以边看边练习~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
快学scala 完整清晰版 大数据spark 主要的编程语言 快学scala 完整清晰版 大数据spark 主要的编程语言
快学Scala 课后习题答案集合
快学Scala 课后习题答案集合-中文版
快学Scala课后习题答案,包含各个章节答案word版和pdf版
快学Scala-课后习题答案-源码-总22章;解压导入即可使用
快学scala的最新版本,独家一份,学习spark2.0的必备入门书籍,快来下载,绝对高清
快学scala答案总汇
《快学Scala》是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力。由于Scala运行于JVM之上,因此它...
花了5元订制的快学Scala pdf电子书! Scala是一门以Java虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的最佳特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发的威力...
快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰 快学scala中文版带目录,清晰
快学Scala 中文版带目录 快学Scala 中文版带目录1 快学Scala 中文版带目录2
Scala-快学Scala 中文版, 一本scala入门的经典书籍, 推荐!
Scala for the Impatient 中文版 快学Scala pdf(含目录) scala 快速入门书箱 scala经典图书 Core Java作者最新力作 中文版 快学Scala Scala for the Impatient 中文版 [美]C S 霍斯曼 2012 电子工业出版社
Cay S.Horstmann所著的《快学Scala》内容简介:Scala是一门以Java 虚拟机(JVM)为目标运行环境并将面向对象和函数式编程语言的**特性结合在一起的编程语言。你可以使用Scala编写出更加精简的程序,同时充分利用并发...
scala入门书籍,快学scala,简单概述scala的基本内容,完整中文版
快学Scala 中文版完整目录书签.pdf-含课后习题答案-源码
随着大数据上升为国家战略,现在各大公司都开始进军大数据行业。...《快学Scala》的作者是国际畅销书《Java核心技术》的主要作者,作者基于完全实用的角度给出了学习Scala的快速、基于代码的入门指南!