Scalaz`F [_]:Applicative`类型约束如何暗示使用隐式参数?

我正在努力理解 Scalaz中 Traverse trait中的以下函数定义:

def traverse [F [_]:applicative,A,B](f:A => F [B],t:T [A]):F [T [B]]

我不理解的部分是F [_]:适用.

现在,让我们看看Applicative是什么:

trait applicative[Z[_]] extends Pointed[Z] with Apply[Z] {
  override def fmap[A,B](fa: Z[A],f: A => B): Z[B] = this(pure(f),fa)
  override def apply[A,B](f: Z[A => B],a: Z[A]): Z[B] = liftA2(f,a,(_:A => B)(_: A))
  def liftA2[A,B,C](a: Z[A],b: Z[B],f: (A,B) => C): Z[C] = apply(fmap(a,f.curried),b)
}

这里,对于某些类型F的遍历工作,需要在范围内引入applicative [F]类型的隐式对象.

我想了解几件事:

> Wat确切地说F [_]:应用意味着什么?
>为什么F [_]与applicative有关?我们需要applicative [F],而不是F [something]扩展applicative对吧?
>为什么此方法使用applicative [F]类型的隐式值而不声明隐式参数?

解决方法

我认为所有这三个问题都可以用这个表示法来回答:

def traverse[F[_] : applicative,B](f: A => F[B],t: T[A]): F[T[B]]

相当于:

def traverse[F[_],t: T[A])(implicit $ev: applicative[F]): F[T[B]]

第一种表示法称为F [_]的context bound.

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...