Scala学习七——包和引入
一.本章要点
- 包也可也可以像内部类那样嵌套
- 包路径不是绝对路径
- 包声明链x.y.z并不自动将中间包x和x.y变成可见
- 位于文件顶部不带花括号的包声明在整个文件范围内有效
- 包对象可以持有函数和变量
- 引入语句可以引入包、类和对象
- 引入语句可以出现在任何位置
- 引入语句可以重命名和隐藏特定成员
- java.lang、scala和Predef总是被引入
二.包
Scala中的包和Java/C++中的包都是一样的,用来管理大型程序中的名称。
可以用完全限定的名称来防止冲突(scala.collection.immutable和scala.collection.mutable),也可以用引入语句来提供一个更短小的别名。
要增加条目到包中,可以将其包含在包语句当中(注:源文件目录和包之间并没有强制的关联关系,可以在一个文件中写多个):
package com{
package horstmann{
package{
class Employee{
}}
}
}
三.作用域规则
Scala的包支持嵌套,可以访问上层作用域中的名称:

问题:

这种情况在Java中不会发生,因为包名是绝对的。但在Scala中包名是相对的(可以使用绝对包名解决,以_root_开始[val s=new _root_.scala.collection.mutable.ArrayBuffer[...]],也可以使用串联式。)
四.串联式包语句
包语句可以包含一个”串“,或者说路径区段,如:

五.文件顶部标记法
文件顶部使用package语句:
package com.horstman.impatient
package people //所有内容属于com.hortman.impatient.people,但com.horstman.impatient包中的内容可见,可以直接引用
class Person
... //相当于
package com.horstman.impatient{
package people{
class Person
... } }
六.包对象
包可以包含类,对象,特质,但不能包含函数或变量的定义(Java虚拟机的局限)。
每个包可以有一个包对象,需要在父包中定义它,且名称和子包一样,例:
package com.horstman.impatient
package object people{
val defaultName="xxx"
}
package people{
class Person{
var name=defaultName //从包对象拿到常量
}
}
在同一个包中使用包对象字段不需要加限定词,在其他地方可以用com.horstman.impatient.people.defaultName访问(包对象被编译成带有静态方法和字段的JVM类)。
七.包可见性
在Scala中可以用private[类名/包名]限制属可见位置(像Java中没有修饰符的类成员在包含该类的包中可见)。
package com.people
class Person{
private[Person] def ...//只在该类实例化对象中可见
} //上层包可见
private[com] def ....
八.引入
通过引入语句使用更短的名称。(import xxx.xxx.xxx,_相当于Java中的通配符)
九.任何地方都可以声明引入
在Scala中,引入语句可以出现在任何地方,并不仅限于文件顶部(如在块中引入,作用效果一直延升到块末尾)
十.重命名和隐藏方法
- 可以使用选取器引({})入包中的几个成员(import java.awr.{Color,Font});
- 选取器允许重命名成员(import jva.util.{HashMap=>javaHashMap});
- HashMap=>_表示隐藏某个成员而不是重命名,一般用来引入其他成员(import java.util.{HashMap=>_,_})
十一.隐式引入
每个Scala程序都隐式引入如下:
//和Java一样,java.lang总是被引入
//允许覆盖之前的引入,如scala.StringBuilder会覆盖java.lang.StringBuilder
import java.lang._
import scala._
//Predef包含了很多有用函数,在Scala还没有加入包对象之前就已经存在了
import Predef._
十二.练习


