Программирование на сокете: кажется, что входной поток блокирует выходной поток - PullRequest
1 голос
/ 18 марта 2011

Я пытаюсь закодировать коммуникационное приложение сервер-клиент, которое использует два отдельных потока, один для ввода и один для вывода.У меня странная проблема «тупика», хотя: когда один поток читает ввод, но клиент ничего не отправил, поток останавливается (так как он ожидает ввода).Однако по какой-то причине, хотя поток ввода заблокирован, поток вывода не может ничего записать.

Это показано в следующем примере кода:

import java.io.*;
import java.net.*;
import java.nio.*;
import java.nio.channels.*;

public class TestServer {
    public static void main(String... args) throws IOException {

        /* Creates a server socket that lurks about our port waiting for connections */
        ServerSocketChannel serverChannel = ServerSocketChannel.open();
        serverChannel.configureBlocking(false);
        serverChannel.socket().bind(new InetSocketAddress(4114));


        while(true){
            SocketChannel connectionChannel = serverChannel.accept();
            if(connectionChannel != null){
                final Socket connection = connectionChannel.socket();


                new Thread(){
                    public void run(){
                        try {
                            System.out.println("READING");
                            System.out.flush();
                            // If the next line is commented out, nothing blocks
                            connection.getInputStream().read();
                            System.out.println("DONE READING");
                            System.out.flush();
                        } catch (Exception e){
                            e.printStackTrace();
                        }
                    }
                }.start();

                new Thread(){
                    public void run(){
                        try {
                            System.out.println("WRITING");
                            System.out.flush();
                            new DataOutputStream(connection.getOutputStream()).writeBytes("AUGH!!!");
                            //connection.getOutputStream().write(5);
                            System.out.println("DONE WRITING");
                            System.out.flush();
                        } catch (Exception e){
                            e.printStackTrace();
                        }
                    }
                }.start();

                break;
            }
        }
    }
}

И код клиента:

import java.net.*;
import java.io.*;

public class TestClient {

    public static void main(String... args) throws IOException {
        Socket connection = new Socket("127.0.0.1", 4114); 
        while(true){
            System.out.println(connection.getInputStream().read());
        }
    }

}

Пример кода выше блоков, но если строка на сервере закомментирована, это не так.Это почему?Разве сокет ограничен только ожиданием ввода / вывода одновременно?Что происходит?

1 Ответ

2 голосов
/ 18 марта 2011

Я не уверен, почему вы видите это, но это как-то связано с использованием каналов.

Если вы замените этот код на

ServerSocket ss = new ServerSocket(4114);
Socket connection = ss.accept();

будет работать как хочешь.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...