Saltar para o conteúdo

COBOL

Origem: Wikipédia, a enciclopédia livre.


COBOL
COBOL Report Apr60
A capa do COBOL 60 relatório para CODASYL (Abril de 1960)
Paradigma Procedural, imperativa, orientada a objetos
Surgido em 1959 (1959) há 65 anos.
Última versão ISO / IEC 1989: 2014 especifica.
Criado por Grace Hopper, William Selden, Gertrude Tierney, Howard Bromberg, Howard Discount, Vernon Reeves, Jean E. Sammet.
Estilo de tipagem Forte e estática
Dialetos ACUCOBOL-GT, COBOL-TI, COBOL / 2, dezembro COBOL-10, a DEC VAX COBOL, DOSVS COBOL, COBOL Fujitsu, Hitachi COBOL2002, HP3000 COBOL / II, IBM COBOL AEA, IBM COBOL / 400, IBM COBOL / II, IBM empresa COBOL, IBM ILE COBOL, IBM OS / VS COBOL, ICL COBOL (VME), isCOBOL, Micro Focus COBOL, Microsoft COBOL, Realia COBOL, Ryan McFarland RM / COBOL, Ryan McFarland RM / COBOL85, Tandem (NonStop) COBOL85 , em tandem (NonStop) SCOBOL, UNIVAC COBOL, Unisys MCP COBOL74, Unisys MCP COBOL85, Unix COBOL X / Open, Veryant isCOBOL, Visual COBOL, Wang VS COBOL
Influenciada por FLOW-MATIC, COMTRAN, FACT
Influenciou PL/I, CobolScript, ABAP

COBOL (sigla de COmmon Business Oriented Language) - Linguagem Comum Orientada para os Negócios é uma linguagem de programação orientada para o processamento de banco de dados comerciais.[1] É a linguagem de programação inteira mais usada, produto do Departamento de Defesa norte-americano sob a direção da contra-almirante Grace Murray Hopper.[2]

A linguagem ainda é amplamente utilizada em sistemas legados armazenados em mainframes. Entretanto, devido à sua baixa popularidade e à aposentadoria dos programadores experientes, muitos dos sistemas estão sendo migrados para novas plataformas e reescritos em linguagens mais modernas. Atualmente, a maior parte do código em COBOL existe essencialmente para manter aplicações existentes.

As especificações do COBOL 2002 incluem suporte à programação orientada a objetos e outras características das linguagens modernas.[3]

História e especificação

[editar | editar código-fonte]

O COBOL foi criado por um comitê de investigadores de várias instituições civis e governamentais durante o segundo semestre de 1959. As especificações eram em grande parte inspiradas na linguagem de programação FLOW-MATIC inventada pela Grace Hopper - referida como "a mãe da língua COBOL."

A linguagem de programação da IBM COMTRAN inventada por Bob Bemer também foi utilizada, mas a especificação da FACT da Honeywell tinha sido distribuída até tarde aos membros do comitê do processo, e teve relativamente pouco impacto.

O uso corrente e o estudo do FLOW-MATIC como a única linguagem do grupo de estudo que efetivamente tinha sido utilizada numa situação real, fez com que fosse bastante atractiva ao comitê.[4]

Em 8 de abril de 1959, na CODASYL (Conference on Data Systems Language) destinada a usuários e pessoas da universidade, no centro de computação da Universidade da Pensilvânia, o Departamento de Defesa dos Estados Unidos, posteriormente, concordou em patrocinar e supervisionar as próximas atividades. A reunião presidida por Charles A. Phillips foi realizada no Pentágono em 28/29 de maio de 1959 (exatamente um ano após a reunião em Zurique do ALGOL 58), não foi decidido definir de três comissões: de curto, médio e longo alcance (a última nunca foi realmente formada).

Foi o Comitê de Curto Prazo, presidido por Joseph Wegstein do National Bureau of Standards (NBS) que durante os meses seguintes criou uma descrição da primeira versão do COBOL.[5]

O Comitê de Curto Prazo foi constituído por membros representantes de seis fabricantes de computadores e três órgãos governamentais, a saber: Burroughs Corporation, IBM, Minneapolis-Honeywell (Honeywell Labs), RCA, Sperry Rand, Sylvania Electric Products, a Força Aérea dos Estados Unidos, o David Taylor Model Basin (DTMB) e o NBS. Este comitê foi presidido por um membro do NBS.

