2011-11-26 86 views
0

我面对小困难,我的Java服务器,基本上它的工作原理,但只有一条线路,当我加入另一个不发送,这里是服务器的代码片段:我的服务器有什么问题?

in = new BufferedReader(new InputStreamReader(socket.getInputStream())); 
out = new PrintWriter(socket.getOutputStream(), true); 
if (toSend.length() != 0) { 
    out.print(toSend); 
    out.flush(); 
    System.out.println("connected"); 
    toSend.setLength(0); 
    changeStatusTS(NULL, true); 
} 
if (in.ready()) { 
    s = in.readLine(); 
    if ((s != null) && (s.length() != 0)) { 
     appendToChatBox("INCOMING: " + s + "\n"); 
     if (s.equals("51789181 19426953") == true) { 

      out.println(ms.lister().toString().replace('[', ' ').replace(']', ' ').trim().replace(',', ' ') + "" + '\n'); 
      out.println(ms.topicDesc().toString().replace('[', ' ').replace(']', ' ').trim().replace(',', ' ') + "" + '\n'); 
      out.flush(); 

     } 
    } 
} 

和接收部:

clientSocket = new Socket("10.0.2.2", 1234); 
DataOutputStream outToServer = new DataOutputStream(clientSocket.getOutputStream()); 
BufferedReader inFromServer = new BufferedReader(new InputStreamReader(clientSocket.getInputStream())); 
sentenceX = "" + point.getLatitudeE6(); 
sentenceY = "" + point.getLongitudeE6(); 
outToServer.writeBytes(sentenceX + " " + sentenceY + '\n'); 

String interesting = inFromServer.readLine(); 
String[] holder = interesting.split("\\s+"); 

String title = inFromServer.readLine(); 
String[] titleHolder = title.split("\\s+"); 

达尔维克显示器正在打印作为误差:

TCP Error: java.lang.ArrayIndexOutOfBoundsException 

的程序工作,但它不接收第二out.println();

+4

仔细查看ArrayIndexOutOfBoundsException发生的行(堆栈跟踪会告诉您在哪一行它发生哪个源文件的代码)。你正在访问一个有无效索引的数组。找出索引无效的原因。添加一些日志语句,以确定它在做什么。 – Jesper

回答

0

只是一个猜测:第二个inFromServer.readLine()电话可能太快。第二个数据包此时可能不会被发送/接收......也许检查字符串是否为ready()可能是个好主意

+0

如果字符串没有准备好,该怎么办? – iie

+1

也许你只需要检查'inFromServer.readLine()'是否返回NULL ...... – xmoex