[问题] 简单的UDP程式一直报错

楼主: liataian (T-PANY FOREVER)   2015-02-02 19:21:56
大家好,是这样的,我想写一个简单的UDP client/server程式,参考过网上很多范例,不过一直卡在某个环节让我无法进行下去,以下是程式:
Client端:每秒会送出一个时间封包给Server端,总共送十个封包
import java.io.*;
import java.net.*;
public class Client {
public static void main(String[] args) throws IOException{
SocketAddress addr = new InetSocketAddress("192.168.1.100", 8888);
for(int i=0; i<=10; i++){
Long client_time = System.currentTimeMillis();
byte[] bdata = client_time.toString().getBytes();
DatagramPacket pack = new DatagramPacket(bdata, bdata.length, addr);
DatagramSocket dest = new DatagramSocket();
dest.send(pack);
try{
Thread.sleep(1000);
}catch(Exception e){
System.out.println(e);
}
}
}
}
Server端:接收Client端的时间封包,并将“Server端这边收到封包当下的时间”与“封包内Client端那边的时间”相减
import java.io.*;
import java.net.*;
public class Server {
public static void main(String[] args) throws IOException{
byte[] buffer = new byte[50];
DatagramPacket pack = new DatagramPacket(buffer, buffer.length);
DatagramSocket dest = new DatagramSocket(8888);
while(true){
System.out.println("等待封包传进"+dest.getLocalPort());
dest.receive(pack);
long server_time = System.currentTimeMillis();
String data = new String(pack.getData());
try{
long client_time = Long.valueOf(data); //错误的地方
//System.out.println(client_time);
long difference = server_time - client_time;
System.out.println(difference);
} catch(NumberFormatException e){
System.out.println(e);
}
}
}
}
错误在这一行:long client_time = Long.valueOf(data);
每当要执行这一行时就会遇到“NumberFormatException”这个例外。
我查过原因大概是,将字串转成长整数时,字串内有包含“非数字”才会导致出错,可是我将client_time印出来的确都是数字,实在看不出哪里有错...卡这边卡了一个下午...
另外Long.parseLong()这方法也试过了还是不行
我的环境是Mac OSX,Client跟Server的程式都只在同一台机子上跑而已,有请版友帮忙提点一下,感谢...
作者: ssccg (23)   2015-02-02 19:35:00
你该检查的是data里面是什么
作者: sbrhsieh (十年一梦)   2015-02-02 19:35:00
new String(pack.get Data(),0,pack.getLength())
作者: ssccg (23)   2015-02-02 19:36:00
data是整个buffer,不是只有你传的那个数字长度
楼主: liataian (T-PANY FOREVER)   2015-02-02 19:37:00
ssccg大,我试过印出data,就是一个从epoch至今的时戳,sorry更正, 如果data是整个buffer,那就是buffer内有问题是吗@@?
作者: sbrhsieh (十年一梦)   2015-02-02 19:39:00
再者,DatagramPacket要重复使用,每次都要透过 setData去重新设定 buffer。
楼主: liataian (T-PANY FOREVER)   2015-02-02 19:42:00
sbrhsieh大,用你的方法好像成功了@@ 加了后面那串是做了什么事呢?!谢谢刚刚搞懂了!!

Links booklink

Contact Us: admin [ a t ] ucptt.com