[英]Scala socket cannot write to output stream
我是斯卡拉世界的新手,所以請原諒我的瑣碎問題。 :)我只想打開一個端口的套接字並打磨並接收消息。 如果我收到一個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!
如果此代碼確實是您正在使用的代碼,則會出現嚴重問題:它使用靜態初始化程序內部的線程。
這里:
object HelloWorld extends {
延伸什么?
def main(args: Array[String]) {}
沒有main方法,所以其他所有內容都在構造函數內部以對象HelloWorld
。 基本上,這意味着使用線程(包括演員)的一切都是不可靠的。 把這些東西放在main方法中。
我不熟悉netcat,但它是否可能不打印"HALLO"
響應,因為它的編碼方式是netcat無法理解的(即Java的序列化格式)? 如果不將輸出流包裝在ObjectOutputStream
是否有效?
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.