Scala学习七——包和引入的更多相关文章
- Scala学习(七)---包和引入
包和引入 摘要: 在本篇中,你将会了解到Scala中的包和引入语句是如何工作的.相比Java不论是包还是引入都更加符合常规,也更灵活一些.本篇的要点包括: 1. 包也可以像内部类那样嵌套 2. 包路径 ...
- Scala学习(七)练习
控制结构和函数 1. 编写示例程序,展示为什么 package com.horstmann.impatient 不同于 package com package horstmann package im ...
- Scala学习-02-方法
算数和操作符重载 所有的操作符都是方法. a + b 是一种缩写形式 : a .+ b “+”是方法名(操作符重载) ++和—— Scala中并没有“++”和“——”.需要使用“+=”和“-=” ...
- 快学scala-第七章 包和引入
知识点: 1. Scala.Java.C++的包的目的都是为了管理大型程序中的名称.与对象或类的定义不同,同一个包可以定义在多个文件当中.或者在同一个文件中,为多个包贡献内容. 2. Scala的包和 ...
- Scala学习(九)---文件和正则表达式
文件和正则表达式 摘要: 在本篇中,你将学习如何执行常用的文件处理任务,比如从文件中读取所有行或单词,或者读取包含数字的文件等.本篇的要点包括: 1. Source.fromFile(...).get ...
- 【大数据】Scala学习笔记
第 1 章 scala的概述1 1.1 学习sdala的原因 1 1.2 Scala语言诞生小故事 1 1.3 Scala 和 Java 以及 jvm 的关系分析图 2 1.4 Scala语言的特点 ...
- Scala学习——基础篇
[<快学Scala>笔记] 一.基础 1.变量val 标志符: 声明常量: 如,val answer = 1var 标志符:声明变量: 类型推断:变量的类型由scala根据初始化变量的表达 ...
- Scala学习笔记(一)数据类型
.类型参数化数组 val arrayString = Array[String](2); arrayString (0)="Hello"; arrayString (1)=&quo ...
- MyBatis学习七:spring和MyBatis整合
<\mybatis\day02\16mybatis和spring整合-sqlSessionFactory配置.avi;> MyBatis学习七:spring和MyBatis整合.逆向工程 ...
随机推荐
- Leetcode题目200.岛屿数量(BFS+DFS+并查集-中等)
题目描述: 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 ...
- 使用Git上传文件至Github
记录一下怎么把文件上传到Github,因为之前都存在本地,没上传过Github,自己以后看起来也有个记忆.因为我自己已经安装好Git和注册好Github账号了,设置好了SSH key.这部分不懂的,就 ...
- 搭建Django项目虚拟环境(Windows系统下)
一.安装virtualenv 我们可以使用正式的Python环境中的pip进行安装.进入cmd界面,运行“ pip install virtualenv ”,完成安装后,可以运行“ where vir ...
- 基于角色的权限控制系统(role-based access control)
role-based access control(rbac),指对于不同角色的用户,拥有不同的权限 .用户对应一个角色,一个角色拥有若干权限,形成用户-角色-权限的关系,如下图所示.当一个用户进行访 ...
- 初写C#的小总结
虽然大学学过很多计算机语言,但是现在工作是前端,一个刚入行的前端菜鸟,之前对于后台完全零接触,但是最近有个项目,我也是第一次真正接触C#,中间遇到了一些小问题,就做个总结记录下,真的是超级简单的小知识 ...
- Fast R-CNN论文阅读摘要
论文链接: https://arxiv.org/pdf/1504.08083.pdf 代码下载: https://github.com/rbgirshick/fast-rcnn Abstract Co ...
- Module ngx_http_rewrite_module
http://nginx.org/en/docs/http/ngx_http_rewrite_module.html Directives break if return ...
- Linux 查看CPU和内存的使用情况
Linux 查看CPU和内存的使用情况 如何查看Linux机器的CPU和内存的使用情况. 可以通过如下方式: 1.查看CPU和内存的实时使用情况 使用如下命令: top 命令执行后,效果如下(资源的使 ...
- Spring Cloud(2):服务发现(Eureka)
Spring Cloud Eureka是Spring Cloud Netflix项目下的一个模块,作用是服务的注册和发现,并实现服务治理.它有一个(或一组,以实现高可用)服务注册中心(eureka s ...
- three.js效果之热力图和轨迹线
1.热力图 开始的时候,是用一个网上找的canvas画渐变热点的demo,原理就是给定顶点坐标,然后画圆,颜色使用渐变色,根据权重决定渐变的层数(红色->橙色->绿色) . 但是终究觉得这 ...