知识点:

1. Scala、Java、C++的包的目的都是为了管理大型程序中的名称。与对象或类的定义不同,同一个包可以定义在多个文件当中。或者在同一个文件中,为多个包贡献内容。

2. Scala的包和其他作用域一样的支持嵌套,可以访问上层作用域中的名称。Scala会遇到默认引入包中的类和自定义包中的类的冲突问题,Java中不会出现这样的问题,包名总是绝对的,从包层级的最顶端开始,但是在Scala中,包名是相对的,就像内部类的名称一样。任何人都可以在任何时候向任何包添加内容。

3. 串联式包语句 com.horstmann.impatient 这样的包语句限定了可见的成员,文件顶部标记法是在文件顶部使用package语句,这比较适用于文件中所有代码属于同一个包的情况。

4. 包对象,包可以包含类、对象和特质,但不能包含函数或变量的定义,这是Java虚拟机的局限,包对象解决了这个局限。每个包都可以有一个包对象,需要在父包中定义它,且名称与子包一样,包对象被编译成带有静态方法和字段的JVM类,名为package.class,位于相应的包下。

5. 包可见性,在Java中,没有被声明为public、private或protected的类成员在包含该类的包中可见,在Scala中,可以通过修饰符达到同样的效果。

pacage com.horstmann.impatient.people

private[people] ….(自己的包中可见)

private[impatient]….(上层包,将可见性扩展到上层包)

6. 引入语句可以使用更短的名称而不是原来较长的名称,引入某个包的全部成员,使用类似于import java.awt._, 这和Java中的通配符*一样,在Scala中,*是合法的标识符。在Scala中,任何地方都可以声明引入,import语句效果一直延伸到包含该语句的块末尾。通过将引入放置在需要这些引入的地方可以大幅减少可能的名称冲突。

如果想要引入包中的几个成员,可以使用选取器,eg: import java.awt.{Color,Font}

选取器语法还允许重命名选到的成员,eg:

      import java.util.{HashMap => JavaHashMap}

      import scala.collection.mutable._

JavaHashMap就是java.util.HashMap,而HashMap则对应scala.collection.mutable.HashMap.

7.隐式引入,每个Scala程序都隐式地以如下代码开始:

import java.lang._

import scala._

import Predef._

这个引入被允许覆盖。

 

练习:参考网址

1.编写示例程序,展示为什么
package com.horstmann.impatient 
不同于
package com 
package horstmann 
package impatient

第一种方式子类不可以使用父包里的类.

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){}//not found:type T1
}

2.编写一段让你的Scala朋友们感到困惑的代码,使用一个不在顶部的com包

不懂.

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={
var temp = (seed * a + b) % BigDecimal(2).pow(n)
seed = temp.toInt
seed
}
def nextDouble:Double={
var 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.nextInt)
println(random.nextInt)
println(random.nextInt)
println(random.nextDouble)
println(random.nextDouble)
println(random.nextDouble)
}
}

4.在你看来Scala的设计者为什么要提供package object语法而不是简单的让你将函数和变量添加到包中呢?

虚拟机的局限

5.private[com] def giveRaise(rate:Double)的含义是什么?有用吗?

private[com]定义包可见性,除了com包其他包都不能访问。

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)
}

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.以下代码的作用是什么?这是个好主意吗?

import java._ 
import javax._

导入Java和javax中的所有类,这两个包中中只有子包,不包含类,所以无用。

9.编写一段程序,引入java.lang.System类,从user.name系统属性读取用户名,从Console对象读取一个密码,如果密码不是"secret",则在标准错误流中打印一个消息;如果密码是"secret",则在标准输出流中打印一个问候消息。不要使用任何其他引入,也不要使用任何限定词(带句点的那种).

import java.lang.System

object Test extends App{
val password = Console.readInt if(password equals "secret")
System.out.println("Hello " + System.getProperty("user.name"))
else System.err.println("password error")
}

快学scala-第七章 包和引入的更多相关文章

  1. 《快学Scala》第六章 对象 第七章 包和引入

  2. 快学Scala 第6章 对象 - 练习

    1. 编写一个Conversions对象,加入inchesToCentimeters.gallonsToLiters和milesToKilometers方法. object Conversions { ...

  3. 《快学Scala》第二章 控制结构和函数

  4. 《快学Scala》第一章 基础

  5. 快学Scala 第七课 (类构造函数)

    类 主构造器: class Person (var name: String){ } 主构造参数可以不带val或者var,如果没有被其他方法使用,则不保存为字段. 如果被其他方法使用,则被升格为字段, ...

  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. [Scala] 快学Scala A1L1

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

随机推荐

  1. shp文件显示

    开发环境 Win7, VS2010 Sp1 QGIS 2.01 #include <qgsapplication.h> #include <qgsproviderregistry.h ...

  2. HDU 1017 A Mathematical Curiosity(枚举)

    题目链接 Problem Description Given two integers n and m, count the number of pairs of integers (a,b) suc ...

  3. insertMany

    结果:

  4. 线程的实现方法以及区别 extends Thread、implements Runable

    /** 线程存在于进程当中,进程由系统创建. 创建新的执行线程有两种方法 注意:   线程复写run方法,然后用start()方法调用,其实就是调用的run()方法,只是如果直接启动run()方法, ...

  5. mysql灵活分页存储过程

    ), -- 表名 ), -- 排序字段(必须!支持多字段不用加order by) IN _PageIndex int, -- 指定当前为第几页 IN _PageSize int, -- 每页多少条记录 ...

  6. Excel补全日期(日期按顺序补全)

    1.给出的数据 2.想补全缺失的日期,比如2015/3/1,2015/3/2,... 1)在D列输入完整的日期,如下图所示: 2)在E2处写函数“=IF(ISERR(VLOOKUP(D2,B:C,2, ...

  7. Jekyll: .md to .html with self defined themes..

    theme is from here $ gem install jekyll bundler ~ $ jekyll new my-awesome-site ~ $ cd my-awesome-sit ...

  8. webstrom官方的活动模版介绍

    编辑模板变量对话框 文件|设置|生活模板--编辑变量Windows和LinuxWebStorm |偏好|生活模板--编辑变量在OS XCtrl + Alt + S 当你点击对话框打开 编辑变量按钮模板 ...

  9. .net core 系列

    1..net core 验证码 2..net core 导出excel 3..net core 上传文件 4..net core 时间戳转换 5..net core 读取配置文件 6..net cor ...

  10. Chapter 1 First Sight——29

    I was anxious not to be late for class on my first day. 在我第一天上学的时候我非常焦虑我会上课迟到. One of my new acquain ...