Your SlideShare is downloading. ×
Historia Lenguajes y sus Tipos
Upcoming SlideShare
Loading in...5
×

Thanks for flagging this SlideShare!

Oops! An error has occurred.

×

Saving this for later?

Get the SlideShare app to save on your phone or tablet. Read anywhere, anytime - even offline.

Text the download link to your phone

Standard text messaging rates apply

Historia Lenguajes y sus Tipos

364
views

Published on

Published in: Technology

0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
364
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
5
Comments
0
Likes
0
Embeds 0
No embeds

Report content
Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
No notes for slide

Transcript

  • 1. Curso: PS263 Lenguajes de programación HISTORIA Y TIPOS DE LENGUAJE DE PROGRAMACIÓN 1. Lenguajes de programación: una visión general Lenguajes de programación: una visión general Hay, al menos, dos formas fundamentales desde las que pueden verse o clasificarse los lenguajes de programación: por su nivel y por sus principales aplicaciones. Además, estas visiones están condicionadas por la evolución histórica por la que ha transcurrido el lenguaje. Además, hay cuatro niveles distintos de lenguajes de Programación: Lenguajes declarativos Lenguajes de alto nivel Lenguajes ensambladores Lenguajes máquina Los lenguajes declarativos son los más parecidos al castellano o inglés en su potencia expresiva y funcionalidad y están en el nivel más alto respecto a los otros. Son fundamentalmente lenguajes de órdenes, dominados por sentencias que expresan “lo que hay que hacer” en vez de “cómo hacerlo”. Ejemplos de estos lenguajes son los lenguajes estadísticos como SAS y SPSS y los lenguajes de búsqueda en bases de datos, como NATURAL e IMS. Estos lenguajes se desarrollaron con la idea de que los profesionales pudieran asimilar más
  • 2. rápidamente el lenguaje y usarlo en su trabajo, sin necesidad de programadores o prácticas de programación. Los lenguajes de alto nivel son los más utilizados como lenguajes de programación. Aunque no son fundamentalmente declarativos, estos lenguajes permiten que los algoritmos se expresen en un nivel y estilo de escritura fácilmente legible y comprensible por otros programadores. Además, los lenguajes de alto nivel suelen tener la característica de “transportabilidad”. Es decir, están implementados sobre varias máquinas, de forma que un programa puede ser fácilmente “transportado” (transferido) de una máquina a otra sin una revisión sustancial. En este sentido, se llaman “independientes de la máquina”. Ejemplos de estos lenguajes de alto nivel son PASCAL, APL y FORTRAN (lenguajes de programación utilizados para aplicaciones científicas), COBOL (para aplicaciones de procesamiento de datos), SNOBOL (para aplicaciones de procesamiento de textos), LISP y PROLOG (para aplicaciones de inteligencia artificial), C y ADA (para aplicaciones de programación de sistemas) y PL/I (para aplicaciones de propósito general). Todos estos lenguajes de alto nivel los desarrollaremos más detenidamente en otro apartado de la presentación. Los lenguajes ensambladores y los lenguajes máquina son dependientes de la máquina. Cada tipo de máquina tiene su propio lenguaje máquina distinto y su lenguaje ensamblador asociado. El lenguaje ensamblador es simplemente una representación simbólica del lenguaje máquina asociado, lo cual permite una programación menos tediosa que con el anterior. Sin embargo, es necesario un conocimiento de la arquitectura mecánica subyacente para realizar una programación efectiva en cualquiera de estos niveles de lenguajes. 2. Perspectiva histórica de los lenguajes de programación
  • 3. El programador, diseñador e implementador de un lenguaje de programación deben comprender la evolución histórica para poder apreciar por qué presentan características diferentes. La misma historia nos permite ver la evolución de familias de lenguajes de programación, ver la influencia que ejercen las arquitecturas y aplicaciones de las computadoras sobre el diseño de lenguajes y evitar futuros defectos de diseño aprendiendo las lecciones del pasado. En el siguiente diagrama que presentamos resumimos algunos de los más importantes avances en el diseño de lenguajes de alto nivel desde sus comienzos hasta finales de la década de los 80. Este diagrama representa sólo un pequeña muestra de todos los lenguajes de programación. Existen en uso, hoy en día, más de 150 lenguajes de programación diferentes, con nombres tan diversos como AMBIT, BASEBALL, LOGO y MAD. Muchos son dialectos de los que se muestran en el diagrama. Los que describimos en nuestra presentación los hemos elegido debido a su mayor influencia y amplio uso entre los programadores, así como por sus distintivas características de diseño e implementación. El diagrama también contiene las líneas que relacionan a varios lenguajes. Las líneas continuas muestran ascendencia directa, mientras que las líneas discontinuas muestran una fuerte influencia. Por ejemplo, vemos que FORTRAN I es un ascendente directo de FORTRAN II, mientras que FORTRAN, COBOL, ALGOL 60, LISP, SNOBOL y los lenguajes ensambladores, influyeron en el diseño de PL/I. Varios lenguajes representados en el diagrama están prefijados por las letras ANS. Con esto queremos decir que el American National Standards Institute ha adoptado esa versión del lenguaje como el estándar nacional.
  • 4. Finalmente, creemos importante denotar algunas influencias anteriores a 1.960 en el diseño de los lenguajes de programación. Incluimos como importantes la notación algebraica ordinaria, por ejemplo, que influyó fuertemente en el diseño de FORTRAN y ALGOL; el inglés como principal influencia en el desarrollo de COBOL; el lambda cálculo de Church, que dio los fundamentos de la notación funcional de LISP, mientras que el algoritmo de Markov motivó el estilo de reconocimiento de formas de SNOBOL. En último lugar, la arquitectura de computadores de Von Neumann, la cual fue una evolución de la máquina más antigua de Turing, es el modelo básico de la mayoría de los diseños de computadoras hasta hoy en día. Estas máquinas no sólo influyeron en los primeros lenguajes sino que también suministraron el esqueleto operacional sobre el que evolucionó la mayoría de la programación de sistemas. 3. Características de todos lenguaje : UNIVERSAL: todo problema que pueda ser resuelto por una computadora, debe ser posible de ser programable (no es un requisito tan estricto) NATURAL: debe facilitar la resolución de problemas al menos para el área de aplicación del lenguaje IMPLEMENTABLE: debe ser posible ejecutar todo programa bien formado en dicho lenguaje; ejemplos de no implementables: notación matemática, lenguaje natural. EFICIENTE: depende de la arquitectura de computadora Los lenguajes de programación buscan hacer cada vez mas expresivo la simplicidad y eficiencia de los lenguajes Ejemplo: Ada y PL/1 fueron diseñados por un grupo grande de personas. Pascal fue diseñado por una sola persona: Niklaus Wirth
  • 5. Curso: PS263 Lenguajes de programación Genealogía de algunos lenguajes de programación 1950 FORTRAN Algol-60 1960 LISP COBOL PL/I Simula Algol-68 Pascal 1970 C Smalltalk 1980 Prolog ML Ada Miranda Java Orientados a objetos C++ Imperativos Funcionales Lógicos
  • 6. 4. Margo de referencia evolución de los lenguajes de programación AÑO LENGUAJE INVENTOR DESCRIPCION 1900s BINARIO Bool primer lenguaje 1946 Plankalkul 1949 Short Code 1950 ASM (ensamblador) Konrad Zuse creado para jugar al ajedrez lenguaje traducido a mano lenguaje ensamblador 1951 A-0 Grace Hopper fue el primer compilador 1952 AUTOCODE Alick E. Glennie compilador muy rudimentario 1956 FORTRAN IBM 1956 COBOL sistema de Traducción de Formulas matemáticas Compilador 1958 ALGOL 58 1960 LISP 1961 FORTRAN IV IBM Interprete orientado a la Inteligencia Artificial sistema de Traducción de Formulas matemáticas 1961 COBOL 61 Extendido 1960 ALGOL 60 Revisado 1964 PASCAL 1964 BASIC Niklaus Wirth Universidad de Dartmouth (california) programación estructurada Beginners All Purpose Symbolic Instruction Code 1965 SNOBOL 1965 APL solo anotación 1965 COBOL 65 1966 PL/I 1966 FORTRAN 66 IBM sistema de Traducción de Formulas matemáticas 1967 SIMULA 67 1968 ALGOL 68 1968 SNOBOL4 1970s GW-BASIC antiguo y clásico BASIC 1970 APL/360 1972 SMALLTALK 1972 C Centro de Investigación de pequeño y rápido Xerox en Palo Alto Laboratorios Bell lenguaje con tipos 1974 COBOL 74 1975 PL /I Lenguaje sencillo
  • 7. 1977 FORTRAN 77 IBM 1980s SMALLTALK/V Digitalk 1980 C con clases Laboratorios Bell Ministerio Japonés de Comercio Internacional e Industria (MITI) Ministerio de Defensa de los EE.UU AT&T Bell Laboratories (Bjarne Stroustrup) 1981 PROLOG 1982 ADA 1984 C++ 1985 CLIPPER sistema de Traducción de Formulas matemáticas pequeño y rápido lenguaje con clases Lenguaje estándar para la Inteligencia Artificial lenguaje muy seguro compilador compilador para bases de datos 1985 QuickBASIC 1.0 Microsoft® compilador de BASIC 1986 QuickBASIC 2.0 Microsoft® soporte de tarjeta gráfica EGA 1987 QuickBASIC 3.0 Microsoft® 43 lineas con la tarjeta EGA 1987 QuickBASIC 4.0 CLIPPER SUMMER 1987 '87 1988 QuickBASIC 4.5 Microsoft® tarjetas Hercules, VGA Microsoft® tarjeta SVGA 1989 QuickBASIC 7.1 Microsoft® ultima versión de QuickBASIC compilador para bases de datos 1989 ASIC v5.0 interprete tipo QBASIC shareware 1990s VISUAL C++ 1990s VISUAL BASICScript Microsoft® 1990 HTML 1990s WML Tim Berners-Lee para internet C. M. Sperbergpara internet McQueen Charles F. para internet Goldfarb para internet 1990s ASP Microsoft® 1993 XML 1993 SGML 1990s PHP 1995 JAVA para internet para internet Sun Microsystems 1995 CLIPPER 5.01 1995 GNAT ADA95 lenguaje de script para internet y propósito general compilador para bases de datos Ministerio de Defensa de los EE.UU lenguaje muy seguro
  • 8. 1995 FORTRAN 95 IBM 1991 VISUAL BASIC 1.0 Microsoft® 1992 VISUAL BASIC 2.0 Microsoft® 1993 VISUAL BASIC 3.0 Microsoft® 1994 VISUAL BASIC 4.0 Microsoft® 1995 VISUAL BASIC 5.0 Microsoft® 1998 VISUAL BASIC 6.0 sistema de Traducción de Formulas matemáticas Microsoft® 1990s C# 2001 VISUAL BASIC .NET Microsoft® La evolución de Visual Basic Fuente: http://iabot.iespana.es/ciencia/software/historia_lenguajes_programacion.htm 5. Sintaxis y semántica La sintaxis se refiere a la forma de los programas; cómo los diferentes componentes del lenguaje son agregados para formar programas. La semántica se refiere al significado de los programas; cómo se comportan cuando son ejecutados. La sintaxis afecta cómo los programas son escritos por los programadores, cómo son leídos por otros programadores La semántica determina cómo los programas son compuestos por los programadores, cómo son comprendidos por otros programadores, y cómo son interpretados por el computador 6.. Lenguajes programación a través de la historia FORTRAN: :introdujo las expresiones simbólicas, por los subprogramas con parámetros. Ejemplo : original. Forma primitiva del IF 123456789 ... IS=0
  • 9. I=1 N=30 10 IF(N-I) 30,20,20 20 IS=IS+I I=I+1 GOTO 10 30 CONTINUE CALL ESTIMAR(IS,IS2) FORTRAN. El miembro original de la familia, FORTRAN I, nació en 1.954, y fue implementado sobre la computadora IBM 704 en 1.956. Dos años más tarde, apareció FORTRAN II. Entre 1.958 y 1.963, FORTRAN se implementó sobre varias computadoras. FORTRAN III fue desarrollado durante este período, pero debido a que contenía demasiadas características dependientes de la máquina, nunca se implementó para uso público. En 1.962 FORTRAN IV fue desarrollado para las computadoras IBM 7090/7094. En 1.966 se estandarizaron las distintas versiones en dos únicas: la “Basic FORTRAN” y “FORTRAN”. En 1.977 se añadieron extensiones y se revisaron ambas versiones, apareciendo así el FORTRAN 77, que mantenía la compatibilidad para los programas escritos antes con versiones anteriores al nuevo estándar. COBOL (Common Bussiness Oriented Language) introdujo a finales de 1.950: el concepto de descripción de datos introduce la idea de un lenguaje con un área de aplicación no numérica (comercial) En su forma original estos dos lenguajes son de bajo nivel: el control de flujo es llevado a cabo por instrucciones jump disfrazadas., se sintió la necesidad de un lenguaje de procesamiento de datos. En mayo de 1.959, los representantes de los fabricantes de computadoras y de los usuarios de la industria y gobierno, se reunieron para formar el Comité CODASYL (Conference on Data Systems Languages), y se desarrolló una descripción de tal lenguaje, cuya revisión, en 1.960, empezó a conocerse como COBOL-60. Numerosas extensiones fueron formando nuevas versiones de este lenguaje COBOL inicial, hasta
  • 10. aprobarse un estándar en 1.974 por la ANS (American National Standard). PASCAL. La historia de Pascal estaría incompleta sin trazar primero la historia del ALGOL, del cual Pascal es una evolución. La historia del ALGOL comenzó en 1.958, cuando un comité de representantes del GAMM (una organización europea de científicos en informática) y ACM (su contrapartida en USA) se reunieron en Zurcí y produjo un informe preliminar sobre un “International Algebraic Language”, o IAL. Este lenguaje, conocido más tarde como ALGOL 58, atrajo mucho interés y fue implementado sobre varias computadoras. Los representantes europeos y estadounidenses se reunieron de nuevo en París en 1.960 para considerar una versión completamente nueva de este lenguaje, conocida como ALGOL 60. Durante este período, ALGOL fue extremadamente popular entre los científicos informáticos, y su definición rigurosa marcó nuevos estándares para el diseño e implementación de lenguajes. ALGOL se convirtió en un lenguaje universal para la definición de algoritmos publicados en revistas. Con el paso del tiempo, fueron apareciendo nuevas versiones revisadas de ALGOL 60, como ALGOL W (desarrollado por Niklaus Wirth) o ALGOL 68, que fue intencionadamente un lenguaje de propósito general con aplicaciones en un amplio rango de interés, aunque rápidamente se reconoció como un lenguaje demasiado ambicioso para ser práctico. De esta manera, Wirth diseñó un sucesor más reducido del ALGOL 60 y lo llamó PASCAL. Su primer compilador se implementó en 1.970 y una versión revisada fue definida e implementada en 1.973. PASCAL fue claramente diseñado para servir como un lenguaje para enseñar diseño de algoritmos y metodología de programación. Como el ALGOL, PASCAL ha jugado un papel único como el principal lenguaje usado para publicar algoritmos en las revistas y libros. A pesar de sus fuertes mejoras sobre ALGOL, -especialmente en el área de entrada-salida, archivos, registros, gestión dinámica de memoria y estructuras de control- PASCAL también fue cuestionado por sus deficiencias, y por ello se propusieron sucesores importantes como algunos de los que describimos a continuación.
  • 11. PL/I. Es un lenguaje de propósito general, diseñado para soportar aplicaciones científicas, de procesamiento de datos, de procesamiento de textos y de programación de sistemas a muy alto nivel. La primera versión del PL/I fue presentada por el Comité del proyecto SHARE FORTRAN. Esta versión fue llamada NPL (New Programming Language). Fue implementado por primera vez por IBM en 1.965 bajo el nombre de PL/I. Al principio, PL/I no fue aceptada por su ineficiencia, y no fue considerado una alternativa aceptable a los lenguajes establecidos por entonces, principalmente COBOL y FORTRAN, que hemos explicado anteriormente. A pesar de ello, en 1.975, después de haber mejorado la eficiencia de sus compiladores, fue publicado un borrador con una propuesta de un PL/I estándar, aceptado en 1.976. Alrededor de 1.981 apareció un refinamiento de PL/I estándar, llamado SUBSET/G, que preservaba la mayoría de las características útiles del PL/I, y suprimía las generalizaciones de poco uso y difíciles de implementar. SNOBOL. Fue diseñado en 1.962 por un grupo de investigación de los laboratorios Bell como una ayuda a sus propias aplicaciones sobre manipulación simbólica de fórmulas. Una versión mejorada y extendida, llamada SNOBOL3, apareció en 1.966 y fue implementada sobre distintas máquinas. Un potencial sucesor de SNOBOL4, que apareció en 1.969, se conoce como ICON. Aunque contiene muchas de las características de procesamiento de cadenas del SNOBOL, la sintaxis de ICON es mucho más parecida a la de los lenguajes convencionales como PASCAL o C, lenguaje de programación cuya evolución histórica explicaremos más adelante. APL. (A Programming Language) Fue el primero formalmente definido e introducido por Kenneth Iverson, en su libro “A Programming Language” en 1.962. Es marcadamente el producto de la genialidad de una persona con gran orientación matemática. IBM trató de desarrollar APL durante los siguientes siete años, pero nunca llegó a estandarizarse, ya que requería un conjunto único de caracteres con un hardware especial, distinto del que soporta el estándar ASCII. Como resultado, APL no ha sido implementado ampliamente sobre las distintas máquinas.
  • 12. LISP. (List Processor) El lenguaje LISP fue desarrollado por John McCarthy durante el periodo de 1.956 a 1.958, implementándose por primera vez entre 1.959 y 1.962. El trabajo de su autor consistía principalmente en representar información en un lenguaje formal y desarrollar un programa que razonara haciendo inferencias sobre ella. Las representaciones estaban en la forma de estructuras de listas y el lenguaje era una variante del lambda cálculo, tal y como describimos anteriormente con ayuda del diagrama de evolución. Desde 1.962 se han producido varios dialectos del LISP, incluyendo principalmente al MACLISP e INTERLISP. PROLOG. (Programming in Logic) Se diseñó principalmente para las aplicaciones de inteligencia artificial, definiendo objetos y relaciones de inferencia entre clases de objetos. Tiene unos fuertes fundamentos teóricos en el cálculo de proposiciones. Representaba una desviación tajante de las ideas tradicionales sobre comportamiento de programas, las cuales se basaban todas en las arquitecturas de máquina de von Neumann. PROLOG fue desarrollado a principios de los años 70 por Philippe Roussel. Su primer intérprete se implementó en 1.972. Desde entonces, PROLOG no cambió desde su concepción, ni se hizo ningún esfuerzo por estandarizarlo. • Ejemplo de Prolog: Se definen una serie de hechos (persona) sobre varias personas Se define la relación: es-hermana Se plantea una consulta : para determinar de quién es hermana marta • persona (juan, 30, hombre, rosa, luis). • persona (marta, 21, mujer, rosa, luis). • es-hermana (X,Y) :- persona(X, _, mujer, Madre, Padre), • persona(Y, _, _, Madre, Padre). • ? es-hermana(marta,Y). • Y=juan.
  • 13. C y C++. La historia de C, y su versión ampliada, C++, la explicaremos más detenidamente, justo porque son los lenguajes de programación que nosotros utilizaremos durante el curso, además de su enorme importancia hoy en día en todos los ámbitos de la computación. C evolucionó a partir de dos lenguajes previos, BCPL y B. BCPL fue desarrollado en 1.967 por Martin Richards, como un lenguaje para escribir software y compiladores de sistemas operativos. En el lenguaje B, muchas características de BCPL fueron modeladas y se utilizó para crear versiones iniciales de lo que se llegó a denominar UNIX. Ambos lenguajes, BCPL y B eran lenguajes “sin tipo”. Cada elemento de datos ocupaba una palabra en memoria y quedaba a cargo del programador el tratar un elemento de datos como si se tratara de un número entero o de un número real. El lenguaje C fue derivado de B por Dennis Ritchie de los Laboratorios Bell, implantándose por primera vez en 1.972. C al inicio se popularizó como lenguaje de desarrollo del sistema operativo UNIX. Hoy día, virtualmente todos los sistemas están escritosen C y/o C++. C, independiente del hardware, se ha hecho disponible para la mayor parte de las computadoras a lo largo de las últimas décadas. Es posible incluso escribir programas en C que sean portátiles hacia la mayor parte de las computadoras. Hacia finales de los 70, C había evolucionado a lo que hoy se conoce como C “tradicional”. La expansión rápida de C sobre varios tipos de computadoras trajo consigo muchas variantes. Estas eran similares, pero no siempre compatibles. Esto provocaba un problema para los programadores, que necesitaban escribir códigos que pudieran funcionar con distintas máquinas. Así se vieron ante la necesidad de una versión estándar de C, que se aprobó en 1.989. El documento se conoce como ANSI / ISO 9899: 1.990. Más tarde, apareció C++, una mejoría sobre muchas de las características de C, y que proporciona capacidades de programación orientada a objetos que promete mucho para incrementar la productividad, calidad y reutilización del software. Los diseñadores de C y los responsables de sus primeras puestas en práctica nunca anticiparon que este lenguaje resultaría en un fenómeno como éste. Cuando un lenguaje de programación se torna tan arraigado como C, nuevas necesidades demandan que el lenguaje evolucione, en lugar de que sólo sea reemplazado por un nuevo lenguaje, como ya había ocurrido con muchos otros
  • 14. lenguajes, tal y como comentamos antes. C++ fue desarrollado por Bjarne Stroustrup en los Laboratorios Bell y originalmente fue llamado C “con clases”. El nombre C++ incluye el operador de incremento (++) de C, para indicar que C++ es una versión mejorada de C. C++ es un conjunto de C, por lo que, para compilar los programas existentes de C, los programadores pueden utilizar un compilador C++ y posteriormente modificar estos programas a C++. A mediados de los años noventa, la mayor parte de los entornos de programación C se convirtieron a C++. MODULA-2. Podemos considerar, con toda exactitud, al lenguaje MODULA-2 como un descendiente directo y mejorado de su antecesor PASCAL. MODULA“, al igual que su ancestro PASCAL, ha sido desarrollado por el profesor iklaus Wirth, del Instituto Tecnológico de Zurich, como dijimos anteriormente. MODULA-2 nació, de una forma experimental, en 1.975 cuando se hizo necesario disponer de un lenguaje de programación de propósitos generales y que, además, fuera lo suficientemente operativo y cualificado para abordar problemas de multiprogramación, diseño de sistemas, software de base, traductores y compiladores, etc. Como resultado, se realiza la primera implementación de MODULA-2 al proyecto Lilith del ETH de Zurich, con el objetivo de diseñar un sistema completo de hardware y software, y para el que era necesario disponer de un lenguaje de desarrollo sencillo y que pudiera abordar, conjuntamente, problemas resolubles con un lenguaje de alto nivel, y necesidades de programación a bajo nivel o cercana a la estructura de la máquina. DELPHI. En el año 1995 se crea el nuevo sucesor de Pascal, al que se llamó Delphi, siendo la primera herramienta con un entorno de desarrollo visual construida por Borland. Esta caracterizado por ser un lenguaje orientado a eventos, es decir, que la ejecución del programa no es secuencial, sino que depende de los eventos que suceden durante la ejecución de la aplicación. Delphi es una herramienta de Desarrollo Rápido de Aplicaciones (RAD). Los componentes que incorpora facilitan el acceso a bases de datos, comunicación
  • 15. a través de Internet, calidad en impresiones, desarrollo de aplicaciones multimedia, enlaces DDE, componentes OLE y VBX, etc. Borland ha introducido al mercado varias versiones de Delphi, aportando mejoras notables, entre las que cabe destacar el CodeInsight, un asistente que muestra automáticamente las listas de parámetros de procedimientos, métodos y eventos. En el año 2001 Borland lanzo al mercado la versión de Delphi 6.0 que funciona bajo Windows y es compatible con todas las versiones anteriores. Junto con esta versión se introdujo en el mercado la primera versión Kylix, una versión de Delphi que funciona bajo Linux. La ultima versión disponible en el mercado es Delphi 7.0. Entre las nuevas carcteristicas se incluye un nuevo compilador que permite construir aplicaciones basadas en la plataforma .NET JAVA. En 1991 un grupo de ingenieros de Sun Microsystems liderados por Patrick Naughton y James Gosling comienza el desarrollo de un lenguaje destinado a generar programas independientes de la plataforma en la que se ejecutan. Su objetivo inicial nada tiene que ver con lo que hoy en día es Java, sus creadores buscaban un lenguaje para programar los controladores utilizados en la electrónica de consumo. Existen infinidad de tipos de CPU distintas, y generar código para cada una de ellas requiere un compilador especial y el desarrollo de compiladores sabemos que es caro. Después de dieciocho meses de desarrollo aparece la primera versión de un lenguaje llamado OAK que más tarde cambiaría de nombre para convertirse en Java. La versión de 1992 está ampliada, cambiada y madurada, y a principios de 1996 sale a la luz la primera versión de Java. Los inicios son difíciles, no se encuentran los apoyos necesarios en Sun y el primer producto que sale del proyecto, un mando a distancia muy poderoso y avanzado, no encuentra comprador. Pero el rumbo de Java cambiaría debido a una tecnología completamente electrodomésticos: Internet. ajena a los controladores de
  • 16. Mientras Java se estaba desarrollando, el mundo de las comunicaciones crecía a una velocidad de vértigo, Internet y principalmente el mundo World Wide Web dejaban los laboratorios de las universidades y llegaban a todos los rincones del planeta. Se iniciaba una nueva era y Java tuvo la suerte de estar allí y aprovechar la oportunidad. En 1993 con el fenómeno Internet en marcha, los desarrolladores de Java dan un giro en su desarrollo al darse cuenta de que el problema de la portabilidad de código de los controladores es el mismo que se produce en Internet, una red heterogénea y que crece sin parar, y dirigen sus esfuerzos hacia allí. En 1995 se libera una versión de HotJava, un navegador escrito totalmente en Java y es en ese mismo año cuando se produce el anuncio por parte de Netscape de que su navegador sería compatible con Java. Desde ahí otras grandes empresas se unen y Java se expande rápidamente. No obstante, las primeras versiones de Java fueron incompletas, lentas y con errores. Han tenido que pasar varios años de desarrollo y trabajo para que Java sea un lenguaje perfectamente asentado y lleno de posibilidades. Actualmente es ampliamente utilizado en entornos tanto relacionados con Internet como completamente ajenos a la Red. El mundo Java está en constante desarrollo, las nuevas tecnologías surgen y se desarrollan a gran velocidad haciendo de Java un lenguaje cada día mejor y que cubre prácticamente todas las áreas de la computación y comunicaciones, desde teléfonos móviles hasta servidores de aplicaciones. 6.. Generalidades Lenguajes programación Es posible identificar las siguientes dos tendencias en el desarrollo de los lenguajes de programación: La tendencia de los lenguajes programación puede ser enfocada a conceptos, aunque un cierto tipo de lenguaje no debe tratar de incorporar todos estos conceptos.
  • 17. La estructura de un lenguaje de programación implica :< Valores Abstracción Almacenamiento Encapsulamiento Generics Herencia Polimorfismo Concurrencia Regularidad Es mejor proveer un conjunto básico de facilidades que puedan ser refinadas usando otros aspectos del lenguaje (tipos de datos abstractos, objetos). Una forma sencilla de obtener máximo poder es permitiendo la combinación de un número de conceptos en una forma regular y sin restricciones innecesarias o con interacciones sorpresivas. 6.1 Principios generales a. Tipos : Todos los tipos de un lenguaje deben tener el mismo estatus ejemplo: <tipo del valor de retorno> función ( <tipo de los parámetros> ) b. Abstracción: Permitir la abstracción sobre cada clase semánticamente significativa Expresiones Comandos funciones procedimientos Declaraciones Tipos generics tipos parametrizados c. Correspondencia : Para cada forma de declaración debe existir su correspondiente mecanismo de paso de parámetros y viceversa. ------------------d. Calificación Incluir un bloque en cada clase sintáctica que es semánticamente significativa Bloques de comandos Bloques de expresiones
  • 18. Bloques de declaraciones e. Sencillez El lenguaje debe ayudar a resolver problemas. Debe permitir que las soluciones sean expresadas naturalmente. Debe ayudar a descubrir dichas soluciones. Lenguajes grandes y complicados pertenecen al espacio de problemas en lugar del espacio de soluciones.” Ej. Pascal: sencillo, con pocos conceptos pero muy bien escogidos, fácil y rápido de dominar, suficientemente poderoso para resolver un gran variedad de problemas. Un lenguaje complejo puede obtener las ventajas de uno sencillo si se divide en “compartimentos” o módulos. Un programador solo necesita dominar aquellas partes del lenguaje necesarias para resolver su problema. Se deben evitar interacciones inesperadas entre las diferentes partes del lenguaje, pues enviaría al programador a territorio desconocido. Por ejemplo, en PL/I se da el siguiente caso: Al evaluar ’25 + 1 / 3’ da 5.3 debido a las reglas sobre el número de decimales usados en aritmética de punto fijo, esto obliga a todos los programadores a conocer las reglas de aritmética de punto fijo aunque no se parte fundamental del problema que quieren resolver Un programador que no programa el manejo de excepciones, puede producir entonces comportamiento default en el programa . Una función entera usada en un contexto real no produce una conversión (que obligue a conocer cómo lo
  • 19. hace), sino que produce un mensaje de error en términos de no poder localizar una función sobrecargada. Un lenguaje no debe tratar de anticipar todas las facilidades requeridas. Un lenguaje debe permitir la identificación e implementación de las facilidades requeridas. Lo anterior es facilitado por la abstracción: expresiones, comandos, tipos funciones, procedimientos, clases. La sintaxis debe ser transparente: debe ser obvio determinar a partir de la forma sintáctica a cuál concepto semántico se está haciendo referencia. Las formas sintácticas y los conceptos semánticos deben corresponder uno a uno. Contraejemplo La frase “var I: T” en Pascal puede ser la declaración de una nueva variable, o la especificación de un parámetro variable. Una forma sintáctica no debe confundir dos conceptos distintos. procedure hacer_caja (x, y, ancho, alto: Integer); hacer_caja (0, 0, 4, 2); 6.2 Estructura: Valor: cualquier cosa que pueda ser calculada, almacenada, incorporada en una estructura de datos, pasada como argumento a un procedimiento o función, retornada como resultado de una función “ Cualquier entidad que existe durante un cómputo” PascalValores primitivos (valores de verdad, caracteres, valores enumerados, enteros, reales)Valores compuestos (registros, arreglos, conjuntos,
  • 20. archivos)PunterosReferencias a variablesProcedimientos y funciones (abstracciones Bibliografía consultada: Allen B. Tucker, “Lenguajes de programación” Editorial McGraw Hill 2003 H. M Deitel “Cómo programar en C y C++” ,Editorial Prentice Hall, 2000