Documentos de Académico
Documentos de Profesional
Documentos de Cultura
VILLAHERMOSA
4ER SEMESTRE
3_1 Hilos
PERIDO ENERO-AGOSTO 2024
UNIDAD 3
1
Un sistema operativo puede realizar multiprogramación al reasignar rápidamente
tiempos de la CPU entre muchos programas, dando el aspecto de paralelismo, al
ejecutarse concurrentemente. Aunque el verdadero paralelismo se logra con una
computadora con varias CPU.
Java soporta varios hilos de ejecución. Un proceso de Java puede crear y manejar,
dentro de sí mismo, varias secuencias de ejecución concurrentes o paralelos. Cada
una de estas secuencias es un hilo independiente y todos ellos comparten tanto el
espacio de dirección como los recursos del sistema operativo. Por lo tanto, cada hilo
puede acceder a todos los datos y procedimientos del proceso, pero tiene su propio
contador de programa y su pila de llamadas a métodos.
Todos los programas que hemos aprendido a desarrollar se ejecutan en forma
secuencial, por ejemplo, cuando llamamos a un método desde la main hasta que
esta no finalice no continúan ejecutándose las instrucciones de la main.
Esta forma de resolver los problemas en muchas situaciones no será la más
eficiente. Imaginemos si implementamos un algoritmo que busca en el disco duro la
cantidad de archivos con extensión java, éste proceso requiere de mucho tiempo ya
que el acceso a disco es costoso. Mientras esta búsqueda no finalice nuestro
programa no puede desarrollar otras actividades, por ejemplo no podría estar
accediendo a un servidor de internet, procesando tablas de una base de datos etc.
En el lenguaje Java se ha creado el concepto de hilo para poder ejecutar algoritmos
en forma concurrente, es decir que comience la ejecución de la función pero
continúe con la ejecución de la función main o la función desde donde se llamó al
hilo.
Con los hilos podremos sacar ventajas en seguir la ejecución del programa y que
no se bloquee en algoritmos complejos o que accedan a recursos lentos.
Los sistemas operativos multitarea ejecutan o emulan ejecutar más de una tarea a
la vez. Esto es solo cierto si dispone de más de un procesador, si no, va alternando
procesos en un solo procesador.
2
Esto lo realiza el planificador del sistema operativo lo cual implica la correcta gestión
de la memoria para guardar los datos del proceso saliente, provocando cierta
sobrecarga del sistema.
Para nuestro sistema operativo tendremos un solo proceso con diversas tareas a
ejecutar. En este sentido el planificador se encarga de que cuando le toque
ejecutarse a nuestro proceso, las tareas del mismo se vayan alternando, con la
diferencia que, al ser de un mismo proceso, no se libera espacio de memoria ni
procesador, como si se haría en el caso de alternar procesos.
Esto agiliza por lo tanto la ejecución de nuestro proceso que además puede simular
paralelizar la ejecución de varias tareas a la vez.
El hecho de usar programación multihilo no implica que siempre vamos a tener una
mejora de rendimiento y es potestad del programador el decidir cuándo conviene
usar este tipo de programación. En líneas generales, si la aplicación que hemos
desarrollado es muy simple no tiene sentido plantearse este tipo de programación.
Por regla general, se considera que una aplicación es candidata a ser programa en
multihilo cuando cumple las siguientes premisas:
3
2. El resultado de las tareas que se ejecuten en diferentes hilos no debe
depender del resultado de otras tareas, ya que, de lo contrario, las tareas se
estarían esperando unas a otras y al final el rendimiento sería menor del
esperado.
3. Se prevea que pueda haber tareas retenidas o bloqueadas por estar
esperando a una lectura de disco, por ejemplo. En estos casos, esta tarea se
bloquea y otra entra en acción, aprovechando de esta forma la programación
multihilo.
Para entender mejor lo que hemos comentado, pondremos dos ejemplos en los que
puede resultar beneficioso el uso de la programación multihilo. Uno de los casos de
uso más comunes es cuando una aplicación precisa acceder a diferentes
orígenes, como servidores o bases de datos, para procesar la información recogida
de cada origen.
Como podemos ver en estos dos casos de uso, la mejora del rendimiento o la
priorización de procesos, son las ventajas más claras que podremos obtener en la
programación multihilo.
4
5