COBOL

De Wikipedia, la enciclopedia libre
COBOL (Common Business-Oriented Language)
Organización Internacional de Normalización, CODASYL e Instituto Nacional Estadounidense de Estándares
Información general
Extensiones comunes cbl, cob y cpy
Paradigma orientado a objetos[1][2]​, imperativo, programación por procedimientos
Apareció en 1959[3]
Influido por FLOW-MATIC
COBOL programa informático

El lenguaje COBOL (acrónimo de COmmon Business-Oriented Language, Lenguaje Común Orientado a Negocios) fue creado en el año 1959 con el objetivo de crear un lenguaje de programación universal que pudiera ser usado en cualquier ordenador y que estuviera orientado principalmente a los negocios, es decir, a la llamada informática de gestión. COBOL se utiliza principalmente en sistemas comerciales, financieros y administrativos para empresas y gobiernos. COBOL todavía se usa ampliamente en aplicaciones implementadas en ordenadores centrales, como trabajos de lote y procesamiento de transacciones a gran escala. Sin embargo, debido a su popularidad decreciente y al retiro de los programadores COBOL experimentados, los programas se están migrando a nuevas plataformas, reescribiéndolos en lenguajes modernos o reemplazándolos con paquetes de software.[4]​ La mayor parte de la programación en COBOL ahora es puramente para mantener las aplicaciones existentes; sin embargo, muchas instituciones financieras grandes todavía estaban desarrollando nuevos sistemas en COBOL hasta 2006.[5]

Historia[editar]

En la creación de este lenguaje participó la comisión CODASYL, compuesta por fabricantes de ordenadores, usuarios y el Departamento de Defensa de Estados Unidos en mayo de 1959. La definición del lenguaje se completó en poco más de seis meses, siendo aprobada por la comisión en enero de 1960. El lenguaje COBOL fue diseñado inspirándose en el lenguaje Flow-Matic de la oficial Grace Hopper y el IBM COMTRAN de Bob Bemer, ya que ambos formaron parte de la comisión.

Gracias a la ayuda de los usuarios COBOL evolucionó rápidamente y fue revisado de 1961 a 1965 para añadirle nuevas funcionalidades. En 1968 salió la primera versión ANSI del lenguaje, siendo revisada posteriormente en 1974 (COBOL ANS-74), 1985 (COBOL ANS-85, ampliado en 1989 con funciones matemáticas, finalizando el estándar actual más usado, conocido como COBOL-ANSI), y en 2002 (COBOL ANS-2002).

El último estándar es el COBOL 2014 que entre otras, incluye una nueva característica que permite gestión dinámica de la memoria (OCCURS DYNAMIC).

Existe una versión IBM Enterprise Cobol, actualizada regularmente y lanzada en 1991, usada en sistemas Host (Mainframe) bajo z/OS.

Para Windows y Linux, hay varios compiladores e IDE-s que existen desde hace tiempo y se siguen modernizando.

  • MicroFocus Visual Object COBOL For Windows 95 (el IDE más antiguo permitiendo crear GUI-s, soporta WinAPI)
  • MicroFocus NetExpress (el IDE ya moderno permitiendo interactuar con Java, EJB, C. También OO COBOL (orientado a objetos))
  • MicroFocus Visual COBOL para Visual Studio y Eclipse (el IDE actual, con WebServices)
  • RM/COBOL, ahora propiedad de Microfocus, originalmente de la compañía Ryan & McFarland, quienes desarrollaron el compilador y el runtime
  • Fujitsu COBOL
  • Fujitsu NetCOBOL for Windows
  • Fujitsu NetCOBOL for .NET
  • Fujitsu PowerCOBOL (forma parte del paquete NetCOBOL for Windows, creando aplicaciones GUI basadas en controles ActiveX, soporta WinAPI).

También actualmente existen:

  • GnuCOBOL (antiguo Open COBOL, que es Open Source)
  • Raincode COBOL
  • COBOL-IT

