¿No sabes por dónde empezar? Ayúdanos normalizando artículos.
¿Tienes experiencia? Crea alguno de estos artículos de actualidad.

Diferencia entre revisiones de «Programación concurrente»

Línea 1: Línea 1:
{{Objeto|nombre=Programación Concurrente en  CSharp|imagen=Proc.JPG|descripcion=Conjunto de [[técnica]]s y notaciones  que sirven para expresar el [[paralelismo]] potencial en los programas}}'''Programación Concurrente.''' Se entiende por  [[programación]] [[concurrente]] el conjunto de [[técnica]]s y  notaciones que sirven para expresar el [[paralelismo]] [[potencial]] en  los programas, así como resolver problemas de [[comunicación]] y  [[sincronización]].
+
{{Objeto|nombre=Programación Concurrente en  CSharp|imagen=Proc.JPG|descripcion=Conjunto de técnicas y notaciones  que sirven para expresar el paralelismo potencial en los programas}}'''Programación Concurrente.''' Se entiende por  [[programación]] concurrente el conjunto de técnicas y  notaciones que sirven para expresar el paralelismo potencial en  los programas, así como resolver problemas de [[comunicación]] y  sincronización.
  
 
==Proceso==
 
==Proceso==
Un [[proceso]] es un [[programa]] en ejecución con un estado asociado. Las distintas [[aplicaciones]] que  se ejecutan en un [[sistema operativo]] [[multitarea]] son [[procesos]]  independientes. Cada una de ellas tiene asociado un contexto (prioridad,  estado del [[procesador]], lista de interrupciones y señales que  admite, páginas de [[memoria]] que ocupa, etc.).
+
Un [[proceso]] es un programa  en ejecución con un estado asociado. Las distintas aplicaciones que  se ejecutan en un [[sistema operativo multitarea]] son [[proceso]]s independientes. Cada una de ellas tiene asociado un contexto (prioridad,  estado del procesador, lista de interrupciones y señales que  admite, páginas de [[memoria]] que ocupa, etc.).
 
==Aplicación==
 
==Aplicación==
Una  [[aplicación]] [[concurrente]] está formada por un conjunto de  [[procesos concurrentes]]. En ella existen distintas hebras de  [[control]] independientes, vías simultáneas de [[ejecución]]. Dichas  [[hebras]] de control pueden ser [[procesos independientes]] en el  [[sistema operativo]] o [[hebras]] dentro de un [[proceso]]. Una  [[aplicación multihebra]] está constituida por distintas [[hebras]] que  comparten el espacio de un [[proceso]] en el [[sistema operativo]].
+
Una  aplicación concurrente está formada por un conjunto de  procesos concurrentes. En ella existen distintas hebras de  [[control]] independientes, vías simultáneas de ejecución. Dichas  hebras de control pueden ser procesos independientes en el  [[sistema operativo]] o hebras dentro de un [[proceso]]. Una  [[aplicación multihebra]] está constituida por distintas hebras que  comparten el espacio de un proceso en el [[sistema operativo]].
  
 
== Consideraciones ==
 
== Consideraciones ==
 
Cada hebra/proceso supone una carga adicional para el [[sistema]].
 
Cada hebra/proceso supone una carga adicional para el [[sistema]].
*  El [[diseño]] de [[aplicaciones concurrentes]] es complejo, ya que  hemos de garantizar la independencia de las hebras/procesos y la  [[integridad]] de los datos con los que trabajan simultáneamente.
+
*  El [[diseño]] de aplicaciones concurrentes es complejo, ya que  hemos de garantizar la independencia de las hebras/procesos y la  integridad de los datos con los que trabajan simultáneamente.
*  La [[depuración]] de las [[aplicaciones concurrentes]] es difícil, dado  que la [[ejecución]] de los distintos procesos/hebras se realiza de  forma atómica.
+
*  La depuración de las aplicaciones concurrentes es difícil, dado  que la [[ejecución]] de los distintos procesos/hebras se realiza de  forma atómica.
* [[Hebras]] y [[procesos]] han de coordinarse de  algún modo, para lo cual hemos de emplear mecanismos de [[comunicación]]  y [[sincronización]] que permitan coordinar la [[ejecución]] de las  distintas hebras/procesos.
+
* Hebras y procesos han de coordinarse de  algún modo, para lo cual hemos de emplear mecanismos de [[comunicación]]  y sincronización que permitan coordinar la ejecución de las  distintas hebras/procesos.
  
 
== ¿Por qué usar hebras y procesos? ==
 
== ¿Por qué usar hebras y procesos? ==
Línea 21: Línea 21:
 
== Estructuración, Paralelismo implícito ==
 
== Estructuración, Paralelismo implícito ==
 
El objetivo principal del uso de [[paralelismo]] es mejorar el  [[rendimiento]] del [[sistema]]. El diseñador/programador deberá decidir  hasta qué punto debe utilizarse en cada momento.
 
