|
Scala example source code file (actor-link-getstate.scala)
The Scala actor-link-getstate.scala source codeimport scala.actors.{Actor, Exit} import scala.actors.Actor._ case class MyException(text: String) extends Exception(text) { override def fillInStackTrace() = this } object Slave extends Actor { def act() { try { loop { react { case 'doWork => Console.out.println("Done") reply('done) } } } catch { case e: Throwable if !e.isInstanceOf[scala.util.control.ControlThrowable] => e.printStackTrace() } } } object Master extends Actor { override def toString = "Master" def act() { try { link(Slave) Slave ! 'doWork react { case 'done => throw new MyException("Master crashed") } } catch { case e: Throwable if !e.isInstanceOf[scala.util.control.ControlThrowable] => e.printStackTrace() } } } object Test { def main(args: Array[String]) { actor { try { self.trapExit = true link(Slave) Slave.start() Master.start() react { case Exit(from, reason) if (from == Slave) => Console.out.println(Slave.getState) } } catch { case e: Throwable if !e.isInstanceOf[scala.util.control.ControlThrowable] => e.printStackTrace() } } } } Other Scala examples (source code examples)Here is a short list of links related to this Scala actor-link-getstate.scala source code file: |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.