Um comitê de Médio Prazo e outro de Longo Prazo foram também propostos na reunião do Pentágono. Entretanto, embora tenha sido formado, o Comitê de Médio Prazo nunca chegou a funcionar; e o Comitê de Longo Prazo nem chegou a ser formado. Por fim, um subcomitê do Comitê de Curto Prazo desenvolveu as especificações da linguagem COBOL. Este subcomitê era formado por seis pessoas:

  • William Selden e Gertrude Tierney da IBM
  • Howard Bromberg e Howard Discount da RCA
  • Vernon Reeves e Jean E. Sammet da Sylvania Electric Products[6]

A decisão de usar o nome "COBOL" foi feita em uma reunião do comitê realizada em 18 de setembro de 1959. O subcomitê completou as especificações para o COBOL em dezembro de 1959.

O primeiro compilador para COBOL foi posteriormente implementado em 1960 e em 6/7 de dezembro, essencialmente o mesmo programa COBOL funcionou em dois computadores diferentes, um computador RCA e uma Remington-Rand Univac, demonstrando que a compatibilidade pode ser alcançada.[7]

ANS COBOL 1968

[editar | editar código-fonte]

Depois de 1959 o COBOL-1968 sofreu várias modificações e melhorias. Na tentativa de superar o problema da incompatibilidade entre diferentes versões de COBOL, o American National Standards Institute (ANSI) desenvolveu uma forma padrão de língua, em 1968, após o lançamento da versão COBOL-61 que se tornou a pedra angular para mais versões. Esta versão ficou conhecida como American National Standard (ANS) COBOL.

Em 1974, a ANSI publicou uma versão revista do COBOL-1968, que continha uma série de recursos que não estavam na versão 1968.[7]

Em 1985, a ANSI publicou ainda uma outra versão revista do COBOL-1985 que tinha novas funcionalidades que não apareciam no padrão 1974, como construções de linguagem mais notavelmente estruturadas ("terminadores de escopo"), incluindo END-IF, END-PERFORM, END-READ, etc.

História de normas COBOL

[editar | editar código-fonte]

As especificações aprovadas por todo o Comitê de Curto Prazo foram aprovadas pelo Comitê Executivo em 3 de janeiro de 1960, e enviadas para a gráfica do governo que editou e imprimiu essas especificações como COBOL 60.

O American National Standards Institute (ANSI) produziu várias revisões do padrão COBOL, incluindo:

Após as alterações de 1985 o padrão ANSI (que era adotado pela ISO), o desenvolvimento e a apropriação foi assumida pela ISO. As seguintes edições e TRs (Relatórios Técnicos) foram emitidas pelo padrão ISO (e adotados como ANSI):

  • COBOL 2002
  • Finalizer Technical Report - 2003
  • Native XML syntax Technical Report - 2006
  • Bibliotecas de coleção de classes orientadas a objeto - aprovação pendente

Desde 2002, o padrão ISO também está disponível para o público codificado como ISO / IEC 1989.

O trabalho progride na próxima revisão integral da norma COBOL. A aprovação e disponibilidade era esperado primeiros em 2010. Para obter informações sobre esta revisão, ver o mais recente projeto desta revisão, ou para ver o que as outro trabalhos em progresso no padrão COBOL, consulte o site de normas do COBOL.

COBOL Orientado a Objetos

[editar | editar código-fonte]

A linguagem de programação de computadores COBOL continua a evoluir até hoje. No início de 1990, decidiu-se acrescentar a orientação a objetos na próxima revisão completa do COBOL. A estimativa inicial era ter esta revisão concluída em 1997 e um ISO CD (Committee Draft, rascunho do comitê) disponível até 1997.

Assim como a C++ e a Java, os compiladores COBOL estão disponíveis enquanto a linguagem se move em direção à padronização.

Alguns fornecedores (incluindo a Micro Focus, a Fujitsu, a Hitachi, a Veryant e a IBM) introduziram a sintaxe orientada a objetos, com base nos rascunhos de 1997 ou outro da revisão completa.

A Fujitsu, a Micro Focus e a Raincode PL/1 atualmente suportam os compiladores COBOL orientados a objetos visando o .NET.[8]

ISO COBOL 2002

[editar | editar código-fonte]

