Scala 使用包来创建命名空间,从而允许你创建模块化程序。
创建包
通过在 Scala 文件的头部声明一个或多个包名称来创建包。
一个惯例是将包命名为与包含 Scala 文件的目录名相同。但是,Scala 并未对文件布局作任何限制。在一个 sbt 工程中,package users
的目录结构可能如下所示:
- ExampleProject- build.sbt- project- src- main- scala- usersUser.scalaUserProfile.scalaUserPreferences.scala- test
注意 users
目录是包含在 scala
目录中的,该包中包含有多个 Scala 文件。包中的每个 Scala 文件都可以具有相同的包声明。声明包的另一种方式是使用大括号:
package users {package administrators {class NormalUser}package normalusers {class NormalUser}}
如你所见,这允许包嵌套并提供了对范围和封装的更好控制。
包名称应全部为小写,如果代码是在拥有独立网站的组织内开发的,则应采用以下的约定格式:<top-level-domain>.<domain-name>.<project-name>
。例如,如果 Google 有一个名为 SelfDrivingCar
的项目,则包名称将如下所示:
package com.google.selfdrivingcar.cameraclass Lens
这可以对应于以下目录结构:
SelfDrivingCar/src/main/scala/com/google/selfdrivingcar/camera/Lens.scala
导入
import
语句用于导入其他包中的成员(类,特质,函数等)。 使用相同包的成员不需要 import
语句。 导入语句可以有选择性:
import users._import users.Userimport users.{User, UserPreferences}import users.{UserPreferences => UPrefs}
Scala 不同于 Java 的一点是 Scala 可以在任何地方使用导入:
def sqrtplus1(x: Int) = {import scala.math.sqrtsqrt(x) + 1.0}
如果存在命名冲突并且你需要从项目的根目录导入,请在包名称前加上 _root_
:
package accountsimport _root_.users._
注意:包 scala
和 java.lang
以及 object Predef
是默认导入的。

文章转载自大数据群英萃,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