El objetivo principal del uso de [[paralelismo]] es mejorar el  [[rendimiento]] del [[sistema]]. El diseñador/programador deberá decidir  hasta qué punto debe utilizarse en cada momento.
*[[Ejecución]] de [[procesos]].
+
*Ejecución de [[procesos]].
*Finalización de [[procesos]].
+
*Finalización de procesos.
*[[Monitorización]] de [[procesos]].
+
*Monitorización de procesos.
 
*Operaciones de E/S
 
*Operaciones de E/S
  
 
=== Ejecución de procesos ===
 
=== Ejecución de procesos ===
La  clase System.Diagnostics.Process permite crear y monitorizar  [[procesos]] (accediendo a la [[información]] que se visualiza en el  Administrador de Tareas de Windows). El método Process.Start() equivale a  la llamada ShellExecute del API de Windows (Win32) y es el que  deberemos utilizar para lanzar un [[proceso]]. Los parámetros del  [[proceso]] se especifican mediante un objeto de la clase  ProcessStartInfo. Al [[encapsular]] una llamada al shell de Windows, el  método Start también podemos usarlo para abrir un [[fichero]] de  cualquier tipo de los que tengan acciones asociadas en el registro de  Windows.
+
La  clase System.Diagnostics.Process permite crear y monitorizar  procesos (accediendo a la [[información]] que se visualiza en el  Administrador de Tareas de Windows). El método Process.Start() equivale a  la llamada ShellExecute del API de Windows (Win32) y es el que  deberemos utilizar para lanzar un proceso. Los parámetros del  [[proceso]] se especifican mediante un objeto de la clase  ProcessStartInfo. Al encapsular una llamada al shell de Windows, el  método Start también podemos usarlo para abrir un [[fichero]] de  cualquier tipo de los que tengan acciones asociadas en el registro de  Windows.
  
 
== Fuentes ==
 
== Fuentes ==

Revisión del 12:45 29 ago 2012

Programación Concurrente en CSharp
Información sobre la plantilla
Proc.JPG
Conjunto de técnicas y notaciones que sirven para expresar el paralelismo potencial en los programas

Programación Concurrente. Se entiende por programación concurrente el conjunto de técnicas y notaciones que sirven para expresar el paralelismo potencial en los programas, así como resolver problemas de comunicación y sincronización.

Proceso

Un proceso es un programa en ejecución con un estado asociado. Las distintas aplicaciones que se ejecutan en un sistema operativo multitarea son procesos independientes. Cada una de ellas tiene asociado un contexto (prioridad, estado del procesador, lista de interrupciones y señales que admite, páginas de memoria que ocupa, etc.).

Aplicación

Una aplicación concurrente está formada por un conjunto de procesos concurrentes. En ella existen distintas hebras de control independientes, vías simultáneas de ejecución. Dichas hebras de control pueden ser procesos independientes en el sistema operativo o hebras dentro de un proceso. Una aplicación multihebra está constituida por distintas hebras que comparten el espacio de un proceso en el sistema operativo.

Consideraciones

Cada hebra/proceso supone una carga adicional para el sistema.

  • El diseño de aplicaciones concurrentes es complejo, ya que hemos de garantizar la independencia de las hebras/procesos y la integridad de los datos con los que trabajan simultáneamente.
  • La depuración de las aplicaciones concurrentes es difícil, dado que la ejecución de los distintos procesos/hebras se realiza de forma atómica.
  • Hebras y procesos han de coordinarse de algún modo, para lo cual hemos de emplear mecanismos de comunicación y sincronización que permitan coordinar la ejecución de las distintas hebras/procesos.

¿Por qué usar hebras y procesos?

El uso de paralelismo (múltiples procesos y hebras, en particular) proporciona una serie de ventajas frente a las limitaciones de los sistemas monotarea.

Ejemplo

  • Aprovechamiento de los recursos del sistema.
  • Establecimiento de prioridades.
  • Multiprocesamiento real.

Estructuración, Paralelismo implícito

El objetivo principal del uso de paralelismo es mejorar el rendimiento del sistema. El diseñador/programador deberá decidir hasta qué punto debe utilizarse en cada momento.

  • Ejecución de procesos.
  • Finalización de procesos.
  • Monitorización de procesos.
  • Operaciones de E/S

Ejecución de procesos

La clase System.Diagnostics.Process permite crear y monitorizar procesos (accediendo a la información que se visualiza en el Administrador de Tareas de Windows). El método Process.Start() equivale a la llamada ShellExecute del API de Windows (Win32) y es el que deberemos utilizar para lanzar un proceso. Los parámetros del proceso se especifican mediante un objeto de la clase ProcessStartInfo. Al encapsular una llamada al shell de Windows, el método Start también podemos usarlo para abrir un fichero de cualquier tipo de los que tengan acciones asociadas en el registro de Windows.

Fuentes

  • Galiano Fernando Berzal.Concurrencia. 2009
  • Carmona David. Programming the Thread Pool in the .NET Framework.June 2002.

Enlace relacionado