A versão ISO COBOL 2002, é uma versão do COBOL que foi criado no padrão ISO (adotado como um padrão ANSI por INCITS)[9] que foi aprovada e disponibilizada em 2002, e foi projetado para ser utilizado em servidor mainframe, como por exemplo: IBM,[10] HITACHI,[11] etc.

O ISO COBOL 2002 incluiu diversos recursos extras, além da orientação a objetos, (mas não estão limitados a):

  • Suporte a idiomas (incluindo, mas não limitado a suporte ao Unicode)
  • Processamento baseado em Locale
  • Funções amigáveis ao usuário
  • CALL (e função) protótipos (para a verificação de parâmetro em tempo de compilação)
  • Ponteiros e sintaxe para a obtenção/liberação de armazenagem
  • Convenções de chamada de e para línguas não-COBOL, como C
  • Suporte para execução em ambientes estruturas como .NET e Java (incluindo COBOL instanciado como Enterprise JavaBeans)
  • Suporte a Bit e Bool
  • Suporte a "True", até esta melhoria itens binários eram truncados (pela especificação de base-10) dentro da DATA DIVISION.
  • Suporte a ponto flutuante
  • Resultados aritméticos padrão (ou portáteis)
  • Geração e parsing de XML

Microsoft COBOL

[editar | editar código-fonte]

O Microsoft COBOL é uma versão de COBOL orientado a objetos que é utilizado dentro do Microsoft Visual Studio .NET. O Cobol é uma linguagem de alto nível projetada para uso em negócios, e que usa comandos com sintaxe em inglês. A Microsoft começou cedo produzindo produtos de idiomas como este. Seus outros produtos de idiomas antigos incluíam Microsoft Fortran, Microsoft Pascal, Microsoft Visual Basic e Macro Assembler. Este produto também foi licenciado para a IBM como IBM Cobol Compiler. Atualmente o Microsoft COBOL está na versão 5.0 disponível para download.[12][13]

Micro Focus Visual COBOL

[editar | editar código-fonte]

A empresa Micro Focus produz o software Micro Focus Visual COBOL[14] que é uma versão do COBOL orientado a objetos, projetado para uso em sistema operacional Windows, com suporte para execução em ambiente .NET.

O compilador Livre/Aberto COBOL que produz executáveis nativos a partir do código-fonte. A atual versão (3.2), funciona em plataformas como Linux, BSD, muitos sistemas Unix proprietários, MacOs, Windows, dentre outros. Esta é a melhor versão para os usuários, extensivamente testada em uma variedade de ambientes comerciais.

Algumas das suas características incluem:

  • Integração com a Linguagem de Programação C (linguagem de programação);
  • 19 Dialetos;
  • Declarações REPORT SECTION, SCREEN SECTION e FUNCTION-ID;
  • Instalação do compilador COBOL 2014, com conjunto de características;
  • Mais de 9740 testes NIST COBOL;
    • 85 testes passados;
    • mais de 1000 verificações internas;
  • Depuração integrada do IDE e Suporte ao GNU Gbd.

A versão recente inclui muitas novas características que mantém a completa compatibilidade com a fonte. Alguns dos destaques são:

  • Manipulação melhorada do dialeto, incluindo alterações de incumprimentos para melhor correspondência do dialeto selecionado, um novo dialeto completo GCOS e apoio para mais declarações de COBOL, funções intrínsecas e sintaxe de ambos os "velhos" e novos dialetos.
  • Tempo de execução altamente melhorado para várias declarações, juntamente com menos uso de memória, especialmente se as verificações de tempo de execução estiverem ativadas.
  • Alterações no arquivo para o suporte a LINE-SEQUENTIAL por COBOL2023 e opções de tempo de execução de modo a manusear arquivos. (Veja NEWS e runtime.cfg).
  • Otimizações para a depuração em nível de fonte via GDB e coredump.

Muitas outras características mantém uma completa compatibilidade com a fonte. Veja o arquivo NEWS para uma completa descrição da versão disponibilizada, assim como para compilações com qualquer -std para saber mais sobre as implicações.

ISO / IEC 1989: 2014

[editar | editar código-fonte]

Linguagem de programação COBOL

[editar | editar código-fonte]

ISO / IEC 1989: 2014 especifica a sintaxe e semântica do COBOL. Seu objetivo é promover um alto grau de independência da máquina para permitir o uso de COBOL em uma variedade de sistemas de processamento de dados.[15]

