从`Some [A]`到'A`

时间:2017-04-05 08:36:09

标签: scala

有没有办法,从A获取Some[A]的类型?

type X = Some[Int]
type Y = ??? // what do I have to write here to get `Int`

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

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

然后使用

type X = Some[Int]
type Y = X#Inner

对于普通的Scala Option类型,这也可以用某种方式吗?

2 个答案:

答案 0 :(得分: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)

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

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

我很欣赏这不是你要求的,但是当你使用这种类型依赖类型时。您需要具有恢复类型的具体值。

答案 1 :(得分:1)

您可以按如下方式编写简单类型函数:

mysqldump --user=<user> -p --no-data --routines <database>

没有部分类型参数应用/推理,它不是很有用,但它有效...