Características[editar]

  • COBOL fue diseñado para escribir programas autodocumentados, mediante separación en divisiones para la declaración de variables de los procedimientos y una división para llevar un registro de quién solicitó el programa y quiénes lo escribieron. A pesar de sus objetivos la estructura que tenía en su inicio era insuficiente para la estructura modular que requieren los sistemas de los negocios corporativos.
  • Sus tipos de datos estaban pensados para manejar archivos ordenados, por lo que cuenta con estructuras para registros y variantes y la declaración de claves para los archivos indexados.
  • Tipos de datos atómicos que se definen mediante la palabra clave PICTURE se pueden definir campos estructurados. Lo que permite definir números con los que se evita errores de redondeo en los cálculos que se producen al convertir los números a binario y que son inaceptables en temas comerciales, COBOL puede emplear y emplea por defecto números en base diez.
  • Para facilitar la creación de programas en COBOL, la sintaxis del mismo fue creada de forma que fuese parecida al idioma inglés, evitando el uso de símbolos que se impusieron en lenguajes de programación posteriores.

Pese a esto, a comienzos de los ochenta se fue quedando anticuado respecto a los nuevos paradigmas de programación y a los lenguajes que los implementaban. En la revisión de 1985 se solucionó, incorporando a COBOL variables locales, recursividad, reserva de memoria dinámica y programación estructurada.

En la revisión de 2002 se le añadió orientación a objetos, aunque desde la revisión de 1974 se podía crear un entorno de trabajo similar a la orientación a objetos, y un método de generación de pantallas gráficas estandarizado.

Antes de la inclusión de las nuevas características en el estándar oficial, muchos fabricantes de compiladores las añadían de forma no estándar. En la actualidad este proceso se está viendo con la integración de COBOL con Internet. Existen varios compiladores que permiten emplear COBOL como lenguaje de scripting y de servicio web. También existen compiladores que permiten generar código COBOL para la plataforma .NET y EJB.


La estructura de un Programa en Cobol se compone de 4 Divisiones.

  1. IDENTIFICATION DIVISION: Es el identificador del programa, lleva los datos de información , nombre de autor fecha de compilación etc.
  2. ENVIRONMENT DIVISION: Indica los recursos de hardware donde se ejecuta el programa, así como la asignación de salida de información por medios de comunicación.
  3. DATA DIVISION: En esta división se establecen las variables que serán utilizadas por el sistema y la declaración de archivos.
  4. PROCEDURE DIVISION: Como su nombre lo indica se ejecuta las instrucciones codificadas.

Programa Hola mundo[editar]

       IDENTIFICATION DIVISION.
       PROGRAM-ID.    HOLAMUNDO.
       AUTHOR.        ANONIMO.
       
       ENVIRONMENT DIVISION.
       CONFIGURATION SECTION.
       SOURCE-COMPUTER.   RMCOBOL-85.
       OBJECT-COMPUTER.   RMCOBOL-85.

       INPUT-OUTPUT SECTION.
       FILE-CONTROL.

       DATA DIVISION.
       FILE SECTION.

       WORKING-STORAGE SECTION.     
             
       PROCEDURE DIVISION.
       
           DISPLAY 'Hola mundo'

           GOBACK

           ..

.

Empleo[editar]

Pese a que muchas personas creen que el lenguaje COBOL está en desuso, la realidad es que casi todos los sistemas que requieren gran capacidad de procesamiento por lotes (Batch), tanto las entidades bancarias como otras grandes empresas con sistemas mainframes utilizan COBOL. Esto permite garantizar la compatibilidad de los sistemas antiguos con los más modernos, así como tener la seguridad de que el lenguaje es perfectamente estable y probado. Según un informe de Gartner Group de 2005, el 75% de los datos generados por negocios son procesados por programas creados en COBOL, y en otro informe de 1997 estima que el 80% de los 300.000 millones de líneas de código existentes están creados en COBOL, escribiéndose 5000 millones de líneas nuevas de COBOL cada año. Con todo eso, hoy por hoy, la programación en COBOL es uno de los negocios más rentables del mundo de la informática. En el resto de aplicaciones el COBOL ha caído en desuso, reemplazado por lenguajes más modernos o versátiles.

Recepción[editar]

Falta de estructura[editar]

