1. 代码结构
COBOL的源程序的代码主体部分必须从第8列开始(A区域),通常包括分区Division,分段Section和第一级的数据等。
其第7列为指示字符保留,例如*表示注释行,-表示续行等。前6列为行号。第12列开始为B区域,一般是实体内容(代码实现),
第二级以上的数据等。73列开始之后为卡号,现已不使用,但不能作为程序的一部分,编译器会忽略这部分的代码。
COBOL的源程序有一套比较刻板的代码区域划分系统,一般顺序如下:
IDENTIFICATIONDIVSION
标识区,是程序的说明部分。包含PROGRAM-ID和AUTHOR,通常只起到注释作用。
ENVIRONMENT DIVISION
环境区,一般定义执行环境,例如需要用到的文件。
INPUT-OUTPUT SECTION
输入输出段,作为环境区的一部分定义文件句柄和外部文件的关联(如JCL中的DDNAME)
FILE-CONTROL
文件控制定义,这里具体列举文件句柄和关联。
DATA DIVISION
数据区,定义变量(COBOL只有文件域全局变量),文件句柄和数据的关联
FILE SECTION
文件数据关联区
WORKING-STORAGE SECTION
变量定义区
PROCEDURE DIVISION
程序区,定义主程序和若干被主程序使用的子程序。在最前的为主程序。
2. 数据
数据类型
纯数字(Numeric)
无符号 99V99, 9(3)V9(2),等;初值/赋值:
有符号,在前面加S,如S99V99;初值/赋值:+12.34,-32.4,加号或可省略。
字符(Alphanumeric)
X(20),XXX,等
纯字母(Alphabetic)
A(10),AAA,等
数字字符编辑型(Alphanumeric Edited)
B代表空格,/代表斜杠等;赋值 PIC XX/XX VALUE "1230",将得到值"12/30"。
数字编辑型(Numeric Edited)
赋值也需带双引号。
9代表任意数字,0也显示;Z代表任意有效数字,起始0被压制;
-接受任意有效数字,起始只显示负号;+接受任意有效数字,起始显示正号或负号;$接受任意有效数字,起始显示货币号;
负号-可以位于最后;CR/DB用于表示借/贷,当设置在末尾时候,值出现负数时会显示相应的字符(根据设置,显示CR或DB)
数据分级
01 表示第一级,后续可连续或跳跃递增至49,每一级保持一致。
77 表示不依赖其他的单独一级数据。
88 表示标的(Condition-name),它为它的映射数据提供一个真值指标,当映射数据值与之VALUE相等时,这个标的本身被引用时就为TRUE,否则为FALSE;同样当标的在程序中被设置为TRUE时,对应映射数据也会被拖至该对应值。
数据存储和表示
字符
IBM大型主机上,字符一般使用EBCDIC方式存放,类似于ASCII的作用,只是具体排序内容不同。
数字
Zoned Decimal,一个十进制数字占用一个字节,最后一个字节的前四比特表征符号,C表示正,D表示负。其余E比特的前4字节为E。
Packed Decimal,符号4比特置于最后,数字用4字节压紧排放,前导可能有4比特的0填充。
Binary,即最为经济的二进制数字存储。
配置方法是通过字符后的USAGE IS DISPLAY(默认)/PACKED-DECIMAL/BINARY的指定。
别名:Binary又称Comp或Comp-4;Packed decimal又称COMP-3。
3. 控制流
条件判断:
IF 条件
非句断语句组
ELSE
非句断语句组
END-IF.
所谓非句断语句组 指一丛COBOL语句,每个独立的语句之后不用通常的COBOL语句使用的句点句断。这说明整个条件判断代码片是一个COBOL语句。END-IF可以省略,原则是其上内容只含一个语句并句断。可以没有ELSE。
条件表达式元素:
逻辑:AND,OR,NOT,等
比较:<,>,=,<>,等
循环
PERFORM WITH TEST BEFORE/AFTER
[VARYING 变量 FROM 初始值 BY 变化量]
UNTIL 测试条件
非句断语句组
END-PERFORM.
或者
PERFORM 子程序名
[WITH TEST BEFORE/AFTER
[VARYING 变量 FROM 初始值 BY 变化量]
UNTIL 测试条件].
赋值和计算
COBOL使用一些特殊的关键字引导赋值和计算
值传递
MOVE 源 TO 目标
赋值过程需要注意类型兼容性和赋值后果。
计算
COMPUTE 目标 [ROUNDED] = 算式
[ON SIZE ERROR 非句断语句组]
[NOT ON SIZE ERROR 非句断语句组]
[END-COMPUTE].
运算符: +-*/和**(指数)等,注意COBOL中运算符两侧空格不仅是一种良好习惯,而且有时候是一个必须,因为要区分减号和划号。
两个后续语句组分别用于处理目标尺寸错误(通常为过小)或正常的情形。
同样END-COMPUTE遵从语句汇集规则。
加法
格式1:
ADD 若干个加数 TO 若干个被加数(结果) [ROUNDED] 计算后续处理
格式2:
ADD 若干个加数 TO 被加数 GIVING 若干个结果数 [ROUNDED] 计算后续处理
计算后续处理指类似COMPUTE后续的处理,以END-ADD结尾。
注意:多个加数求和后加到被加数;多个结果指运算独立输出到多个结果。
减法,类似加法只是用SUBTRACT FROM(英语语法);乘法用MULTIPLY BY,且两侧只能各有一个操作数。
除法
DIVIDE 除数 INTO 若干个被除数 [ROUNDED]
DIVIDE (被)除数 BY/INTO (被)除数 GIVING商数
[ROUNDED]
DIVIDE (被)除数 BY/INTO (被)除数 GIVING 商数 [ROUNDED] REMAINDER 余数
4. 字符串处理
5. 数组和表
6. 文件处理
一般文件使用
1. 在FILE-CONTROL中定义文件句柄
2. 在FILE-SECTION中定义关联数据变量
3. 在程序中打开和关闭文件
4. 在程序中读取或写入文件
定义句柄:
SELECT 句柄名 ASSIGN TO 外部名(DDNAME) [附加参数]
打开文件:
OPEN INPUT/OUTPUT/I-O/EXTEND 文件句柄 .
关闭文件:
CLOSE 文件句柄.
读文件用READ语句,作用在句柄上,数据会自动读入到关联数据中,该数据的长度和文件的记录长度一致。
写文件用WRITE语句,作用在关联数据上,如下形式:
WRITE 关联数据变量名 AFTER ADVANCING [行数 LINES/PAGE].
索引文件 (Indexed File)
对应于VSAM的KSDS。
【顺序访问】
定义句柄的附加参数:
ORGANIZATION IS INDEXED
ACCESS IS SEQUENTIAL
RECORD KEY IS 键变量.
其中键变量是一个跟踪当前记录主键值的变量。
【随机访问】
定义句柄的附加参数:
ORGANIZATION IS INDEXED
ACCESS IS RANDOM
RECORD KEY IS 键变量.
可以用START和定义键变量值来寻找第一个符合要求的记录。
【动态访问】
定义句柄的附加参数:
ORGANIZATION IS DYNAMIC
ACCESS IS RANDOM
RECORD KEY IS 键变量.
相对文件 (Relative File)
对应于VSAM的RSDS。
【顺序访问】
定义句柄的附加参数为:
ORGANIZATION IS RELATIVE
ACCESS IS SEQUENTIAL.
读取:
READ 文件句柄名 [NEXT] RECORD [INTO 数据变量名]
[AT END 未句断语句组]
[NOT AT END 未句断语句组]
[END-READ]
【随机访问】
定义句柄的附加参数为:
ORIGANIZATION IS RELATIVE
ACCESS IS RANDOM
RELATIVE KEY IS 键变量.
“键变量”是一个数据变量,定义在WORKING-STORAGE 中,它必须能覆盖所有的相对记录。
读取:
READ 文件句柄名 RECORD [INTO 数据变量名]
[INVALID KEY 未句断语句组]
[NOT INVALID KEY 未句断语句组]
[END-READ]
7. 内部函数
调用方式
FUNCTION 函数名 [(参数组)]
重要函数
NUMVAL(字符变量),尝试将字符变量转换为数字
NUMVAL-C(货币变量),尝试将货币变量转换为数字
8. 外部子程序
分享到:
相关推荐
在IT领域,IBM大型主机(Mainframe)因其强大的处理能力和稳定性而备受推崇,尤其在金融、电信、政府等关键行业的核心业务系统中占据着重要地位。这些系统通常运行在IBM的大型主机操作系统之上,如z/OS、z/VSE或z/...
总之,IBM的大型主机不仅是技术发展的见证者,也是现代企业IT基础设施不可或缺的一部分。随着技术的进步和市场需求的变化,大型主机将继续发挥其独特的作用,并在未来的信息技术领域占据一席之地。
IBM大型主机,通常被称为Mainframe,是企业级计算的核心设备,尤其在金融、保险、电信等关键行业,其稳定性和处理能力备受赞誉。本实验课件主要围绕IBM大型主机的操作系统进行,帮助学习者深入理解并掌握大型主机的...
IBM大型主机,全称为IBM Mainframe,是IBM公司推出的一种高性能、高稳定性的企业级计算平台,被广泛应用于金融、电信、政府等关键业务领域。本课件主要围绕IBM大型主机的操作系统——z/OS展开,旨在为初学者提供一个...
IBM大型机,通常被称为Mainframe,是IBM公司推出的一种高性能、高可靠性的计算机系统,主要用于处理大规模的事务处理、数据库管理、以及企业级的应用。在金融、电信、保险等行业,IBM Mainframe因其卓越的性能、安全...
IBM z/OS 是运行在IBM大型机上的主要操作系统之一,它提供了高度可靠、安全且可扩展的环境,支持各种企业级应用程序和服务。 ### 重要内容 #### 1. 大型机的历史与发展 - **System/360**:作为IBM历史上一个重要...
### IBM Mainframe基础知识 #### IBM大型机的历史发展与技术特点 IBM主框架计算机(Mainframe)自诞生以来一直是计算领域的核心部分,...对于企业和组织来说,IBM主框架计算机仍然是处理关键任务应用的最佳选择之一。
综上所述,IBM Mainframe 大型机不仅是一种高性能计算平台,还代表了一套完整的生态系统,涵盖了操作系统、应用程序、技术支持等多个方面。对于希望深入了解大型机技术及其应用场景的学习者而言,这些资料是非常宝贵...
《大型主机数据库基础与应用开发》是一门深入探讨大型主机环境下数据库管理和开发的教程,主要针对IBM的大型主机系统和DB2数据库系统。这门课程由同济大学的唐剑锋教授讲授,旨在帮助学生理解和掌握大型主机数据库的...
在IT行业中,IBM大型主机(Mainframe)是一个关键的话题,特别是在企业级的高并发、大数据处理和稳定性需求的场景下。MVS(Multiple Virtual Storage,多虚拟存储)和ZOS(z/OS,z系列操作系统)是IBM大型主机操作...
Hercules,全称Hercules-390,是这个领域的开源项目之一,它允许用户在x86架构的PC上运行IBM大型机的操作系统,如MVS、OS/390、VM/CMS等。PCOM5.7可能是指模拟环境中的一种通信协议或组件,用于模拟IBM大型机上的...
大型机Mainframe是计算机科学领域中的一个重要组成部分,尤其在金融、电信和保险等行业,它扮演着核心系统的关键角色。这个“大型机Mainframe资料全集”涵盖了多个与Mainframe相关的主题,包括操作系统OS390、数据库...
Z/OS是IBM为大型主机开发的操作系统之一,专门用于zSeries服务器。Z/OS提供了丰富的功能和服务,支持各种高级特性,例如多层安全性、大规模并行处理等。此外,Z/OS还能够支持多种编程语言和工具,便于开发和维护复杂...
【IBM主机系统导论授课PPT】是一份深入讲解IBM主机系统的培训材料,适用于初学者和专业人士提升对这一核心技术的理解。IBM主机系统,通常指的是IBM大型机(Mainframe),是企业级计算的重要平台,以其高可靠性、安全...
主要用在IBM的大型计算机(Mainframe Computer)上,在VSE、VM、OS/400、AIX、OS/2其他的IBM平台上也可以找到它的解译器或编译器。但在大部份其他的平台上也可以找到它的解译器或编译器。另有面向对象的版本,成为...
五大国有银行——中国银行、农业银行、工商银行、建设银行、交通银行的核心系统均建立在IBM大型机之上,外资银行如花旗、汇丰、渣打等也有类似部署。此外,大型机还在制造业,如宝钢及其下属的宝信软件,以及其他...
PL/I,Programming Language No.1,是IBM大型机操作系统上的一种重要编程语言,尤其在金融、航空和制造业等领域有着广泛的应用。由于其特性,PL/I成为了处理大规模事务处理和科学计算的理想选择。本教程将介绍PL/I的...
IBM Mainframe汇编手册是一本全面介绍IBM Mainframe环境下高阶汇编语言使用的指南。该手册不仅为初学者提供了入门指导,同时也为高级用户提供深入的技术细节。尽管现在可能较少使用到这种汇编语言,但在特定领域或对...
Ibm MAINFRAME TSO JCL COBOL VSAM DB2 CICS
**CICS IBM 主机系统**(Customer Information Control System)是IBM为主机系统(Mainframe)设计的一种事务处理程序,主要用于支持大型企业的业务交易处理、数据库访问及连接管理等关键业务流程。它为开发者提供了...