每当尝试从套接字读取输入流时,我都会挂起一个套接字客户端。

DataInputStream dis = new DataInputStream(socket.getInputStream());

int singleByte;
while((singleByte = dis.read()) != -1) {  //<-- hangs here
    char c = (char)singleByte;
    // append character
    message_string += c;
}



挂在while((singleByte = dis.read()) != -1) {


我已经确认服务器正在回显我以原始ASCII发送的内容。

我不明白什么?尝试读取服务器响应时为什么挂起?

服务器端(处理请求):

class HandleInputBuffer implements Runnable {

    private String msg = "";
    private String response = "8";

    public HandleInputBuffer(String str) {
        this.msg = str;
    }

    @Override
    public void run() {

        String exception_msg = "";

        // process incoming message
        try {
            if(msg!=null){
                if(msg.length()>0){

                    // create and send reply
                    String response = "8";

                    // ****************************
                    // create and send response
                    // ****************************
                    try {

                        response = msg;
                        output_stream = new DataOutputStream(client_socket.getOutputStream());
                        output_stream.writeInt(response.getBytes("US-ASCII").length);
                        output_stream.write(response.getBytes("US-ASCII"));
                        output_stream.flush();
                        output_stream.close();

                        //client_socket.shutdownOutput();
                        client_socket.close();


                    } catch (IOException e) {
                        e.printStackTrace();
                        try{output_stream.flush();} catch (IOException e1) {}
                        try {client_socket.close();} catch (IOException e1) {}
                        try {updateConversationHandler = new Handler();} catch (Exception e1) {}

                        return;
                    }

                }

            }
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

}


客户端重构-此代码挂起int length = dis.readInt();

InetAddress serverAddr = InetAddress.getByName(edit_ip_address.getText().toString());

if(socket == null){
     socket = new Socket(serverAddr, Integer.parseInt(edit_port.getText().toString()));
}

// send bytes
output_stream = new DataOutputStream(socket.getOutputStream());
output_stream.write(command.getBytes("US-ASCII"));

DataInputStream dis = new DataInputStream(socket.getInputStream());

int length = dis.readInt();
byte[] buffer = new byte[length];  //<-- OutOfMemoryException
dis.readFully(buffer);
for (byte b:buffer){
     char c = (char)b;
     message_string += c;
}

最佳答案

该循环将一直阻塞,直到对等方关闭连接。

因此,对等方没有关闭连接。

编辑读取发送内容的正确方法如下:

您需要阅读所写的整数字。它不会通过available():神奇地出现

int length = dis.readInt();
byte[] buffer = new byte[length];
dis.readFully(buffer);


但是我假设数据是字符数据,所以我放弃了发送和接收代码并使用readUTF()/writeUTF()。如果不是,则不应将其组装为String。

编辑2证明这有效:

Client.java:

import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.Socket;

public class Client
{
    public static void  main(String[] args) throws IOException
    {
        try (Socket s = new Socket("localhost", 9999))
        {
            DataOutputStream    out = new DataOutputStream(s.getOutputStream());
            out.writeInt(1);
            out.writeBytes("8");
            DataInputStream in = new DataInputStream(s.getInputStream());
            int count = in.readInt();
            System.out.println("Reading "+count+" bytes");
            byte[] buffer = new byte[count];
            in.readFully(buffer);
            System.out.write(buffer, 0, count);
            System.out.println();
        }
    }
}


Server.java:

import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;

public class Server
{
    public static void  main(String[] args) throws IOException
    {
        try (ServerSocket ss = new ServerSocket(9999))
        {
            try (Socket s = ss.accept())
            {
                DataInputStream in = new DataInputStream(s.getInputStream());
                int count = in.readInt();
                System.out.println("Reading "+count+" bytes");
                byte[] buffer = new byte[count];
                in.readFully(buffer);
                System.out.write(buffer, 0, count);
                System.out.println();
                DataOutputStream    out = new DataOutputStream(s.getOutputStream());
                out.writeInt(count);
                out.write(buffer, 0, count);
            }
        }
    }
}


如果不是,则表示您正在从套接字读取其他内容,或向其写入其他内容,或者未运行您认为正在运行的代码。

关于java - DataInputStream在读取时挂起,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34639805/

10-09 06:20
查看更多