En la década de 1970, la adopción del paradigma de programación estructurada se estaba generalizando cada vez más. Edsger Dijkstra, un preeminente informático, escribió una carta al editor de Comunicaciones de la ACM, publicada en 1975 titulada "¿Cómo decimos verdades que podrían doler?", en la que fue crítico con COBOL y varios otros lenguajes contemporáneos; remarcando que "el uso de COBOL paraliza la mente".[6]​ En una discrepancia publicada a los comentarios de Dijkstra, el científico informático Howard E. Tompkins afirmó que el COBOL no estructurado tendía a ser "escrito por programadores que nunca han tenido el beneficio de COBOL estructurado bien enseñado", argumentando que el problema era principalmente uno de entrenamiento.[7]

Una de las causas del código espagueti fue la declaración GO TO. Los intentos de eliminar GO TOs del código COBOL, sin embargo, resultó en programas intrincados y calidad de código reducida.[8]GO TOs fueron reemplazados en gran parte por las declaraciones y procedimientos PERFORM, que promovió la programación modular[8]​ y dio fácil acceso a potentes instalaciones de bucle. Sin embargo, PERFORM podría usarse solo con procedimientos para que los cuerpos de los bucles no se ubicaran donde se usaron, lo que dificultaba la comprensión de los programas.[9]

Los programas COBOL eran famosos por ser monolíticos y carecer de modularización.[10]​ El código COBOL solo podía modularizarse a través de procedimientos, que resultaron ser inadecuados para sistemas grandes. Era imposible restringir el acceso a los datos, lo que significa que un procedimiento podía acceder y modificar cualquier elemento de datos. Además, no había forma de pasar parámetros a un procedimiento, una omisión que Jean Sammet consideró como el mayor error del comité.[11]​ Otra complicación procedía de la capacidad de PERFORM THRU una secuencia específica de procedimientos. Esto significaba que el control podía saltar y regresar de cualquier procedimiento, creando un flujo de control intrincado y permitiendo que un programador rompiera la regla entrada única, salida única.[12]

Esta situación mejoró a medida que COBOL adoptó más características. COBOL-74 agregó subprogramas, brindando a los programadores la capacidad de controlar los datos a los que podía acceder cada parte del programa. COBOL-85 luego agregó subprogramas anidados, lo que permitió a los programadores ocultar subprogramas.[13]​ Un mayor control sobre los datos y el código llegó en 2002 cuando se incluyeron la programación orientada a objetos, las funciones definidas por el usuario y los tipos de datos definidos por el usuario.

Sin embargo, gran parte del software COBOL heredado importante utiliza código no estructurado, que se ha vuelto imposible de mantener. Puede ser demasiado arriesgado y costoso modificar incluso una simple sección de código, ya que puede usarse desde lugares desconocidos de formas desconocidas.[14]

Problemas de compatibilidad[editar]

COBOL estaba destinado a ser un lenguaje "común" altamente portátil. Sin embargo, para 2001, se habían creado alrededor de 300 dialectos.[15]​ Una fuente de dialectos era el propio estándar: el estándar de 1974 estaba compuesto por un núcleo obligatorio y once módulos funcionales, cada uno con dos o tres niveles de soporte. Esto permitió 104 976 variantes oficiales.[16]

COBOL-85 no era totalmente compatible con versiones anteriores y su desarrollo fue controvertido. Joseph T. Brophy, el CIO de Travellers Insurance, encabezó un esfuerzo para informar a los usuarios de COBOL sobre los altos costos de reprogramación de implementar el nuevo estándar.[17]​ Como resultado, el comité ANSI COBOL recibió más de 2200 cartas del público, en su mayoría negativas, que solicitaban al comité que hiciera cambios. Por otro lado, se pensaba que la conversión a COBOL-85 aumentaría la productividad en años futuros, justificando así los costos de conversión.[18]

Sintaxis detallada[editar]

Un lenguaje débil, verboso y fofo que utilizan los codificadores para hacer cosas aburridas y sin sentido en mainframes de dinosaurios. [...] Su mismo nombre rara vez se pronuncia sin expresiones rituales de disgusto u horror.
The Jargon File 4.4.8.[19]

