Programa - PowerPoint PPT Presentation

About This Presentation
Title:

Programa

Description:

Programa o com Threads Threads Java como um Estudo de Caso Estados de uma Thread Java O diagrama seguinte mostra os estados nos quais uma thread Java pode estar e ... – PowerPoint PPT presentation

Number of Views:46
Avg rating:3.0/5.0
Slides: 18
Provided by: bosco
Category:
Tags: programa | threads

less

Transcript and Presenter's Notes

Title: Programa


1
Programação com Threads
  • Threads Java como um
  • Estudo de Caso

2
Estados de uma Thread Java
  • O diagrama seguinte mostra os estados nos quais
    uma thread Java pode estar e alguns métodos que
    podem ser usados para mudar de um estado para
    outro.

3
Ciclo de Vida de Java Threads
NEW
READY
TIME-WAITING
FINISHED
WAITING
RUNNING
BLOCKED
DEAD
4
Nova Thread - NEW
  • Inicialização da thread
  • Feita através do construtor Thread().
  • class MyThreadClass extends Thread ...
    ... MyThreadClass myThread new
    MyThreadClass()

5
NEW ? RUNNABLE (Executável)
  • Neste estado de NEW (Nova), nenhum recurso do
    sistema foi alocado para a thread, ainda.
  • Assim, a partir daqui, tudo que você pode fazer é
    um start()para ativar a thread, e a thread passa
    a um estado RUNNANLE (estado Ready), ou um
    stop(), para "matá-lo".
  • A chamada de qualquer outro método não faz
    sentido e levantará a exceção IllegalThreadStateEx
    ception.

6
Estado de RUNNABLE (Pronto)
  • Quando uma thread entra pela primeira vez no
    estado RUNNABLE a partir do estado NEW, ela vai
    para o estado de Ready, que a JVM não vê.
  • Este é o estado em que o thread está pronta para
    rodar, mas não tem os recursos do SO para ser
    executada.
  • O método start()requisita os recursos do SO,
    necessários para rodar a thread e chama o seu
    método run().
  • O método run() é a "alma" de uma thread. É neste
    método que definimos o que o thread vai executar.
  • Thread myThread new MyThreadClass()
    myThread.start()

7
Estado Ready
  • Falamos em Ready (Pronto), porque a thread pode
    não estar realmente sendo executada no estado de
    Ready (Pronto).
  • Imagine um computador com um único processador -
    seria impossível executar todos as threads
    prontas" ao mesmo tempo.
  • O que ocorre é que o processador deve ser
    escalonada entre as vários threads.

8
Estado Running (Executando)
  • Quando o Scheduler escalona uma thread para o
    processador, esta passa ao estado de Running.
  • Quando uma thread está em Running (Executando),
    as instruções do seu método run() estão sendo
    executadas pelo processador.

9
Running ? Ready
  • Se uma thread está no estado Running, ela pode
    passar ao estado Ready , se um método
    yield()for executado.
  • Ou pode passar do estado Running para o estado
    NOT-RUNNABLE.

10
Em NOT-RUNNABLE
  • O estado NOT-RUNNABLE significa que a thread está
    impedido de executar por alguma razão.
  • Existem 3 maneiras através das quais um thread ir
    para um estado NOT-RUNNABLE
  • A thread executa um método sleep()
  • O thread bloqueia, esperando por I/O.
  • O thread usa seu método wait() para esperar por
    uma condição.

11
Estados NOT-RUNNABLE (Suspenso)
  • Dormindo TIME-WAITING - em espera
    temporizada a thread executou o método sleep().
    Para retornar de Dormindo, tempo tem que
    terminar.
  • Bloqueado BLOCKED - aguarda I/O I/O
    precisa ser completado. Para retornar de I/O, o
    I/O tem que terminar.
  • Em Espera - WAITING - a thread executou um
    método wait() aguarda
    uma condição ser satisfeita o objeto que a
    "segura" precisa liberá-la, através de um método
    notify() ou de um método notifyAll()

12
Saindo de NOT-RUNNABLE
  • Para cada forma de entrar no estado Non-Runnable,
    alguma forma específica fará o thread retornar
    para o estado Runnable.

13
Métodos de Gerenciamento de Threads
  • Thread(ThreadGroup group, Runnable target, String
    name)Cria uma nova thread no estado NEW, a qual
    pertencerá a group e será identificado como name
    a thread executará o método run() de target.
  • setPriority(int newPriority)
  • getPriority()
  • Configura e retorna a prioridade da thread.
  • run() a thread executa o método run() de seu
    objeto de destino, caso ele tenha um caso
    contrário, ela executa seu próprio método run()
    (Thread implementa Runnable).

14
Métodos de Gerenciamento de Threads
  • start() Muda o estado da thread de NEW para
    RUNNABLE.
  • sleep(int millisecs) Passa a thread para o
    estado TIME- WAITING.
  • yield() Libera o processador. Passa a thread do
    estado RUNNING para o estado READY.
  • destroy() Termina (destrói) a thread.

15
Métodos de Sincronização de Threads
  • wait(long millisecs, int nanosecs) Bloqueia uma
    thread até uma chamada feita por notify(),
    notifyAll(), ative a thread.
  • notify(), notifyAll() Ativa, respcitvamente, uma
    ou mais threads que tenham chamado wait().
  • join(int millisecs) Bloqueia uma thread
    chamadora até o término de
    uma outra thread.
  • interrupt() Ativar prematuramente uma thread que
    esteja em espera.

16
Arquitetura do Pool de Threads
  • Uma das possíveis arquiteturas baseadas em
    Threads, chama-se Pool de Threads.
  • Um Pool de Threads é criado e gerenciado quando o
    aplicativo é executado.

17
Pool de Threads
  • Em sua forma mais simples, o aplicativo cria um
    Pool de Threads Trabalhadoras para processar os
    pedidos de execução de tarefas programadas com
    threads.
  • No caso de haver um número fixo de threads
    trabalhadoras, com menos threads do que o número
    de threads que pedem execução, uma thread
    requerendo execução será colocada numa fila e
    atribuída à primeira thread trabalhadora que
    completar sua tarefa.
Write a Comment
User Comments (0)
About PowerShow.com