Scala套接字无法写入输出流

时间:2010-08-12 20:08:53

标签: java sockets serialization scala outputstream

我是斯卡拉世界的新手,所以请原谅我的琐碎问题。 :)我只想打开一个端口的套接字并打磨并接收消息。 如果我收到一个HELO,我想对一条消息作出反应,但我无法以任何方式写入套接字。 我使用nc来监听传入的连接:

nc -k -l 127.0.0.1 3333

当客户端连接时,我写

HELO

在netcat中,但客户端没有回答。

这是我的scala代码:

package hello

import java.io._
import java.net.{ InetAddress, ServerSocket, Socket, SocketException }
import java.util.Random
import scala.actors.Actor
import scala.actors.Actor._

object HelloWorld extends {
    def main(args: Array[String]) {}
    val ia = InetAddress.getByName("localhost");
    val socket = new Socket(ia, 3333)
    val out = new ObjectOutputStream(
        new DataOutputStream(this.socket.getOutputStream))
    val in = new DataInputStream(socket.getInputStream())
    println("Starting client");
    var i = 0;
    /* The actor!
     * 
     */
    val myActor = actor {
        loop {
            receive {
                case s: String => {
                    if (s.startsWith("HELO")) {
                        println("DEBUG: RECEIVED HELO=>SENDING AUTH!")
                        this.out.writeUTF("HALLO")
                        this.out.flush();
                    } else {
                        println("received:" + s);
                    }
                }
                case _ => println("I have no idea what I just got.")
            }
        }
    }
    /*
     * Testing the actor!
     * 
     */
    myActor ! "foobar";
    while (!socket.isConnected()) {
        println("Not connected waiting")
        Thread.sleep(5000);
    }
    if (socket.isConnected()) {
        println("connected");
    }
    try {
        while (true) {
            i += 1;
            val x = in.readLine()

            myActor ! x;
            Thread.sleep(500);
        }

    } catch {
        case e: IOException =>
            e.printStackTrace()
    }
}

接收工作正常,并且actor对传入消息作出反应,但写入永远不会完成。我只是监督一些事情,或者我的代码是错误的发送到outputSteam。

来自控制台窗口的输出:

Starting client
connected
received:foobar
DEBUG: RECEIVED HELO=>SENDING AUTH!

2 个答案:

答案 0 :(得分:2)

如果此代码确实是您正在使用的代码,则会出现严重问题:它是在静态初始化程序中使用线程。

下面:

object HelloWorld extends {

扩展什么?

def main(args: Array[String]) {}

没有main方法,所以其他所有内容都在构造函数内部以对象HelloWorld。基本上,这意味着使用线程(包括演员)的一切都是不可靠的。把这些东西放在main方法中。

答案 1 :(得分:1)

我不熟悉netcat,但它是否可能不打印"HALLO"响应,因为它的编码方式是netcat无法理解的(即Java的序列化格式)?如果不将输出流包装在ObjectOutputStream

中,它是否有效