La sintaxis de COBOL a menudo ha sido criticada por su verbosidad. Los defensores dicen que esto tenía la intención de hacer el código autodocumentado, facilitando el mantenimiento del programa.[20]​ COBOL también estaba destinado a ser fácil de aprender y usar para los programadores,[21]​ sin dejar de ser legible para el personal no técnico, como los gerentes.[22][23][24][25]​ El deseo de legibilidad condujo al uso de elementos estructurales y sintácticos similares al inglés, como sustantivos, verbos, cláusulas, oraciones, secciones y divisiones. Sin embargo, en 1984, los mantenedores de los programas COBOL luchaban por lidiar con el código "incomprensible".[24]​ y los principales cambios en COBOL-85 estaban allí para ayudar a facilitar el mantenimiento.[26]

Jean Sammet, miembro del comité de corto alcance, señaló que "se hizo un pequeño intento por atender al programador profesional, de hecho, las personas cuyo principal interés es la programación tienden a estar muy descontentas con COBOL", lo que atribuyó a la sintaxis detallada de COBOL.[27]

Aislamiento de la comunidad informática[editar]

La comunidad COBOL siempre ha estado aislada de la comunidad informática. Ningún informático académico participó en el diseño de COBOL: todos los miembros del comité procedían del comercio o el gobierno. Los informáticos de la época estaban más interesados en campos como el análisis numérico, la física y la programación de sistemas que en los problemas comerciales de procesamiento de archivos que abordaba el desarrollo de COBOL.[28]​ Jean Sammet atribuyó la impopularidad de COBOL a una "reacción snob" inicial debido a su falta de elegancia, la falta de científicos informáticos influyentes que participaran en el proceso de diseño y el desdén por el procesamiento de datos comerciales.[29]​ La especificación COBOL usó una "notación" única, o metalenguaje, para definir su sintaxis en lugar de la nueva forma Backus-Naur que el comité no conocía. Esto resultó en críticas "severas".[30][31][32]

El mundo académico tiende a considerar COBOL como prolijo, torpe y poco elegante, y trata de ignorarlo, aunque probablemente haya más programas y programadores COBOL en el mundo que FORTRAN, ALGOL y PL/I combinados. En su mayor parte, solo las escuelas con un objetivo vocacional inmediato brindan instrucción en COBOL.

Más tarde, COBOL sufrió una escasez de material que lo cubriera; los libros introductorios tardaron hasta 1963 en aparecer (con Richard D. Irwin publicando un libro de texto universitario sobre COBOL en 1966).[34]​ Para 1985, había el doble de libros sobre FORTRAN y cuatro veces más sobre BASIC que sobre COBOL en la Biblioteca del Congreso.[35]​ Los profesores universitarios enseñaban lenguajes y técnicas más modernos y de última generación en lugar de COBOL, que se decía que tenía una naturaleza de "escuela de comercio".[36]​ Donald Nelson, presidente del comité CODASYL COBOL, dijo en 1984 que "los académicos ... odian COBOL" y que los graduados en informática "tenían 'odio COBOL' en ellos".[37]

A mediados de la década de 1980, también hubo una condescendencia significativa hacia COBOL en la comunidad empresarial por parte de los usuarios de otros lenguajes, por ejemplo FORTRAN o ensamblador, lo que implica que COBOL podría usarse solo para problemas no-desafiantes.[38]

En 2003, COBOL figuraba en el 80% de los planes de estudio de sistemas de información en los Estados Unidos, la misma proporción que C++ y Java.[39]​ Diez años después, una encuesta realizada por Micro Focus encontró que el 20 % de los académicos universitarios pensaban que COBOL estaba desactualizado o muerto y que el 55 % creía que sus estudiantes pensaban que COBOL estaba desactualizado o muerto. La misma encuesta también encontró que solo el 25 % de los académicos tenían programación COBOL en su plan de estudios, aunque el 60 % pensó que deberían enseñarla.[40]

Preocupaciones sobre el proceso de diseño[editar]

Se han planteado dudas sobre la competencia del comité de normas. El miembro del comité a corto plazo, Howard Bromberg, dijo que había "poco control" sobre el proceso de desarrollo y que estaba "plagado por la discontinuidad del personal y... la falta de talento".[41]​ Jean Sammet y Jerome Garfunkel también señalaron que los cambios introducidos en una revisión del estándar se revertirían en la siguiente, debido tanto a los cambios en quién estaba en el comité del estándar como a la evidencia objetiva.[42]

