从`Some [A]`到'A`

Fab*_*ner 5 scala

有没有什么办法,去的类型ASome[A]

type X = Some[Int]
type Y = ??? // what do I have to write here to get `Int`
Run Code Online (Sandbox Code Playgroud)

我可以定义自己的Option类型,允许这样:

sealed trait Option[+A]
case object None extends Option[Nothing]
case class Some[+A](a: A) {
  type Inner = A
}
Run Code Online (Sandbox Code Playgroud)

然后使用

type X = Some[Int]
type Y = X#Inner
Run Code Online (Sandbox Code Playgroud)

对于普通的Scala Option类型,这也可以吗?

V-L*_*amp 2

这是一个使用路径相关类型从值恢复类型的解决方案:

  trait IsOption[F]{
    type T    
    def apply(f: F): Option[T]
  }  
  object IsOption{
    def apply[F](implicit isf: IsOption[F]) = isf    
    implicit def mk[A] = new IsOption[Option[A]]{
      type T = A      
      def apply(f: Option[A]): Option[A] = f
    }
  }  
  def getInner[A](in:A)(implicit inner: IsOption[A]): Option[inner.T] = inner(in)
Run Code Online (Sandbox Code Playgroud)

答案很大程度上受到这张精彩演示文稿幻灯片的启发:http://wheaties.github.io/Presentations/Scala-Dep-Types/dependent-types.html#/2/1

您有一个接收不透明 A 的函数,但您通过隐式恢复了它是一个选项和内部类型的事实IsOption[A]

我知道这并不完全是您所要求的,但是当您使用此类依赖于类型的类型时。您需要有一个具体的值来从中恢复类型。

  • 您可以执行`val isOpt =隐式[Option[T]]; 类型 Inner = isOpt.T` (2认同)