Ocp, jse 6 programmer (1 z0 851) - guia practica 4 de 7(concurrencia) v1

445 visualizaciones

Publicado el

0 comentarios
1 recomendación
Estadísticas
Notas
  • Sé el primero en comentar

Sin descargas
Visualizaciones
Visualizaciones totales
445
En SlideShare
0
De insertados
0
Número de insertados
10
Acciones
Compartido
0
Descargas
44
Comentarios
0
Recomendaciones
1
Insertados 0
No insertados

No hay notas en la diapositiva.

Ocp, jse 6 programmer (1 z0 851) - guia practica 4 de 7(concurrencia) v1

  1. 1. Oracle Certified Professional, Java SE 6 Programmer (1Z0-851) - Guía practica 4 de 7.Esta guía práctica cubre la siguiente sección del examen:Sección 4: Concurrencia4.1. Escribir código para definir, instanciar e iniciar hilos nuevos usando java.lang.Thread o java.lang.Runnable.4.2. Reconocer el estado en el cual el hilo puede existir e identificar caminos en los cuales un hilo puede transitar de un estado a otro.4.3. Dado un escenario, escribir código que haga apropiado uso del bloqueo de objetos para proteger variables estáticas o de instancia del problema del acceso concurrente.Oscar Vásquez Flores (eoscarvf@gmail.com )
  2. 2. Oracle Certified Professional, Java SE 6 Programmer (1Z0-851) - Guía practica 4 de 7.4.1. Escribir código para definir, instanciar e iniciar hilos nuevos usandojava.lang.Thread o java.lang.Runnable.❑ Los hilos pueden ser creados por extender la clase Thread y sobre escribir el metodopublic void run().❑ Los hilos también pueden ser creado por llamar al constructor de Thread que tienecomo argumento a un Runnable. El objeto Runnable se dice que es el objetivo del hilo.❑ Se puede llamar a start() en un objeto Thread solamente una vez. Si se invoca más deuna vez se lanza RuntimeException.❑ Es legal crear varios objetos Thread utilizando el mismo objeto Runnable comoobjetivo.❑ Cuando un objeto Thread es creado no se inicia de forma automática, es necesarioinvocar al metodo start() para que se ejecute. Cuando un objeto Thread existe pero no sea iniciado, este se encuentra en el estado new, el cual es diferente al estado alive.4.2. Reconocer el estado en el cual el hilo puede existir e identificar caminos en los cuales un hilo puede transitar de un estado a otro.❑ Una vez que es iniciado una thread nueva, esta siempre entra al estado runnable.❑ El thread scheduler puede mover una thread entre el estado runnable y el estadorunning.❑ Para un maquina típica de un solo procesador, únicamente una thread puede esta enestado running en un tiempo, aunque varias threads pueden estar en estado runnable.❑ No hay garantía en el orden en el cual las threads que han sido iniciadas, determine elorden en la cual ellas se ejecuten.❑ No hay garantía que los threads se turnen de forma equivalente. Esto depende delthread scheduler y según lo determinado por cada implementación de JVM.Si se desea una garantía que los threads se turnen de forma independiente a la JVM, sepuede utilizar el metodo sleep(), esto impide que el thread acapare el proceso deejecución mientras que otra thread no tiene asignación de proceso. Aunque en la mayoríade los casos basta con invocar al metodo yield() para que los threads trabajen bien juntos.❑ Una thread que esta en estado running puede entrar al estado blocked/waiting porinvocación al metodo wait(), sleep() o join().❑ Una thread en estado running puede entrar al estado blocked/wating porque no puedeadquirir el control de bloqueo de un bloque de código sincronizado.❑ Cuando el sleep() o wait() a terminado, o un objeto bloqueado se convierte endisponible, el thread puede únicamente reingresar al estado runnable.❑ Una thread en estado dead no puede ser iniciada otra vez.❑ Se manda a dormir a la thread para demorar su ejecución por un periodo de tiempo ylos bloqueos no son liberados durante este tiempo.Oscar Vásquez Flores (eoscarvf@gmail.com )
  3. 3. Oracle Certified Professional, Java SE 6 Programmer (1Z0-851) - Guía practica 4 de 7.❑ Se garantiza que el tiempo para dormir de un thread sea por lo menos el tiempo que seindique en el argumento de sleep(), al menos que sea interrumpido. Perro no se garantizaen que momento esa thread volverá a estar en estado running.❑ El metodo sleep() es static el cual provoca que la thread duerma, estando en estadorunning. Una thread no puede invocar el metodo sleep() de otro thread, la invocaciónsiempre es desde la misma clase.❑ El metodo setPriority() es utilizado en un objeto Thread para dar una prioridad de1(Bajo) a 10(Alto), aunque las prioridades no son garantizadas y no todos los JVMsreconocen estos 10 niveles de prioridad, algunos niveles pueden ser tratados comoiguales.❑ Si no se modifica de forma explicita la prioridad de una thread, es igual a la prioridad dela thread que la creo.❑ El metodo yield() puede causar que una thread deje de correr, si hay threads enestado runnable de la misma prioridad, no hay garantía de que esto pase, y no haygarantía que cuando el thread deje de correr y regrese al estado runnable, sea otra threadla que se coloque en estado running (Puede volver a ser la misma).Una thread puede ejecutar el yield() e inmediatamente reingrese al estado running.❑ Lo más parecido a una garantía es que en cualquier tiempo dado cuando una threadesta corriendo usualmente no tiene una prioridad mas bajo que los threads que están enestado runnable. Si una thread de prioridad baja esta corriendo cuando una thread deprioridad alta entra al estado runnable, el JVM usualmente se adelanta a la ejecución debaja prioridad y colocara al thread de alta prioridad en running.❑ Cuando una thread1 invoca al metodo join() de otra thread2, la thread1 que estacorriendo espera hasta que la thread2 se haya completado. Es decir el metodo join() ledice a la thread2 que queremos juntarnos al finalizar esta y que nos avise, entonces por elmomento la thread1 puede entrar al estado runnable.4.3. Dado un escenario, escribir código que haga apropiado uso del bloqueo de objetos para proteger variables estáticas o de instancia del problema del acceso concurrente.❑ Los métodos synchronized permiten que solo una thread esta trabajando con esemetodo en un determinado momento.❑ synchronized se utiliza para marcar metodos y bloques de código (es decir solo unaparte del cuerpo de un metodo).❑ Para sincronizar un bloque de código (Es decir solo una pequeña porción del cuerpodel metodo), se debe especificar un argumento al synchronized, el cual debe ser el objetocuyo bloqueo queremos sincronizar.❑ Si un objeto tiene partes que no están marcadas con synchronized esas si pueden seraccedidas por varias threads de forma simultanea.❑ Cuando una thread es enviada a dormir, lo que tenga bloqueado no estará disponiblepara otras threads.❑ Los métodos static pueden ser synchronized, utilizando el bloqueo de unainstancia de java.lang.Class representando la clase.Oscar Vásquez Flores (eoscarvf@gmail.com )
  4. 4. Oracle Certified Professional, Java SE 6 Programmer (1Z0-851) - Guía practica 4 de 7.❑ Un deadlocking es cuando la ejecución de una thread se queda a la mitad y el códigoesta esperando que el bloqueo sea removido de algún objeto.❑ Deadlocking puede ocurrir cuando un objeto bloqueado intenta acceder a otro objetobloqueado el cual intenta accede al primer objeto bloqueada. En otras palabras, ambosthreads están esperando que el otro libere el objeto bloqueado, de esta forma el bloqueonunca se libera.❑ Un Deadlocking es algo incorrecto, se debe evitar esto.❑ El metodo wait() permite decir a un hilo:No hay nada que yo pueda hacer por ahora, entonces colócame en un pool de espera ynotifícame cuando algo pase y yo este involucrado.Básicamente un wait() significa:Mantenme en espera en el pool o agrégame en la lista de espera.❑ El metodo notify() es usado para enviar una señal a una y solo a una de las threadsque están esperando por el mismo objeto bloqueado.❑ El metodo notify() no puede especificar cual thread que espera será notificada.❑ El metodo notifyAll() trabaja igual que notify(), pero envía la señal a todos las threadsque esperan sobre el objeto.❑ Los tres métodos: wait(), notify() y notifyAll() deberán ser invocados dentro de uncontexto synchronized. Una thread invoca a un wait() o notify() sobre una objetoparticular, el thread deberá sostener el bloqueo sobre el objeto.Oscar Vásquez Flores (eoscarvf@gmail.com )

×