ISO / IEC 1989: 2014 especifica:

  • a forma de um grupo de compilação escrito em COBOL;
  • o efeito de compilar um grupo de compilação;
  • o efeito da execução de unidades de execução;
  • os elementos da linguagem para os quais uma implementação conforme é necessária para fornecer uma definição;
  • os elementos da linguagem para os quais o significado é explicitamente indefinido;
  • os elementos da linguagem que dependem dos recursos do processador.

ISO / IEC 1989: 2014 não especifica:

  • os meios pelos quais um grupo de compilação escrito em COBOL é compilado em código executável por um processador;
  • o momento no qual o método, função ou módulos de tempo de execução do programa são vinculados ou vinculados a uma instrução de ativação, exceto que a ligação de tempo de execução ocorre por necessidade quando a identificação do programa ou método apropriado não é conhecido no tempo de compilação;
  • o momento em que as classes e interfaces parametrizadas são expandidas;
  • o mecanismo pelo qual as localidades são definidas e disponibilizadas em um processador;
  • a forma ou conteúdo das mensagens de erro, sinalização ou aviso;
  • a forma e o conteúdo das listagens produzidas durante a compilação, se houver;
  • a forma de documentação produzida por um implementador de produtos em conformidade com esta Norma;

Fujitsu NET COBOL

[editar | editar código-fonte]

A empresa Fujitsu produz o software Fujitsu NET COBOL que é uma versão do COBOL orientado a objetos, projetado para uso em servidor mainframe, com suporte para execução em ambiente .NET.[16][17][18]

A empresa IBM nos últimos anos já produziu o software IBM COBOL em diversas versões: IBM OS/VS COBOL, IBM COBOL/II, IBM COBOL SAA, IBM Enterprise COBOL, IBM COBOL/400, IBM ILE COBOL, projetado para uso em servidor mainframe, com suporte para execução em ambiente com sistema operacional compatível com UNIX. A versão mais atualizada dele é o "IBM Enterprise COBOL for z/OS".[19][20][20]

Os programas criados em linguagem COBOL estão em uso globalmente em agências governamentais e militares além de empresas comerciais, e estão sendo executados em sistemas operacionais como o da IBM z/OS e z/VSE, as famílias POSIX (Unix / Linux, etc) e Windows da Microsoft, bem como Unisys |OS 2200.

Em 1997, o Gartner Group relatou que 80% dos negócios do mundo rodavam em COBOL com mais de 200 bilhões de linhas de código existentes e cerca de 5 bilhões de linhas de código novo por ano.[21]

Características

[editar | editar código-fonte]

O COBOL teve como meta servir como uma linguagem de programação para negócios. Os programas para negócios não precisam de cálculos tão precisos como os encontrados em engenharia, assim o COBOL foi concebido basicamente com as características:[22]

  • Acesso rápido e atualização de arquivos e bases de dados;
  • Geração de uma grande quantidade de informações; e
  • Saída com um formato compreensível ao usuário.

O COBOL é geralmente a linguagem escolhida em cálculos financeiros por suportar aritmética inteira aplicada a números muito grandes (milhões, bilhões etc) ao mesmo tempo que é capaz de lidar com números muito pequenos como frações de centavos. Outra característica é a formatação,[23] classificação e geração de relatórios.[2]

Um exemplo do programa "Olá, Mundo" em COBOL:

      IDENTIFICATION DIVISION.
      PROGRAM-ID. HELLO-WORLD.
      PROCEDURE DIVISION.
          DISPLAY 'Ola, mundo'.
          STOP RUN.


Existem vários dialetos do COBOL. Alguns compiladores, por exemplo, permitem o uso de aspas duplas, além do padrão de aspas simples:

      DISPLAY "Hello, world".

Olá, OS/360 cerca de 1972

[editar | editar código-fonte]

Em um IBM System/360 executando OS/360 MVT 21.8f, por volta de 1972, o teste Olá, Mundo teria levado cartões perfurados de 80 colunas, contendo o código-fonte semelhante a:

