여러 대기열에 실행기 서비스에 의해 순차적으로 실행될 작업이 보관되어 있는 시나리오에서 차단 작업은 과도한 스택 공간을 소비할 수 있습니다. 이 문제를 완화하려면 비차단 접근 방식이 필요합니다.
한 가지 해결 방법은 결과를 처리하고 필요한 매개변수를 전달하는 메서드로 콜백 인터페이스를 정의하는 것입니다. 이 인터페이스는 Runnable 작업에 대한 래퍼 클래스에서 구현될 수 있으며, 그런 다음 실행기 서비스에 제출됩니다. 작업이 완료되면 콜백 인터페이스가 호출됩니다.
interface Callback { void complete(); } class CallbackTask implements Runnable { private final Runnable task; private final Callback callback; CallbackTask(Runnable task, Callback callback) { this.task = task; this.callback = callback; } public void run() { task.run(); callback.complete(); } }
또는 Java 8에서는 비동기 작업 구성 및 조건부 처리를 위한 메커니즘을 제공하는 CompletableFuture를 도입합니다. 다음은 CompletableFuture를 사용하는 예입니다.
CompletableFuture<String> f = CompletableFuture.supplyAsync(() -> ExampleService.work()); f.thenAccept(listener::notify);
이 예에서 exampleService.work()는 비동기적으로 실행되는 작업입니다. 알림 메소드는 작업이 완료될 때 호출되는 콜백입니다.
이러한 기술을 사용하면 작업을 차단하지 않고 실행기 서비스에 제출할 수 있으므로 스택 공간 소모를 피하면서 대규모 대기열을 효율적으로 처리할 수 있습니다.
위 내용은 Java 실행자가 차단하지 않고 비동기 작업 완료 알림을 어떻게 처리할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!