Los estándares COBOL han sufrido repetidamente retrasos: COBOL-85 llegó cinco años más tarde de lo esperado,[43]​ COBOL 2002 se retrasó cinco años,[44]​ y COBOL 2014 se retrasó 6 años[45][46]​ Para combatir los retrasos, el comité de estándares permitió la creación de apéndices opcionales que agregarían características más rápidamente que esperando la próxima revisión del estándar. Sin embargo, algunos miembros del comité expresaron su preocupación por las incompatibilidades entre las implementaciones y las frecuentes modificaciones del estándar.[47]

Influencias en otros idiomas[editar]

Las estructuras de datos de COBOL influyeron en los lenguajes de programación posteriores. Su estructura de registros y archivos influyó en PL/I y Pascal, y la cláusula REDEFINES fue un predecesor de los registros variantes de Pascal. Las definiciones explícitas de estructuras de archivos precedieron al desarrollo de sistemas de administración de bases de datos y los datos agregados fueron un avance significativo sobre las matrices de Fortran.[35]​ Las declaraciones de datos de PICTURE se incorporaron a PL/I, con cambios menores.

La facilidad de COBOL con COPY, aunque se considera "primitivo",[48]​ influyó en el desarrollo de directivas include.[35]

El enfoque en la portabilidad y la estandarización significó que los programas escritos en COBOL pudieran ser portátiles y facilitó la difusión del lenguaje a una amplia variedad de plataformas de hardware y sistemas operativos.[49]​ Además, la estructura de división bien definida restringe la definición de referencias externas a la División de Entorno, lo que simplifica los cambios de plataforma en particular.[50]

En los medios[editar]

  • En el código que se ve de la programación del cyborg de la película The Terminator (1984), algunas de las sentencias están escritas en Cobol.[51]

