Scala actor 简单示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
package test.scala.lang.actor
 
import scala.actors.Actor
 
object TestScalaActor {
 
  def main(args: Array[String]): Unit = {
    testActor
    testActor2
  }
 
  // 通过扩展类创建actor
  def testActor = {
    //要启动一个actor, 需要先构造一个实例, 并调用start方法
    val actor = new HiActor
    actor.start()
 
    // 向actor发送消息
    actor ! "Hi"
    actor ! "Hii"
  }
 
  // 创建临时actor
  // 通过 Actor伴生对象 actor 方法创建和启动actor
  def testActor2 = {
 
    val actor2 = Actor.actor {
      while (true) {
        Actor.receive {
          case "Hi" => println("2Hello")
          case _    => println("2please say Hi")
        }
      }
    }
 
    actor2 ! "Hi"
    actor2 ! "Hii"
     
     
    val actor3 = Actor.actor{
      while(true) {
        Actor.receive{
          case MsgA => println("MsgA")
          case MsgB => println("MsgB")
          case _    => println("some message")
        }
      }
    }
    actor3 ! MsgA
    actor3 ! MsgB
    actor3 ! "Hi"
  }
 
}
 
case class MsgA()
 
case class MsgB()
 
// actor 扩展scala.actors.Actor,
// 有一个抽象方法 act, 重写该方法制定该actor的行为
class HiActor extends Actor {
 
  // act 方法 和 Java Runnable的run 方法类似
  def act() {
    while (true) {
      receive {
        case "Hi" => println("Hello")
        case _    => println("please say Hi")
      }
    }
  }
 
}

  

 

posted on   develooop  阅读(378)  评论(0编辑  收藏  举报

导航

< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8
AmazingCounters.com
点击右上角即可分享
微信分享提示