A distinção sutil entre notify() e notifyAll()
Embora a principal diferença entre notify() e notifyAll() esteja no número de threads em espera que eles despertam (um contra todos), isso levanta outra questão:
Por que um thread sempre readquire o bloqueio do objeto?
Em geral Nesse caso, notify() e notifyAll() não especificam qual thread em espera será selecionado para readquirir o bloqueio. A JVM ou o agendador de thread do sistema faz essa seleção, que pode ser não determinística.
A necessidade de notifyAll()
No entanto, usar notify() em determinados cenários pode levar a um impasse, conforme ilustrado pelo exemplo a seguir:
Producer/Consumer Class with notify()
public class ProducerConsumer { private final int MAX_SIZE = 1; // Buffer size private List
Cenário de impasse:
Como um como resultado, todos os três threads estão aguardando indefinidamente, levando a um impasse. notify() no código do produtor/consumidor. Isso garante que todos os threads em espera sejam ativados, evitando deadlocks.
Recomendação:
Para a maioria dos cenários, notifyAll() é o método preferido, pois evita possíveis deadlocks. Se o cenário específico exigir a ativação de apenas um thread de espera específico, então notify() poderá ser usado com cautela.
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3