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

Scala Future – 为了理解,混合同步和异步

发布时间:2020-12-16 18:08:52 所属栏目:安全 来源:网络整理
导读:在我的method1中,我需要异步调用另一个方法2,它返回Option(result1).比如果result1为空,我需要异步调用另一个方法3,但如果result1不为空,我只需要返回它. 这是方法: def signIn(username: String): Future[User] = { for { foundUser - userService.findByU
在我的method1中,我需要异步调用另一个方法2,它返回Option(result1).比如果result1为空,我需要异步调用另一个方法3,但如果result1不为空,我只需要返回它.

这是方法:

def signIn(username: String): Future[User] = {
    for {
      foundUser <- userService.findByUsername(username) // this method returns Future[Option[User]],// foundUser is Option[User]
      user <- if (foundUser.isEmpty) {
        val newUser = User(username = "User123")
        userService.create(newUser).map(Some(_)) // this method returns Future[Option[User]]
      }
      else
        // Here I want to return just foundUser,of course,it is not possible. 
        // IS THIS APPROACH CORRECT?? DOES THIS LINE CREATE ASYNCHRONOUS CALL?          
        Future.successful(foundUser)
    } yield user 
  }

问题是:

Future.successful(foundUser) – 这个方法在上面的代码中是否正确?这行是否会创建异步调用?如果是这样,如何避免呢?我已经异步获取了foundUser,并且我不想仅仅为了返回已经获取的值而进行额外的异步调用.

解决方法

Future.successful不会在提供的ExecutionContext上排队其他函数.它只是使用 Promise[T]来创建一个完整的Future [T]:

/** Creates an already completed Future with the specified result.
   *
   *  @tparam T       the type of the value in the future
   *  @param result   the given successful value
   *  @return         the newly created `Future` instance
   */
  def successful[T](result: T): Future[T] = Promise.successful(result).future

作为旁注,您可以使用Option.fold减少样板量:

def signIn(username: String): Future[User] = 
  userService
    .findByUsername(username)
    .flatMap(_.fold(userService.create(User(username = "User123")))(Future.successful(_))

(编辑:李大同)

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

    推荐文章
      热点阅读