Download Evolución de los Lenguajes de Programación

Document related concepts
no text concepts found
Transcript
Evolución de los Lenguajes
de Programación
Dr. Oldemar Rodríguez
Escuela de Informática
Universidad Nacional
¿Qué es un Paradigma de
programación?


Un paradigma de programación
representa un enfoque particular o
filosofía para la construcción del
software.
No es mejor uno que otro sino que
cada
uno
tiene
ventajas
y
desventajas.
También
hay
situaciones donde un paradigma
resulta más apropiado que otro.
Evolución de los Lenguajes
de Programación
Tiempo
FORTRAN
LISP
Algol-60
Algol-68
Pascal
CLP
Simula-67
PROLOG
BCLP
Scheme
Logo
MicroMundos
C
SmallTalk-80
Modula-2
ADA
C++
Object Pascal
Delphi
JAVA
C++Builder
C++ .NET
Origen de los lenguajes
Lenguaje
Algol-60
Pascal
Modula-2
Oberon
CPL
BCPL
C
C++
Lisp
PROLOG
Logo
Creador
Wirth y Hoare
Wirth
Wirth
Wirth
Strachey
Richards
Dennis Ritchie
Bjarne Stroustrup
John McCarthy
Alain Colmeraurer y Phillipe Roussel
Seymour Papert
Año
1966
1971
1983
1988
1966
1969
1972
1986
1958
1972
Año 2000
Año 2004
Programming Language Popularity: The TCP Index for 2004
Programming Language Popularity: The TCP
Index for December, 2012
Elementos de un lenguaje de
programación
Sintaxis: La sintaxis de un lenguaje
especifica cómo están construidos los
programas en ese lenguaje.
Semántica: La semántica de un
lenguaje especifica el significado del
programa.
Funciones definidas por el
programador.
Tipos: El tipo de una expresión nos
indica los valores que ésta puede
representar y las operaciones que
pueden aplicarse a ella.
Elementos de un lenguaje de
programación
Sobrecarga: un símbolo, y en
particular un operador, está
sobrecargado cuando posee
significados distintos en contextos
distintos.
Herencia.
Backtraking.
Lazy evaluation.
Programación Estructurada





La programación estructura surge ante la necesidad de
hacer programas cada vez más entendibles o legibles.
Surge en el año de 1968.
Se fundamenta en el flujo de control estructurado, es
decir uso constructores de bifurcación, bifurcación, y
repetición en lugar de usar los saltos “GO TO”.
Es decir el flujo de control es evidente del texto del
programa, mediante el uso del if, case, repeat, do, while.
Los lenguajes estructurados utilizan también funciones,
procedimientos, parámetros y datos estructurados
(arreglos, registros, etc.).
Programación Estructurada en C
While
Sintaxis:
while(expresion) sentencia

Ejemplo:
#include <stdio.h>
void main() {
int numero=1;
while(numero<=100) {
printf("%d\n",numero);
++numero;
}
}
do while
Sintaxis:
do sentencia while(expresion)
Ejemplo:
#include <stdio.h>
void main() {
int numero=1;
do
printf("%d\n",numero++);
while(numero<=100);
}
for
Sintaxis:
for(expresion1; expresion2; expresion3)
sentencia
Una sentencia for es siempre equivalente
a la siguiente expresión while:
expresion1;
while(expresion2) {
sentencia;
expresion3;
}
for
Sintaxis:
for(expresion1; expresion2; expresion3)
sentencia
Ejemplo:
#include <stdio.h>
void main() {
int numero;
for(numero=1; numero<=100; numero+=2)
printf("%d\n",numero);
}
if - else
Sintaxis:
if(expresion)
sentencia1
else
sentencia2
Ejemplo:
scanf("%d",&numero);
if((numero%2)==0)
printf("El número %d es par",numero);
else
printf("El número digitado no es par");
switch
Sintaxis:
switch (expresion) sentencia
Ejemplo:
switch (color = toupper(getchar())) {
case 'R':
printf("COLOR ROJO");
break;
case 'B':
printf("COLOR BLANCO");
break;
case 'A':
printf("COLOR AZÚL");
break;
default:
printf("ERROR");
}
Funciones en C:
La sintaxis general de una función es la
siguiente:
tipo nombre_función(declaración de parámetros)
{
cuerpo de la función
}
Ejemplo:
float Potencia(float x,int n) {
float exp=1;
if(x<0)
return -1;
else
for(int i=1; i<=n; i++)
exp*=x;
return exp;
}
Procedimientos:

Ejemplo:
void imprime(int n) {
for(int i=2;i<=n;i+=2)
printf("%d\n",i);
}
Tipos de Datos Abstractos
(TDA)
Un TDA incluye:
Un tipo de datos.
Un conjunto de operaciones asociadas al tipo.
Usualmente provee constructores y
destructores para el tipo.
Generalmente se usan "Tipos Opacos", es decir
la declaración de la estructura de datos se
trasladada a la parte implementación. Esto
tiene la ventaja de prohíbe importar y accesar
directamente los componentes del tipo.
Un TDA incluye:
FEn Modula2 los TDA se pueden implementar con
facilidad gracias a que provee mecanismos
para:
1.
2.
3.
Un módulo para el programa Principal.
Módulos de definición.
Módulos de implementación
F Sintaxis del Módulo de definición (.DEF)
DEFINITION MODULE Nombre;
[ Lista de importación, puede incluir constante, variables, tipos,
procedimientos ]
[ Declaración de constantes ]
[ Declaración de tipos ]
[ Declaración de variables ]
[ Declaración de procedimientos ]
END Nombre.
F Sintaxis del Módulo de implementación (.MOD)
IMPLEMENTATION MODULE Nombre;
[ Lista de importación, puede incluir constante, variables, tipos,
procedimientos ]
[ Declaración de constantes ]
[ Declaración de tipos ]
[ Declaración de variables ]
[ Declaración de procedimientos ]
BEGIN
[ Instrucciones ]
END Nombre.
DEFINITION MODULE LISTA ;
TYPE
Tipo Lista;
TipoElemento = REAL;
// Se llama un TIPO OPACO
PROCEDURE CrearLista(VAR L : TipoLista);
(* pre:- L no existe *)
(* pos:- L existe *)
PROCEDURE EsVacia(L : TipoLista) : BOOLEAN;
(* pre:- L existe *)
PROCEDURE Posicion(L : TipoLista; Lugar : CARDINAL) : TipoLista;
(* pre:- L existe *)
(* pos:- Retorna un puntero a la posicion Lugar *)
PROCEDURE InsertarEnLista(VAR L : TipoLista; X : TipoElemento; Lugar :
CARDINAL);
(* pre:- L existe y 1 <= Lugar <= LargoLista(L) + 1 *)
(* pos:- incluye el elemento X de tipo TipoElemento en la posicion Lugar*)
PROCEDURE EliminarDeLista(VAR L : TipoLista; Lugar : CARDINAL);
(* pre:- L existe y Lugar(L) >= 1 *)
(* pos:- excluye de la lista el elemento ubicado en la posicion Lugar *)
PROCEDURE RecuperarDeLista(L : TipoLista; Lugar : CARDINAL; VAR X :
TipoElemento);
(* pre:- L existe y Lugar(L) >= 1 *)
(* pos:- Deja en X el elemento recuperado *)
PROCEDURE VisualizaLista(L : TipoLista);
(* pre:- L existe *)
(* pos:- permite visualizar por pantalla el contenido de la lista *)
END Lista.
IMPLEMENTATION MODULE Lista;
FROM Storage IMPORT Available, ALLOCATE, DEALLOCATE;
FROM IO IMPORT WrCard, WrStr, WrLn, WrReal;
TYPE
TipoLista = POINTER TO Reg;
Reg = RECORD
Elemento : TipoElemento;
Sig : TipoLista;
END;
PROCEDURE CrearLista(VAR L : TipoLista);
BEGIN
L:=NIL;
END CrearLista;
PROCEDURE EsVacia(L : TipoLista) : BOOLEAN;
BEGIN
IF L=NIL THEN
RETURN TRUE
ELSE
RETURN FALSE
END;
END EsVacia;
.......................................................................................................................etc.
END Lista.
MODULE PrLista;
FROM Lista IMPORT CrearLista, InsertarEnLista, VisualizaLista,
TipoLista, EliminarDeLista, RecuperarDeLista;
FROM IO IMPORT WrStr, WrLn, RdReal, RdCard, WrReal;
VAR
BaseD : TipoLista;
Num : REAL;
Pos : CARDINAL;
PROCEDURE HaceLista(VAR L : TipoLista);
BEGIN
REPEAT
WrStr('De El Numero a insertar >- ');
Num:=RdReal();
WrLn;
WrStr('De El Lugar >- ');
Pos:=RdCard();
InsertarEnLista(BaseD,Num,Pos);
UNTIL Num=0.0;
END HaceLista;
BEGIN
CrearLista(BaseD);
HaceLista(BaseD);
VisualizaLista(BaseD);
WrLn;
WrStr('De El Lugar que desea eliminar >- ');
Pos:=RdCard();
EliminarDeLista(BaseD,Pos);
VisualizaLista(BaseD);
WrLn;
WrStr('De El Lugar que desea visualizar >- ');
Pos:=RdCard();
RecuperarDeLista(BaseD,Pos,Num);
WrLn;
WrReal(Num,6,6);
WrLn;
VisualizaLista(BaseD);
END PrLista.
FEn C los TDA se pueden implementar utilizando:
1.
2.
3.
4.
Un archivo *.cpp para el programa Principal.
Las definiciones en archivos *.h.
Las implementaciones en un archivos *.cpp.
Un proyecto que unifique todos los archivos
extensión *.cpp.