无法在Scala中编译基本actor示例

时间:2011-03-31 12:19:15

标签: eclipse scala

我正在尝试从the official guide编译示例,该示例使用乒乓。 我把Ping和Pong类放在他们自己的文件中,在默认包中。但是,Ping类有编译错误,说它找不到Pong类,反之亦然。我还尝试清理项目,以便重建,但我无法取得任何进展。我使用的是here的最终版本2.8.1。

我做错了什么?

1 个答案:

答案 0 :(得分:4)

可以在scala-2.8.1.final-sources.tgz

中找到pingpong.scala的完整源代码

位于tgz:scala-2.8.1.final-sources / docs / examples / actors / pingpong.scala

该示例假定所有类都在同一个文件中,可以使用

进行编译
scalac pingpong.scala

但是如果你想把它们放在不同的文件中:

Ping.scala

import scala.actors.Actor
import scala.actors.Actor._

case object Ping
class Ping(count: Int, pong: Actor) extends Actor {
  def act() {
    var pingsLeft = count - 1
    pong ! Ping
    while (true) {
      receive {
        case Pong =>
          if (pingsLeft % 1000 == 0)
            Console.println("Ping: pong")
          if (pingsLeft > 0) {
            pong ! Ping
            pingsLeft -= 1
          } else {
            Console.println("Ping: stop")
            pong ! Stop
            exit()
          }
      }
    }
  }
}

Pong.scala

import scala.actors.Actor
import scala.actors.Actor._

case object Pong
class Pong extends Actor {
  def act() {
    var pongCount = 0
    while (true) {
      receive {
        case Ping =>
          if (pongCount % 1000 == 0)
            Console.println("Pong: ping "+pongCount)
          sender ! Pong
          pongCount = pongCount + 1
        case Stop =>
          Console.println("Pong: stop")
          exit()
      }
    }
  }
}

pingpong.scala

case object Stop

object pingpong extends Application {
  val pong = new Pong
  val ping = new Ping(100000, pong)
  ping.start
  pong.start
}

然后运行scalac * .scala