加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Scala顶级包对象

发布时间:2020-12-16 18:36:38 所属栏目:安全 来源:网络整理
导读:编辑此问题更加清晰,请参阅下面的评论以获得解释. 所以这对我来说似乎有点显而易见,但它看起来并不像那样,但是如果我有一个scala包对象并且它位于我的包的顶层.像com.company一样说它就像下面这样简单 package compackage object company{ val something = "
编辑此问题更加清晰,请参阅下面的评论以获得解释.

所以这对我来说似乎有点显而易见,但它看起来并不像那样,但是如果我有一个scala包对象并且它位于我的包的顶层.像com.company一样说它就像下面这样简单

package com

package object company{
  val something = "Hello world."
}

现在我觉得这个变量会流下来并且可以从它的子包中访问,但它们不是.

// 2 Layers down instead of the direct child
package com.company.app

import com.company._

object Model extends App {
  println(something)
}

这似乎只适用于导入,这很好,但我希望使用包对象,我可以为整个包定义顶级的东西并让它涓涓细流,但事实并非如此吗?这有什么办法吗?我很欣赏对此的任何见解.

解决方法

您的问题中发布的代码无需导入即可正常工作.如果您希望当前包上的所有数据包对象的定义逐渐减少,则必须修改子包中类的包语句

包对象

package com

package object company {
  val something = "Hello world."
}

子包com.company.model中的类

package com
package company
package model
// package com.company.model would not work here!

object Model extends App {
  println(something)
}

这种技术经常在scala库本身中使用.例如,参见s.c.i.HashSet中的package语句:

package scala
package collection
package immutable

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读