java.net.SocketException引起这个异常的原因主要是由于客户端和服务器端有一端突然断开,导致另一端抛出这个异常。
java.net.BindException创建socket时如果端口被占用则抛出此异常。
奇怪的是,在有的机器上端口被占用时不会抛出BindException,而是抛出java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind。
在网上找了一圈 暂时没有找到这个问题的原因,可能和操作系统本身的tcp/ip协议有关系,目前发现在win7系统上有这个问题。
如果程序里只有创建socket服务的代码,其代码本身的逻辑就是如果创建socket服务失败就换个端口重新创建直到创建成功为止。 那么如果这里捕获到了java.net.SocketException这个异常,也可以当作端口被占用的逻辑来处理。
- public GetScreenServer(int port,InputStream inputstream,OutputStream outputstream) {
- this.outputstream = outputstream;
- this.inputstream = inputstream;
- this.serverPort =port;
- while (serverSkt == null) {
- try {
- serverSkt = new ServerSocket(serverPort);
- } catch (BindException be) {
- //be.printStackTrace();
- com.hjdf.calis.cvrs.util.CvrsSystem.println("error bin serverPort "+serverPort);
- serverPort++;
- }catch(SocketException e){
- /**
- * java.net.SocketException引起这个异常的原因主要是由于客户端和服务器端有一端突然断开,导致另一端抛出这个异常。
- * 但是在有的机器上端口被占用时不会抛出BindException,而是抛出java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind
- * 暂时没有找到这个问题的原因,可能和操作系统本身的tcp/ip协议有关系,目前发现在win7系统上有这个问题。
- * 另由于这里的代码只有创建ServerSocket,其本身的逻辑就是如果创建失败就换个端口重新创建直到创建成功为止。
- * 故这里也可以当作端口被占有的逻辑处理。
- */
- com.hjdf.calis.cvrs.util.CvrsSystem.println("error SocketException: "+serverPort);
- serverPort++;
- }catch(IOException e) {
- System.err.println(e.toString());
- }
- }
- }
转载于:https://blog.51cto.com/fluagen/425642