Referencias[editar]

  1. «What is COBOL?». OpenText (en inglés). Consultado el 6 de noviembre de 2023. 
  2. «Evolution of the COBOL Language at Micro Focus Since 1985». www.microfocus.com (en inglés). Consultado el 6 de noviembre de 2023. 
  3. «What is COBOL?». www.microfocus.com (en inglés). Consultado el 6 de noviembre de 2023. 
  4. Mitchell, Robert L. (14 de marzo de 2012). «Brain drain: Where Cobol systems go from here». Computerworld. Consultado el 9 de febrero de 2015. 
  5. Mitchell, Robert L. (4 de octubre de 2006). «Cobol: Not Dead Yet». Computerworld. Consultado el 27 de abril de 2014. 
  6. Dijkstra, Edsger W. (18 de junio de 1975). «How do we tell truths that might hurt?». University of Texas at Austin. EWD498. Archivado desde el original el 2 de mayo de 2017. Consultado el 29 de agosto de 2007. 
  7. Tompkins, H. E. (1983). «In defense of teaching structured COBOL as computer science». ACM SIGPLAN Notices 18 (4): 86-94. S2CID 33803213. doi:10.1145/948176.948186. 
  8. a b Riehle, 1992, p. 125.
  9. Shneiderman, 1985, pp. 349–350.
  10. Coughlan, Michael (16 de marzo de 2014). Beginning COBOL for Programmers. Apress. p. 4. ISBN 978-1430262534. Consultado el 13 de agosto de 2014. 
  11. Sammet, 1978b, p. 258.
  12. Riehle, 1992, p. 126.
  13. Riehle, 1992, p. 127.
  14. «COBOL and Legacy Code as a Systemic Risk | naked capitalism» (en inglés estadounidense). 19 de julio de 2016. Consultado el 23 de julio de 2016. 
  15. Lämmel, Ralf; Verhoef, Chris (November–December 2001). «Cracking the 500-language problem». IEEE Software 18 (6): 79. doi:10.1109/52.965809. hdl:1871/9853. Archivado desde el original el 19 de agosto de 2014. 
  16. Howkins, T. J.; Harandi, M. T. (April 1979). «Towards more portable COBOL». The Computer Journal 22 (4): 290. doi:10.1093/comjnl/22.4.290. 
  17. Garfunkel, 1987, p. 11.
  18. Garfunkel, 1987, p. 15.
  19. Raymond, Eric S. (1 de octubre de 2004). «COBOL». The Jargon File, version 4.4.8. Archivado desde el original el 30 de agosto de 2014. Consultado el 13 de diciembre de 2014. 
  20. Brown, 1976, p. 53.
  21. CODASYL, 1969, § II.1.1.
  22. Shneiderman, 1985, p. 350.
  23. Sammet, 1961, p. 381.
  24. a b Conner, 1984, p. ID/10.
  25. Marcotty, 1978a, p. 263.
  26. «Expert addresses Cobol 85 standard». Computerworld 19 (37): 41, 48. 16 de septiembre de 1985. 
  27. Conner, 1984, p. ID/14.
  28. Sammet, 1961, p. 380.
  29. Marcotty, 1978a, p. 266.
  30. Sammet, 1978b, p. 255.
  31. Shneiderman, 1985, pp. 348–349.
  32. Bemer, 1971, p. 133.
  33. Conway, Richard; Gries, David (1973). An Introduction to Programming: A Structured Approach using PL/1 and PL/C. Cambridge, Massachusetts: Winthrop Publishers. p. 341. ISBN 0-87626-405-4. 
  34. «COBOL Logic and Programming, third edition 1974». Archivado desde el original el 5 de marzo de 2016. Consultado el 25 de febrero de 2016. 
  35. a b c Shneiderman, 1985, p. 349.
  36. Shneiderman, 1985, p. 351.
  37. «An interview: Cobol defender». Computerworld 18 (37): ID/29-ID/32. 10 de septiembre de 1984. Consultado el 8 de junio de 2014. 
  38. Pratt, Terrence W.; Zelkowitz, Marvin V. (1984). Programming Languages: Design and Implementation (2nd edición). Englewood Cliffs, N.J. : Prentice Hall. ISBN 0136780121. 
  39. Carr y Kizior, 2003, p. 13.
  40. «Academia needs more support to tackle the IT skills gap». Micro Focus. 7 de marzo de 2013. Consultado el 4 de agosto de 2014. 
  41. Beyer, 2009, p. 301.
  42. Sammet, Jean; Garfunkel, Jerome (October 1985). «Summary of Changes in COBOL, 1960–1985». Annals of the History of Computing 7 (4): 342. S2CID 17940092. doi:10.1109/MAHC.1985.10033. 
  43. Cook, Margaret M. (June 1978). Ghosh, Sakti P.; Liu, Leonard Y., eds. Data Base Facility for COBOL 80. 1978 National Computer Conference. Anaheim, California: AFIPS Press. pp. 1107-1112. LCCN 55044701. doi:10.1109/AFIPS.1978.63. Consultado el 2 de septiembre de 2014. «The earliest date that a new COBOL standard could be developed and approved is the year 1980 [...].» 
  44. Saade, Henry; Wallace, Ann (October 1995). «COBOL '97: A Status Report». Dr. Dobb's Journal. Archivado desde el original el 22 de abril de 2014. Consultado el 21 de abril de 2014. 
  45. «COBOL Standards». Micro Focus. Archivado desde el original el 31 de marzo de 2004. Consultado el 2 de septiembre de 2014. 
  46. «Resolutions from WG4 meeting 24 – June 26–28, 2003 Las Vegas, Nevada, USA» (doc). 11 de julio de 2003. p. 1. Archivado desde el original el 8 de marzo de 2016. Consultado el 29 de junio de 2014. «a June 2008 revision of the COBOL standard». 
  47. Babcock, Charles (14 de julio de 1986). «Cobol standard add-ons flayed». Computerworld 20 (28): 1, 12. 
  48. Marcotty, 1978b, p. 274.
  49. Esto se puede ver en:
  50. Coughlan, Michael (2002). «Introduction to COBOL». Consultado el 3 de febrero de 2014. 
  51. «The Terminator. Trivia (en IMDb)» (en inglés). Consultado el 10 de julio de 2011. 

Migración de Cobol MainFrame

Bibliografía[editar]

Véase también[editar]

Enlaces externos[editar]