Bajadas+en+proceso

=Proceso=

Un proceso puede informalmente entenderse como un programa en ejecución. Formalmente un proceso es "Una unidad de actividad que se caracteriza por la ejecución de una secuencia de instrucciones, un estado actual, y un conjunto de recursos del sistemas asociados". Para entender la diferencia entre un programa y un proceso, A. S. Tanenbaum propone la analogía "Un científico computacional con mente culinaria hornea un pastel de compleaños para su hija; tiene la receta para un pastel de cumpleaños y una cocina bien equipada con todos los ingredientes necesarios, harina, huevo azúcar, leche, etcétera." Situando cada parte de la analogía se puede decir que la receta representa el programa (el algoritmo), el científico computacional es el procesador y los ingredientes son las entradas del programa. El proceso es la actividad que consiste en que el científico computacional vaya leyendo la receta, obteniendo los ingredientes y horneando el pastel. Cada proceso tiene su contador de programa registros y variables, aislados de otros procesos, incluso siendo el mismo programa en ejecución 2 veces. Cuándo este último caso sucede, el sistema operativo usa la misma región de memoria de código, debido a que dicho código no cambiará, a menos que se ejecute una versión distinta del programa. Los procesos son gestionados por el sistama operativo y están formados por: Un proceso se erige en pequeñas porciones, conocidas como paginas, y cada proceso tiene su propia tabla de paginacion fungiendo como una optimización del sistema operativo ante los fallo de pagina Esta definición varía ligeramente en el caso de sistemas operativos multihilo donde un proceso consta de uno o más //hilos//, la memoria de trabajo (compartida por todos los hilos) y la información de planificación. Cada hiloconsta de instrucciones y estado de ejecución. Los procesos son creados y eliminados por el sistema operativo, así como también éste se debe hacer cargo de la comunicacion de procesos pero lo hace a petición de otros procesos (interrupción o tiempo de reloj). El mecanismo por el cual un proceso crea otro proceso se denomina bifuracion (//fork//). El proceso de arranque de GNU/linux inicia con un sólo proceso (init) y después comienza a crear los hilos necesarios para tener el sistema listo para su uso. Los nuevos procesos pueden ser independientes y no compartir el espacio de memoria con el proceso que los ha creado o ser creados en el mismo espacio de memoria. En los sistemas operativos multihilo es posible crear tanto hilos como procesos. La diferencia estriba en que un proceso solamente puede crear hilos para sí mismo y en que dichos hilos comparten toda la memoria reservada para el proceso. Los procesos pueden ser cooperativos o independientes. Dos o más procesos pueden cooperar mediante señales de forma que uno obliga a detenerse a los otros hasta que reciban una señal para continuar. La sincronización explícita entre procesos es un caso particular del estado "bloqueado". En este caso, el suceso que permite desbloquear un proceso no es una operación de entrada/salida, sino una señal generada a propósito por el programador desde otro proceso. Hay cuatro eventos principales que provocan la creación de procesos: Los procesos pueden contener uno o más hilos, haciendo más eficiente las tareas, asimismo la complejidad de los algoritmos de sincronización, ya que podría ocurrir la condiciones de carrera muy a menudo, inclusive los indeseados interbloqueos
 * Las instrucciones de un programa destinadas a ser ejecutadas por el microprocesador
 * Su estado de ejecución en un momento dado, esto es, los valores de los registros de la unidad central de procesamiento para dicho programa.
 * Su memoria de trabajo (memoria crítica), es decir, la memoria que ha reservado y sus contenidos.
 * Otra información que permite al sistema operativo su planificacion
 * Se usa una variable de tipo semaforo para sincronizar los procesos.
 * Si un proceso está esperando una señal, se suspende hasta que la señal se envíe.
 * Se mantiene una cola de procesos en espera en el semáforo.
 * La forma de elegir los procesos de la cola en espera es mediante una política first in first out
 * El arranque del sistema.
 * La ejecución, desde un proceso, de una llamada al sistema para la creación de otro proceso.
 * Una petición de usuario para crear un proceso.
 * El inicio de un trabajo por lotes.

Tipos de procesos
Existen dos tipos de procesos, aquellos que se ejecutan en modo kernely aquellos que se ejecutan enmodo usuario Los primeros son más lentos por las llamadas al sistema que realizan, sin embargo, son más seguros por la integridad que representan. Cuando hablamos de los procesos de usuario, podemos decir que el sistema operativo podría no ser multiproceso, ya que se vale de librerías (como pthread) para hacer un multiplexado y dar la apariencia de trabajar como multiproceso. Podría pensarse en otra clasificación, como son los procesos en primer plano y procesos en segundo plano. Los primeros interactuan con el usuario, es decir, el usuario proporciona los datos que el proceso utilizará. Los segundos, son creados para tareas bien definidas y no necesitan la invertención del usuario, por ejemplo, se puede tener un proceso en segundo plano para revisar la temperatura el disco duro constantemente, éstos también son conocidos como demonios.