2015-04-20 15:36:01 -07:00
|
|
|
//: concurrency/CloseResource.java
|
|
|
|
// Interrupting a blocked task by
|
|
|
|
// closing the underlying resource.
|
2015-05-05 11:20:13 -07:00
|
|
|
// {TimeOutDuringTesting}
|
2015-04-20 15:36:01 -07:00
|
|
|
import java.net.*;
|
|
|
|
import java.util.concurrent.*;
|
|
|
|
import java.io.*;
|
|
|
|
import static net.mindview.util.Print.*;
|
|
|
|
|
|
|
|
public class CloseResource {
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
ExecutorService exec = Executors.newCachedThreadPool();
|
|
|
|
ServerSocket server = new ServerSocket(8080);
|
2015-05-05 14:05:39 -07:00
|
|
|
try (InputStream socketInput = new Socket("localhost", 8080).getInputStream()) {
|
|
|
|
exec.execute(new IOBlocked(socketInput));
|
|
|
|
exec.execute(new IOBlocked(System.in));
|
|
|
|
TimeUnit.MILLISECONDS.sleep(100);
|
|
|
|
print("Shutting down all threads");
|
|
|
|
exec.shutdownNow();
|
|
|
|
TimeUnit.SECONDS.sleep(1);
|
|
|
|
print("Closing " + socketInput.getClass().getName());
|
|
|
|
socketInput.close(); // Releases blocked thread
|
|
|
|
}
|
2015-04-20 15:36:01 -07:00
|
|
|
TimeUnit.SECONDS.sleep(1);
|
|
|
|
print("Closing " + System.in.getClass().getName());
|
|
|
|
System.in.close(); // Releases blocked thread
|
|
|
|
}
|
2015-05-18 23:05:20 -07:00
|
|
|
} /* Output: (85% Match)
|
2015-04-20 15:36:01 -07:00
|
|
|
Waiting for read():
|
|
|
|
Waiting for read():
|
|
|
|
Shutting down all threads
|
|
|
|
Closing java.net.SocketInputStream
|
|
|
|
Interrupted from blocked I/O
|
|
|
|
Exiting IOBlocked.run()
|
|
|
|
Closing java.io.BufferedInputStream
|
|
|
|
Exiting IOBlocked.run()
|
|
|
|
*///:~
|