mirror of
https://github.com/KevinMidboe/linguist.git
synced 2025-10-29 09:40:21 +00:00
76 lines
3.2 KiB
Scala
76 lines
3.2 KiB
Scala
import math.random
|
|
import scala.language.postfixOps
|
|
import scala.util._
|
|
import scala.util.{Try, Success, Failure}
|
|
import scala.concurrent._
|
|
import duration._
|
|
import ExecutionContext.Implicits.global
|
|
import scala.concurrent.{ ExecutionContext, CanAwait, OnCompleteRunnable, TimeoutException, ExecutionException, blocking }
|
|
/* This worksheet demonstrates some of the code snippets from
|
|
* Week3, Lecture 4, "Composing Futures".
|
|
*/
|
|
|
|
|
|
object node11 {
|
|
println("Welcome to the Scala worksheet") //> Welcome to the Scala worksheet
|
|
|
|
/**
|
|
* Retry successfully completing block at most noTimes
|
|
* and give up after that
|
|
*/
|
|
|
|
def retry[T](n: Int)(block: =>Future[T]): Future[T] = {
|
|
val ns: Iterator[Int] = (1 to n).iterator
|
|
val attempts: Iterator[()=>Future[T]] = ns.map(_ => ()=>block)
|
|
val failed: Future[T] = Future.failed(new Exception)
|
|
attempts.foldLeft(failed)((a, block) => a fallbackTo { block() })
|
|
} //> retry: [T](n: Int)(block: => scala.concurrent.Future[T])scala.concurrent.Fut
|
|
//| ure[T]
|
|
def rb(i: Int) = {
|
|
blocking{Thread.sleep(100*random.toInt)}
|
|
println("Hi " ++ i.toString)
|
|
i + 10
|
|
} //> rb: (i: Int)Int
|
|
def block(i: Int) = {
|
|
println("Iteration: " + i.toString)
|
|
|
|
val ri = retry(i)( Future {rb(i)} )
|
|
|
|
ri onComplete {
|
|
case Success(s) => println(s.toString ++ " = 10 + " ++ i.toString)
|
|
case Failure(t:Exception) => println(t.toString ++ " " ++ i.toString)
|
|
case r => println(r.toString ++ " " ++ i.toString)
|
|
}
|
|
|
|
} //> block: (i: Int)Unit
|
|
/* Multiple executions of a block of commands where
|
|
* each block contains one collectCoins and
|
|
* one buyTreasure. If either call fails, the whole iteration does not fail,
|
|
* because we are catching exceptions (with flatMap) in this implementation.
|
|
* Note that these blocks execute synchrounsly.
|
|
*/
|
|
(0 to 4 toList).foreach(i =>block(i)) //> Iteration: 0
|
|
//| Iteration: 1
|
|
//| java.lang.Exception 0
|
|
//| Hi 1
|
|
//| Iteration: 2
|
|
//| 11 = 10 + 1
|
|
//| Hi 2
|
|
//| Iteration: 3
|
|
//| Hi 3
|
|
//| Hi 2
|
|
//| Iteration: 4
|
|
//| 12 = 10 + 2
|
|
blocking{Thread.sleep(3000)} //> Hi 4
|
|
//| Hi 3
|
|
//| 13 = 10 + 3
|
|
//| Hi 3
|
|
//| 14 = 10 + 4
|
|
//| Hi 4
|
|
//| Hi 4
|
|
//| Hi 4-
|
|
|
|
|
|
|
|
}
|