//COBUCLG  JOB CLASS=A,MSGCLASS=A,MSGLEVEL=(1,1)
//HELOWRLD EXEC COBUCLG,PARM.COB='MAP,LIST,LET'
//COB.SYSIN DD *
  001  IDENTIFICATION DIVISION.
  002  PROGRAM-ID.  'HELLO'.
  003  ENVIRONMENT DIVISION.
  004  CONFIGURATION SECTION.
  005  SOURCE-COMPUTER.  IBM-360.
  006  OBJECT-COMPUTER.  IBM-360.
  0065 SPECIAL-NAMES.
  0066     CONSOLE IS CNSL.
  007  DATA DIVISION.
  008  WORKING-STORAGE SECTION.
  009  77  HELLO-CONST   PIC X(12) VALUE 'HELLO, WORLD'.
  075  PROCEDURE DIVISION.
  090  000-DISPLAY.
  100      DISPLAY HELLO-CONST UPON CNSL.
  110      STOP RUN.
//LKED.SYSLIB DD DSNAME=SYS1.COBLIB,DISP=SHR
//            DD DSNAME=SYS1.LINKLIB,DISP=SHR
//GO.SYSPRINT DD SYSOUT=A
//

Estrutura básica

[editar | editar código-fonte]

No COBOL há três tipos básicos de dados usados nas instruções:[23]

  • Numérico (sinalizado ou não, com decimal ou inteiros)
  • Alfanumérico
  • Constantes figurativas

O COBOL consiste basicamente em quatro divisões separadas:[24]

  • IDENTIFICATION DIVISION

A IDENTIFICATION DIVISION possui informações documentais, como nome do programa, quem o codificou e quando essa codificação foi realizada.

  • ENVIRONMENT DIVISION

A ENVIRONMENT DIVISION descreve o computador e os periféricos que serão utilizados pelo programa.

  • DATA DIVISION

A DATA DIVISION descreve os arquivos de entrada e saída que serão usadas pelo programa. Também define as áreas de trabalho e constantes necessárias para o processamento dos dados.

  • PROCEDURE DIVISION

A PROCEDURE DIVISION contém o código que irá manipular os dados descritos na DATA DIVISION. É nesta divisão que o desenvolvedor descreverá o algoritmo do programa.

  IDENTIFICATION DIVISION
  ENVIRONMENT DIVISION
    * CONFIGURATION SECTION
    * INPUT-OUTPUT SECTION
  DATA DIVISION
    * FILE SECTION
    * WORKING-STORAGE SECTION
    * LOCAL-STORAGE SECTION
    * LINKAGE SECTION
    * COMMUNICATION SECTION
    * REPORT SECTION
    * SCREEN SECTION
  PROCEDURE DIVISION

Área de codificação no COBOL

[editar | editar código-fonte]

Colunas Descrição

1 a 6  	branco (será preenchido com a numeração COBOL)
  7 	        (branco) LINHA DE CODIFICAÇÃO
               * (asterisco) linha de comentário
               - (hífen) continuação de literal não numérico
8 a 72  	instruções do COBOL iniciando na coluna 8

Críticas e defesas

[editar | editar código-fonte]

Falta de estruturalismos

[editar | editar código-fonte]

Na década de 1970, a adoção da programação estruturada paradigma estava se tornando cada vez mais difundido. Edsger Dijkstra , um cientista da computação proeminente, escreveu uma carta ao editor de Comunicações da ACM , publicado 1975, intitulado "Como podemos dizer verdades que possam ferir?", No qual ele foi crítico de COBOL e várias outras linguagens contemporâneas; observando que "o uso de COBOL aleija a mente". Em uma dissidência publicado para observações de Dijkstra, o cientista da computação Howard E. Tompkins afirmou que não estruturada COBOL tendiam a ser "escrito por programadores que nunca tiveram o benefício de estruturada COBOL ensinou bem", argumentando que a questão era primariamente um de treinamento.

Uma causa de código espaguete foi o GO TOcomunicado. As tentativas para remover GO TOs de código COBOL, no entanto, resultou em programas complicados e qualidade do código reduzida. GO TOs foram em grande parte substituído pela declaração PERFORM e procedimentos, que promoveu a programação modular e deu fácil acesso aos meios de looping poderosos. No entanto, PERFORMsó poderia ser usado com procedimentos tão corpos de loop não foram localizados onde foram usados, fazendo programas mais difícil de entender.

Programas COBOL foram infame por ser monolítico e sem modularização. COBOL código só pode ser modularizado através de procedimentos, os quais se verificou serem inadequados para grandes sistemas. Era impossível restringir o acesso aos dados, significando que um procedimento poderia acessar e modificar qualquer item de dados. Além disso, não havia maneira de passar parâmetros para um procedimento, uma omissão Jean Sammet considerado como maior erro do comitê. Outra complicação resultou da capacidade de PERFORM THRUuma sequência específica de procedimentos. Isto significava que o controle poderia saltar para e retornar a partir de qualquer procedimento, a criação de fluxo de controle complicado e permitindo um programador para quebrar a regra - saída única de entrada única.

