ServerSocket의 accept() 메서드 중단
멀티 스레드 애플리케이션에서는 accept()와 같은 장기 실행 차단 작업을 중단해야 하는 경우가 많습니다. 중요한 이벤트에 대응합니다. Accept()가 새 클라이언트 연결을 기다리는 ServerSocket의 경우 종료 요청을 정상적으로 처리하려면 중단이 필수적입니다.
accept()를 중단하는 효율적인 방법 중 하나는 다른 스레드에서 기본 소켓을 닫는 것입니다. close()가 호출되면 동일한 소켓에서 활성 또는 보류 중인 accept() 호출이 중단됩니다. 이는 close() 작업이 SocketChannel의 닫힌 플래그를 설정하여 더 이상 소켓 작업에 사용할 수 없음을 알리기 때문입니다.
다음은 이 접근 방식을 보여주는 코드 예제입니다.
<code class="java">public class Main { public static void main(String[] args) { // Initialize ServerSocket and Admin thread ServerSocket serverSocket = new ServerSocket(); Thread adminThread = new Thread(() -> { // Process commands from the Admin thread while (true) { String command = readCommandFromConsole(); if ("exit".equals(command)) { // Interrupt the main thread by closing the ServerSocket serverSocket.close(); } } }); adminThread.start(); // Main server loop while (true) { try { // Accept client connections Socket clientSocket = serverSocket.accept(); } catch (SocketException e) { // Socket was closed, indicating an interruption from the Admin thread break; } } // Shutdown gracefully adminThread.join(); System.out.println("Server exited gracefully"); } }</code>
여기서 예를 들어, 메인 스레드는 accept()를 사용하여 클라이언트 연결을 기다리는 루프에 들어갑니다. 동시에 관리 스레드는 동시에 실행되어 명령을 기다립니다. 관리 스레드에서 "exit" 명령을 받으면 서버 소켓이 닫힙니다. 이 작업은 메인 스레드의 accept() 호출을 중단하여 대기 루프에서 벗어나 종료 프로세스를 진행할 수 있도록 합니다.
accept()를 중단하기 위해 close() 메서드를 사용한다는 점에 유의하는 것이 중요합니다. )은 잠재적인 경쟁 상황을 피하기 위해 신중하게 수행되어야 합니다. 클라이언트 연결이 진행되는 동안 accept() 호출이 중단되면 연결이 끊어지거나 예기치 않은 동작이 발생할 수 있습니다. 가장 좋은 방법은 서버 소켓에 대한 독점적인 액세스를 보장하기 위해 accept() 호출 주위에 동기화된 블록을 사용하는 것이 좋습니다.
위 내용은 종료 요청을 적절하게 처리하기 위해 다중 스레드 환경에서 ServerSocket의 `accept()` 메서드를 어떻게 중단할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!