links.scala

来自「JAVA 语言的函数式编程扩展」· SCALA 代码 · 共 48 行

SCALA
48
字号
package examples.actorsimport scala.actors.{Actor, Exit}import scala.actors.Actor._object links extends Application {  case object Stop  actor {    val start = link(p(2))    start ! Stop  }  def p(n: Int): Actor =    if (n == 0) top1()    else top(p(n-1), n)  def top(a: Actor, n: Int): Actor = actor {    println("starting actor " + n + " (" + Thread.currentThread() + ")")    self.trapExit = true    link(a)    loop {      receive {        case ex @ Exit(from, reason) =>          println("Actor " + n + " received " + ex)          exit('finished)        case any => {          println("Actor " + n + " received " + any)          a ! any        }      }    }  }  def top1(): Actor = actor {    println("starting last actor"  + " (" + Thread.currentThread() + ")")    receive {      case Stop =>        println("Last actor now exiting")        exit('abnormal)      case any =>        println("Last actor received " + any)        top1()    }  }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?