Esta situação melhorou como COBOL adotada mais recursos. COBOL-74 subprogramas adicionados, dando programadores a capacidade para controlar os dados de cada parte do programa pode aceder. COBOL-85, em seguida, acrescentou subprogramas aninhados, permitindo que programadores pudessem esconder subprogramas. Além disso controle sobre os dados e código veio em 2002, quando a programação orientada a objetos, funções e tipos de dados, definidos pelo usuário, foram incluídos.

No entanto, muito mais importante software legado COBOL usa código não estruturados, que se tornou insustentável. Ele pode ser muito arriscado e caro para modificar ainda uma seção de código simples, uma vez que pode ser usado a partir de lugares desconhecidos em caminhos desconhecidos.

Problemas de compatibilidade após normalização

[editar | editar código-fonte]

O COBOL 85 não era totalmente compatível com as versões anteriores, resultando nem um "parto de cesariana" do COBOL 85. Joseph T. Brophy, CIO, St. Paul Travelers (Travelers Insurance), lideraram uma força-tarefa para informar aos usuários de COBOL dos pesados custos de reprogramação para implementar o novo padrão. Como resultado, o Comitê ANSI do COBOL recebeu mais de 3.200 cartas do público, em sua maioria negativas, exigindo que o comitê fizesse as alterações. Por outro lado, a conversão para COBOL 85 foi pensada para aumentar a produtividade nos próximos anos, justificando, assim, os custos de conversão.[25]

Sintaxe verbosa

[editar | editar código-fonte]

A sintaxe da COBOL tem sido muitas vezes criticada por sua verbosidade.[23] No entanto, os defensores notam que isto foi intencional no projeto da linguagem, e muitos a consideram um dos pontos fortes da COBOL. Um dos objetivos do projeto de COBOL foi que gerentes, supervisores e usuários não-programadores pudessem ler e entender seu código. É por isso que a COBOL tem o inglês como sintaxe e elementos estruturais, incluindo: substantivos, verbos, orações, frases, seções e divisões. Consequentemente, a COBOL é considerada por pelo menos uma fonte a ser "A linguagem de programação mais legível, compreensível e documentada em uso hoje. [...] Não só esta legibilidade geralmente auxilia o processo de manutenção, mas quanto mais velho um programa se tornar, mais valiosa se torna essa legibilidade."[26] Por outro lado, a mera capacidade de ler e entender algumas linhas de código da COBOL não concede a um executivo ou usuário final a experiência e os conhecimentos necessários para projetar, construir e manter sistemas de software de grande porte.

Isolamento da área acadêmica

[editar | editar código-fonte]

Nenhum acadêmico da ciência da computação participou do projeto do COBOL: todos do comitê faziam parte da área comercial ou do governo. Enquanto o COBOL procurava resolver problemas de processamento de arquivos comerciais, os cientistas da computação estavam mais interessados em campos como análise numérica, física e programação de sistemas. O desdém dos acadêmicos pelo processamento de dados empresariais e a não participação de cientistas da computação influentes no projeto da linguagem contribuíram para a impopularidade do COBOL.

Outras defesas

[editar | editar código-fonte]

Além disso, tradicionalmente a COBOL é uma linguagem simples, com alcance limitado da função (sem ponteiros, sem tipos definidos pelo usuário e sem funções definidas pelo usuário),[27] estimulando um estilo de codificação simples. Isso fez com que seja bem adequada ao seu domínio principal de computação de negócios, onde a complexidade do programa encontra-se em regras de negócio que precisam ser codificados em vez de sofisticados algoritmos e estruturas de dados. E porque a norma não pertence a nenhum fornecedor em particular, os programas escritos em COBOL são altamente portáteis. A língua pode ser utilizada numa grande variedade de plataformas de hardware e sistemas operativos. E sua estrutura hierárquica rígida restringe a definição de referências externas para a Divisão de Ambiente (environment division), o que simplifica a mudança de plataforma em particular.[26]

