1
我試圖編譯the official guide的示例,即帶有乒乓的示例。 我已將Ping和Pong類放入其默認包中的文件中。然而,Ping類有編譯錯誤,說它找不到Pong類,反之亦然。我也試圖清理項目,以便重建會發生,但我無法取得任何進展。我正在使用來自here的2.8.1的最終版本。無法在Scala中編譯基本的演員示例
我在做什麼錯?
我試圖編譯the official guide的示例,即帶有乒乓的示例。 我已將Ping和Pong類放入其默認包中的文件中。然而,Ping類有編譯錯誤,說它找不到Pong類,反之亦然。我也試圖清理項目,以便重建會發生,但我無法取得任何進展。我正在使用來自here的2.8.1的最終版本。無法在Scala中編譯基本的演員示例
我在做什麼錯?
爲pingpong.scala的完整源可以在scala-2.8.1.final-sources.tgz
位置找到在TGZ:階-2.8.1.final來源/文檔/示例/男演員/ pingpong.scala
該示例假定所有的類都在同一個文件,可以與
scalac pingpong.scala
編譯但是,如果你想將它們放在不同的文件:
Ping.scal一個
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
謝謝!通過您的來源閱讀後,我意識到我忘了添加案件對象。 – Geo 2011-03-31 13:00:26