Java 为什么socketRead0使线程处于可运行状态

Java 为什么socketRead0使线程处于可运行状态,java,multithreading,sockets,Java,Multithreading,Sockets,我用Java编写了一个简单的ECHO协议服务器,使用Thread 很简单: ServerSocket serverSocket = new ServerSocket(7000, 0, InetAddress.getByName("127.0.0.1")); while (true) { Socket socket = serverSocket.accept(); new Thread(() -> { try (Socket s = socket;

我用Java编写了一个简单的ECHO协议服务器,使用
Thread

很简单:

ServerSocket serverSocket = new ServerSocket(7000, 0, InetAddress.getByName("127.0.0.1"));
while (true) {
    Socket socket = serverSocket.accept();
    new Thread(() -> {
        try (Socket s = socket;
             BufferedReader in = new BufferedReader(new InputStreamReader(s.getInputStream()));
             BufferedWriter out = new BufferedWriter(new OutputStreamWriter(s.getOutputStream()))) {
            String inputLine;
            while ((inputLine = in.readLine()) != null) {
                out.write(inputLine + '\n');
                out.flush();
            }
        } catch (IOException e) {
        }
    }).start();
}
线程正在
inputLine=in.readLine()
上等待客户端的输入。 但是我通过
jstack
发现所有工作线程都处于
RUNNABLE
状态,我认为它们可能处于
WAITING
状态

线程在等待数据到达时被阻塞,但为什么在这里它是可运行的

以下是
jstack
输出:

"Thread-0" #10 prio=5 os_prio=31 tid=0x00007f9f8282e800 nid=0x1307 runnable [0x000070000623a000]
 java.lang.Thread.State: RUNNABLE
  at java.net.SocketInputStream.socketRead0(Native Method)
  at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
  at java.net.SocketInputStream.read(SocketInputStream.java:170)
  at java.net.SocketInputStream.read(SocketInputStream.java:141)
  at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284)
  at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326)
  at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178)
  - locked <0x000000076b167a18> (a java.io.InputStreamReader)
  at java.io.InputStreamReader.read(InputStreamReader.java:184)
  at java.io.BufferedReader.fill(BufferedReader.java:161)
  at java.io.BufferedReader.readLine(BufferedReader.java:324)
  - locked <0x000000076b167a18> (a java.io.InputStreamReader)
  at java.io.BufferedReader.readLine(BufferedReader.java:389)
  at EchoServer3.lambda$main$0(EchoServer3.java:20)
“线程-0”#10优先级=5 os_优先级=31 tid=0x00007f9f8282e800 nid=0x1307可运行[0x000070000623a000]
java.lang.Thread.State:可运行
位于java.net.SocketInputStream.socketRead0(本机方法)
位于java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
位于java.net.SocketInputStream.read(SocketInputStream.java:170)
位于java.net.SocketInputStream.read(SocketInputStream.java:141)
位于sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284)
位于sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326)
位于sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178)
-锁定(java.io.InputStreamReader)
位于java.io.InputStreamReader.read(InputStreamReader.java:184)
在java.io.BufferedReader.fill中(BufferedReader.java:161)
在java.io.BufferedReader.readLine(BufferedReader.java:324)
-锁定(java.io.InputStreamReader)
位于java.io.BufferedReader.readLine(BufferedReader.java:389)
在EchoServer3.lambda$main$0(EchoServer3.java:20)

等待
意味着一个Java线程正在等待另一个Java线程释放Java对象锁


Java不知道操作系统块、锁或调度。因此,一个Java线程在等待输入时可能被阻塞的事实并不影响Java对其状态的查看。

等待
意味着一个Java线程正在等待另一个Java线程释放Java对象锁

Java不知道操作系统块、锁或调度。因此,Java线程在等待输入时可能被阻塞的事实并不影响Java对其状态的看法