Outras linguagens de programação de terceira geração:

  • Lawrence R. Newcomer, Cobol Estruturado, 1985, Editora: Schaum McGraw-Hill, ISBN 0-07-450315-4
  • Renato Erich Kleiber, Cartão de Referência: Cobol 80, Editora: Livros Técnicos e Científicos Editora S/A, ISBN 85-216-0411-4
  • Garfunkel, Jerome (1987). The COBOL 85 example book. New York: Wiley. ISBN 0-471-80461-4 

Referências

  1. Márcia Regina Sawaya. Dicionario De Informatica & Internet. NBL Editora; 1999. ISBN 978-85-213-1099-0. p. 83.
  2. a b Stephen R. Schach. Engenharia de Software. McGraw Hill Brasil; ISBN 978-85-63308-44-3. p. 465.
  3. Rui Bivar De Oliveira. The Power of Cobol: For Systems Developers of the 21st Century. Booksurge Llc; 30 May 2006. ISBN 978-0-620-34652-8.
  4. Jean_Sammet, The Early History of COBOL, p.121–161, ACM SIGPLAN Notices, Association for Computing Machinery, Inc., 1978
  5. Garfunkel, Jerome (1987). The Cobol 85 Example Book. New York: Wiley. ISBN 0-471-80461-4 
  6. Wexelblat, Richard (1981). History of Programming Languages. Boston: Academic Press. ISBN 0-12-745040-8 
  7. a b Atul Kahate. Object Oriented Analysis & Design. Tata McGraw-Hill Education; ISBN 978-0-07-058376-4. p. 420.
  8. NetCOBOL for .NET supports COBOL migration and software development in the .NET environment
  9. As grandes mudanças do ISO COBOL 2002
  10. COBOL 2002 – The Good, the Bad, and the UGLY Session 8204 (August 25, 2005)
  11. The COBOL2002 Family - HITACHI
  12. Usando COBOL na plataforma Microsoft.NET - Visual Studio .NET
  13. «Microsoft COBOL 5.0». WinWorld. Consultado em 7 de abril de 2021 
  14. «COBOL Programming | Visual COBOL | Micro Focus». www.microfocus.com. Consultado em 7 de abril de 2021 
  15. 14:00-17:00. «ISO/IEC 1989:2014». ISO (em inglês). Consultado em 13 de setembro de 2020 
  16. «Fujitsu Software NetCOBOL - Fujitsu Global». www.fujitsu.com. Consultado em 7 de abril de 2021 
  17. «Migração de mainframe e midrange COBOL para NetCOBOL - Fujitsu Brazil». www.fujitsu.com. Consultado em 7 de abril de 2021 
  18. «Fujitsu Progression. Mainframe e Midrange para .NET - Fujitsu Brazil». www.fujitsu.com. Consultado em 7 de abril de 2021 
  19. «IBM Enterprise COBOL for z/OS - O que é - Brasil». www.ibm.com. 7 de abril de 2021. Consultado em 7 de abril de 2021 
  20. a b «IBM Docs». www.ibm.com (em inglês). 1 de janeiro de 2021. Consultado em 7 de abril de 2021 
  21. Kizior, Ronald J.; Carr, Donald; Halpern, Paul. «Does COBOL Have a Future?» (PDF). The Proceedings of the Information Systems Education Conference 2000. 17 (126). Consultado em 30 de setembro de 2012 
  22. Behrouz A. Forouzan; Sophia Chung Fegan. Foundations of Computer Science: From Data Manipulation to Theory of Computation. Cengage Learning Editores; 2003. ISBN 978-970-686-285-3. p. 197.
  23. a b c "(...)para escrever um simples programa em Cobol são necessárias muitas linhas de código, o que torna a linguagem não muito fácil de aprender.", Mario Leite. Técnicas de Programação - Uma Abordagem Moderna. Brasport; ISBN 978-85-7452-229-6. p. 191.
  24. Earl H. Parsons. Structured Programming with COBOL Examples. [S.l.]: iUniverse. p. 41. ISBN 978-0-595-25094-3 
  25. Garfunkel, Jerome (1987). The COBOL 85 example book. New York: Wiley. ISBN 0-471-80461-4 
  26. a b COBOL Tutorial - Introduction to COBOL
  27. "Em COBOL não há funções, mas podemos utilizar o comando PER- FORM para executar sub-rotinas." Cleuton Sampaio. Web 2.0 e Mashups - Reinventando a Internet. Brasport; 2007. ISBN 978-85-7452-338-5. p. 46.

Ligações externas

[editar | editar código-fonte]