Diferencia entre revisiones de «Programa informático»
m Revertidos los cambios de 200.105.236.122 a la última edición de Javierito92 |
|||
Línea 24: | Línea 24: | ||
== Programación == |
== Programación == |
||
hola nicky y jaessy |
|||
{{AP|Programación}} |
|||
[[Archivo:CodeCmmt002.svg|thumb|230px|right|Código fuente de un programa escrito en el [[lenguaje de programación Java]]]] |
|||
La [[programación]] es un proceso el cual consiste en escribir o editar el código fuente. Editar el código fuente significa poner a prueba, analizar y redefinir. La persona que tiene la habilidad para programar se le llama [[programador]] o desarrollador de software. Usualmente, al gran proceso de programación se le llama '''desarrollo de software'''. El término '''ingeniería de software''' se está volviendo popular, refiriéndose a la ingeniería como disciplina. |
|||
=== Paradigmas en los lenguajes de programación === |
|||
Los programas se pueden clasificar por el [[Paradigma de programación|paradigma]] del [[lenguaje de programación]] que se usa para producirlos. Los principales paradigmas son imperativos y declarativos. |
|||
Los programas que usan un lenguaje imperativo especifican un [[algoritmo]], usan declaraciones, expresiones y sentencias.<ref name="cpl-ch4-75">{{cita libro |
|||
| apellidos = Wilson |
|||
| nombre = Leslie B. |
|||
| título = Comparative Programming Languages, Second Edition |
|||
| editorial = Addison-Wesley |
|||
| fecha = 1993 |
|||
| páginas = 75 |
|||
| id = ISBN 0-201-56885-3 |
|||
}} (en inglés).</ref> Una declaración asocia un nombre de variable con un tipo de dato, por ejemplo: <code> var x: integer; </code>. Una expresión contiene un valor, por ejemplo: <code> 2 + 2 </code> contiene el valor 4. Finalmente, una sentencia debe asignar una expresión a una variable o usar el valor de una variable para alterar el flujo de un programa. Por ejemplo: <code>x := 2 + 2; if x == 4 then haz_algo();</code>. Una crítica común en los lenguajes imperativos es el efecto de las sentencias de asignación sobre una clase de variables llamadas "no locales".<ref name="cpl-ch9-213">{{cita libro |
|||
| apellidos = Wilson |
|||
| nombre = Leslie B. |
|||
| título = Comparative Programming Languages, Second Edition |
|||
| editorial = Addison-Wesley |
|||
| fecha = 1993 |
|||
| páginas = 213 |
|||
| id = ISBN 0-201-56885-3 |
|||
}} (en inglés).</ref> |
|||
Los programas que usan un lenguaje declarativo especifican las propiedades que la salida debe conocer y no especifica cualquier detalle de implementación. Dos amplias categorías de lenguajes declarativos son los '''lenguajes funcionales''' y los '''lenguajes lógicos'''. Los lenguajes funcionales (como [[Haskell]]) no permiten asignaciones de variables no locales, así, se hacen más fácil, por ejemplo, programas como funciones matemáticas.<ref name="cpl-ch9-213">{{cita libro |
|||
| apellidos = Wilson |
|||
| nombre = Leslie B. |
|||
| título = Comparative Programming Languages, Second Edition |
|||
| editorial = Addison-Wesley |
|||
| fecha = 1993 |
|||
| páginas = 213 |
|||
| id = ISBN 0-201-56885-3 |
|||
}} (en inglés).</ref> El principio detrás de los lenguajes lógicos (como [[Prolog]]) es definir el problema que se quiere resolver (el objetivo) y dejar los detalles de la solución a el sistema de Prolog.<ref name="cpl-ch10-244">{{cita libro |
|||
| apellidos = Wilson |
|||
| nombre = Leslie B. |
|||
| título = Comparative Programming Languages, Second Edition |
|||
| editorial = Addison-Wesley |
|||
| fecha = 1993 |
|||
| páginas = 244 |
|||
| id = ISBN 0-201-56885-3 |
|||
}} (en inglés).</ref> El objetivo es definido dando una lista de sub-objetivos. Cada sub-objetivo también se define dando una lista de sus sub-objetivos, etcétera. Si al tratar de buscar una solución, una ruta de sub-objetivos falla, entonces tal sub-objetivo se descarta y sistemáticamente se prueba otra ruta. |
|||
La forma en la cual es programa se crea puede ser por medio de texto o de forma visual. En un [[lenguaje de programación visual]], los elementos son manipulados gráficamente en vez de especificarse por medio de texto. |
|||
=== Compilación o interpretación de lenguajes de programación === |
|||
Si un programa está escrito en un lenguaje de programación comprensible para un humano, se le llama [[código fuente]]. El código fuente se puede convertir en un [[archivo ejecutable]] con la ayuda de un [[compilador]] o también puede ser ejecutado de inmediato por medio de un [[Intérprete (informática)|intérprete]]. |
|||
Los programas que son compilados comúnmente son llamados ejecutables, imágenes binarias, o simplemente como [[archivo binario|binarios]], ya que la forma en que se almacena el código de los ejecutables es en [[sistema de numeración binario|binario]]. Los compiladores se utilizan para traducir el código fuente de un lenguaje de programación, ya sea a [[código objeto]] o a [[código de máquina]]. El código objeto necesita una transformación más para convertirse en código de máquina, y el código de máquina es el [[microcódigo|código]] nativo del [[microprocesador|procesador]], listo para su ejecución. Un lenguaje de programación utilizado comúnmente para compilar es el [[C (lenguaje de programación)|lenguaje C]]. |
|||
Los programas interpretados podrían primeramente ser decodificados e inmediatamente después ejecutarse, o también puede darse el caso que se transforme a una eficiente representación intermedia para su futura ejecución. [[BASIC]], [[Perl]], y [[Python]] son ejemplos de lenguajes en los cuales los programas se ejecutan inmediatamente. De forma alternativa, los programas escritos en [[Lenguaje de programación Java|Java]] primeramente son compilados y almacenados en un código independiente de la máquina al cual se le llama [[bytecode]]. Un intérprete llamado '''máquina virtual''' ejecuta dicho bytecode cuando se le solicita. |
|||
La desventaja principal de los intérpretes es que los programas se ejecutan más lentamente que si fueran compilados. El código interpretado es más lento que el código compilado porque el intérprete debe de decodificar cada sentencia cada vez que se carga y luego ejecutar dicha acción. Sin embargo, el desarrollo del software puede ser más rápido usando un intérprete porque las pruebas sobre el código fuente se llevan de forma inmediata cuando se omite la fase de compilación. Otra desventaja de los intérpretes es que el intérprete debe de estar presente en la computadora para poder ejecutar los programas, en cambio los programas hechos con compiladores no necesitan tener el compilador presente en tiempo de ejecución. |
|||
Un lenguaje de programación no es estricta y exclusivamente compilado o interpretado. La clasificación usualmente refleja el método más popular de la ejecución del lenguaje. Por ejemplo, BASIC se trata como un lenguaje interpretado y C como un lenguaje compilado, a pesar de la existencia de compiladores para BASIC e intérpretes para C. |
|||
=== Programas que se auto-modifican === |
|||
Un programa en ejecución se trata de forma diferente que los datos en los cuales opera. De cualquier forma, en algunos casos ésta distinción es ambigua, especialmente cuando un programa se modifica a sí mismo. El programa modificado es secuencialmente ejecutado como parte del mismo programa. Se pueden escribir programas auto-modificables en lenguajes como Lisp, COBOL y Prolog. |
|||
== Ejecución y almacenamiento de los programas == |
== Ejecución y almacenamiento de los programas == |
Revisión del 17:51 23 sep 2009
Un programa, o también llamado programa informático, programa de computación o programa de ordenador, es simplemente un conjunto de instrucciones para una computadora.[1] Las computadoras necesitan de los programas para funcionar, y un programa no hace nada a menos que sus instrucciones sean ejecutadas por el procesador.[2] Un programa se puede referir tanto a un programa ejecutable como a su código fuente, el cual es transformado en un ejecutable cuando es compilado.
Generalmente el código fuente de los programas es escrito por profesionales conocidos como programadores. El código fuente es escrito en un lenguaje de programación que sigue uno de los siguientes dos paradigmas: imperativo o declarativo. El código fuente puede ser convertido en una imagen ejecutable por un compilador. Cuando se pide que el programa sea ejecutado, el procesador ejecuta el programa instrucción por instrucción, hasta que el programa termina.
De acuerdo a sus funciones, los programas pueden ser clasificados en software de sistema y software de aplicación. Pueden ejecutarse muchos programas de forma simultánea en un mismo ordenador, a lo cual se le llama multitarea.
Programación
hola nicky y jaessy
Ejecución y almacenamiento de los programas
Típicamente, los programas se almacenan en una memoria no volátil (por ejemplo un disco), para que luego el usuario de la computadora, directa o indirectamente, solicite su ejecución. Al momento de dicha solicitud, el programa es cargado en la memoria de acceso aleatorio o RAM del equipo, bajo el control del software llamado sistema operativo, el cual puede acceder directamente al procesador. El procesador ejecuta (corre) el programa, instrucción por instrucción hasta que termina. A un programa en ejecución se le suele llamar también proceso. Un programa puede terminar su ejecución en forma normal o por causa de un error, dicho error puede ser de software o de hardware.
Programas empotrados en hardware
Algunos programas están empotrados en el hardware. Una computadora con arquitectura de programas almacenados requiere un programa inicial almacenado en su ROM para arrancar. El proceso de arranque es para identificar e inicializar todos los aspectos del sistema, desde los registros del procesador, controladores de dispositivos hasta el contenido de la memoria RAM.[3] Seguido del proceso de inicialización, este programa inicial carga al sistema operativo e inicializa al contador de programa para empezar las operaciones normales. Independiente de la computadora, un dispositivo de hardware podría tener firmware empotrado para el control de sus operaciones. El firmware se utiliza cuando se espera que el programa cambie en raras ocasiones o nunca, o cuando el programa no debe perderse cuando haya ausencia de energía.[4]
Programas cargados manualmente
Los programas históricamente se cargaron manualmente al procesador central mediante interruptores. Una instrucción era representada por una configuración de estado abierto o cerrado de los interruptores. Después de establecer la configuración, se ejecutaba un botón de ejecución. Este proceso era repetitivo. También, históricamente los programas se cargaban manualmente mediante una cinta de papel o tarjetas perforadas. Después de que el programa se cargaba, la dirección de inicio se establecía mediante interruptores y el botón de ejecución se presionaba.[5]
Programas generados automáticamente
La programación automática es un estilo de programación que crea código fuente mediante clases genéricas, prototipos, plantillas, aspectos, y generadores de código para aumentar la productividad del programador. El código fuente se genera con herramientas de programación tal como un procesador de plantilla o un IDE. La forma más simple de un generador de código fuente es un procesador macro, tal como el preprocesador de C, que reemplaza patrones de código fuente de acuerdo a reglas relativamente simples.
Un motor de software da de salida código fuente o lenguaje de marcado que simultáneamente se vuelve la entrada de otro proceso informático. Podemos pensar como analogía un proceso manejando a otro siendo el código máquina quemado como combustible. Los servidores de aplicaciones son motores de software que entregan aplicaciones a computadoras cliente. Por ejemplo, un software para wikis es un sevidor de aplicaciones que permite a los usuarios desarrollar contenido dinámico ensamblado a partir de artículos. Las Wikis generan HTML, CSS, Java, y Javascript los cuales son interpretados por un navegador web.
Ejecución simultánea
Muchos programas pueden correr simultáneamente en la misma computadora, a lo cual se le conoce como multitarea y puede lograrse a través de mecanismos de software o de hardware. Los sistemas operativos modernos pueden correr varios programas a través del planificador de procesos — un mecanismo de software para conmutar con frecuencia la cantidad de procesos del procesador de modo que los usuarios puedan interactuar con cada programa mientras estos están corriendo.[6] También se puede lograr la multitarea por medio del hardware; las computadoras modernas que usan varios procesadores o procesadores con varios núcleos pueden correr muchos programas a la vez.[7]
Categorías funcionales
Los programas se pueden categorizar según líneas funcionales. Estas categorías funcionales son software de sistema y software de aplicación. El software de sistema incluye al sistema operativo el cual acopla el hardware con el software de aplicación.[8] El propósito del sistema operativo es proveer un ambiente en el cual el software de aplicación se ejecuta de una manera conveniente y eficiente.[8] Además del sistema operativo, el software de sistema incluye programas utilitarios que ayudan a manejar y configurar la computadora. Si un programa no es software de sistema entonces es software de aplicación. El middleware también es un software de aplicación que acopla el software de sistema con la interfaz de usuario. También son software de aplicación los programas utilitarios que ayudan a los usuarios a resolver problemas de aplicaciones, como por ejemplo la necesidad de ordenamiento.
Véase también
Referencias
- ↑ Stair, Ralph M., et al (2003). Principles of Information Systems, Sixth Edition. Thomson Learning, Inc. p. 132. ISBN 0-619-06489-7. (en inglés).
- ↑ Silberschatz, Abraham (1994). Operating System Concepts, Fourth Edition. Addison-Wesley. p. 58. ISBN 0-201-50480-4. (en inglés).
- ↑ Silberschatz, Abraham (1994). Operating System Concepts, Fourth Edition. Addison-Wesley. p. 30. ISBN 0-201-50480-4. (en inglés).
- ↑ Tanenbaum, Andrew S. (1990). Structured Computer Organization, Third Edition. Prentice Hall. p. 11. ISBN 0-13-854662-2. (en inglés).
- ↑ Silberschatz, Abraham (1994). Operating System Concepts, Fourth Edition. Addison-Wesley. p. 6. ISBN 0-201-50480-4. (en inglés).
- ↑ Silberschatz, Abraham (1994). Operating System Concepts, Fourth Edition. Addison-Wesley. p. 100. ISBN 0-201-50480-4. (en inglés).
- ↑ Akhter, Shameem (2006). Multi-Core Programming. Richard Bowles (Intel Press). pp. 11-13. ISBN 0-9764832-4-6. (en inglés).
- ↑ a b Silberschatz, Abraham (1994). Operating System Concepts, Fourth Edition. Addison-Wesley. p. 1. ISBN 0-201-50480-4. (en inglés). Error en la cita: Etiqueta
<ref>
no válida; el nombre «osc-ch1-1» está definido varias veces con contenidos diferentes
Bibliografía
- Knuth, Donald E. (1997). The Art of Computer Programming, Volume 1, 3rd Edition. Boston: Addison-Wesley. ISBN 0-201-89683-4. (en inglés).
- Knuth, Donald E. (1997). The Art of Computer Programming, Volume 2, 3rd Edition. Boston: Addison-Wesley. ISBN 0-201-89684-2. (en inglés).
- Knuth, Donald E. (1997). The Art of Computer Programming, Volume 3, 3rd Edition. Boston: Addison-Wesley. ISBN 0-201-89685-0. (en inglés).