COBOL 段落编号背后的逻辑是啥?

Posted

技术标签:

【中文标题】COBOL 段落编号背后的逻辑是啥?【英文标题】:What is the logic behind COBOL paragraph numbering?COBOL 段落编号背后的逻辑是什么? 【发布时间】:2018-05-18 07:17:38 【问题描述】:

我多次看到以下段落命名结构:

nnnn-PARAGRAPH-NAME.

nnnn 代表 4 位数字。

这是一个完整的例子:

0000-MAINLINE. 
    PERFORM 1000-INITIALIZE-THE-PROGRAM. 
    PERFORM 2000-PROCESS-1-BILLING-RECORD 
        UNTIL 88-100-ALL-RECORDS-PROCESSED. 
    PERFORM 3000-TERMINATE-THE-PROGRAM. 
    GOBACK. 
1000-INITIALIZE-THE-PROGRAM. 
    PERFORM 1100-VALIDATE-CONTROL-CARD. 
    PERFORM 1200-OPEN-THE-FILES. 
    PERFORM 8000-GET-NEXT-BILLING-RECORD. 
1100-VALIDATE-CONTROL-CARD. 
    PERFORM 1110-READ-CONTROL-CARD. 
    PERFORM 1120-EDIT-CONTROL-CARD. 
1110-READ-CONTROL-CARD. 
    PERFORM 9000-ABEND-THE-PROGRAM.  *> IF A READ ERROR OCCURRED 
1120-EDIT-CONTROL-CARD. 
    PERFORM 9000-ABEND-THE-PROGRAM   *> IF AN EDIT ERROR OCCURRED 
1200-OPEN-THE-FILES. 
    PERFORM 9000-ABEND-THE-PROGRAM   *> IF AN OPEN ERROR OCCURRED 
2000-PROCESS-1-BILLING-RECORD. 
    PERFORM 2100-CALCULATE-BILLABLE-AMT. 
    PERFORM 2200-PRINT-BILLING-REPORT. 
    PERFORM 8000-GET-NEXT-BILLING-RECORD. 
2200-PRINT-BILLING-REPORT. 
    PERFORM 2210-PRINT-REPORT-HEADER.  *> WHEN IT'S NEEDED 
3000-TERMINATE-THE-PROGRAM. 
    PERFORM 3100-CLOSE-THE-FILES. 
    PERFORM 3200-DISPLAY-FINAL-MESSAGES. 
8000-GET-NEXT-BILLING-RECORD. 
    PERFORM 9000-ABEND-THE-PROGRAM.    *> IF A READ ERROR OCCURRED 
9000-ABEND-THE-PROGRAM. 

因此,我的问题如下:

    现在是否已弃用? 为什么这是(或曾经是)一个好的做法? 段落编号遵循哪些标准?

【问题讨论】:

【参考方案1】:

说明

数字告诉您程序结构。在这个程序中:

1*都是初始化过程,1000-...调用1100-...和1200-。而 1100-... 调用 1110-... 和 1120-... 等 2*是主要的处理逻辑程序 3*是终结处理逻辑程序 8000 从任何地方调用 9000错误程序

所以程序调用结构是

                                     0000-
           +---------------------------+------------------------------+                             
         1000-                       2000-                          3000-
  +--------+------+             +------+------+               +-------+-------+ 
1100-           1200-         2100-         2200-           3100-           3200-

 etc...

具体问题

    现在是否已弃用? 绝对不是,它应该用于其他程序语言。了解编号系统 为什么这是(或曾经是)一个好的做法?这是一个很好的做法,因为它告诉你 程序如何相互关联 - 这非常方便。 获取过程的调用结构 提高理解力 节省了大量时间。例如,如果您找到 2000-,您将转到主处理逻辑 段落编号遵循哪些标准?

其他要点

一旦你习惯了编号系统,它会让你更容易理解程序。不同网站的做法不同,有些网站也可能使用字母/而不是数字,例如

      Perform A000-Initialise
      Perform B000-Main
      Perform C000-Finalise

 A000-Initialise.
     Perform A100-...
     etc

在任何一个站点,他们将在所有(或大多数程序)中使用相同的编号标准。

网站可能会为特定目的保留第一个数字/字母。这在使用 A000-、B000- 格式时更为常见。您可以将 R... 用于文件 reads W... 用于文件 writes S... 用于SQL 调用等

编号系统让经验丰富的程序员的生活更轻松。使用过其他语言,应该使用除 Cobol 之外的其他程序语言。

【讨论】:

@MarkSchultheiss 那么在 1000 和 2000 处调用的 FETCH CURSOR 段落应该放在 8000 处吗?干杯! FETCH CURSOR 应该是 8000 - 检查您站点上的其他程序是如何做到的。 也许将“都是初始化程序”改写为“程序初始化程序” 我们处理实用程序类型的东西的方式是启动 Z9000 并在有另一个实用程序时增加数字。所以到处叫的都是Z9开头的。【参考方案2】:

4 位数字实际上并没有用于任何用途,但如果程序结构正确,它可以帮助有经验的程序员了解他们的程序。让我们看看这个例子:

PROCEDURE DIVSION.
0000-MAINLINE.
   PERFORM OPEN-FILES
   PERFORM VALIDATE-CONTENTS
   PERFORM PROCESS-DATA
   PERFORM WRITE-REPORTS
   PERFORM CLOSE-FILES
.
CLOSE-FILE.
   PERFORM CLOSE-FILE1
   PERFORM CLOSE-FILE2
   PERFORM CLOSE-FILE3
.
PROCESS-DATA.
   PERFORM VARYING X 
              FROM 1 BY 1
             UNTIL X > NUMBER-OF-RECS
      PERFORM DO-THE-THINGS
   END-PERFORM
.
WRITE-REPORTS.
   DISPLAY 'THIS IS MY REPOR'.
.
VALIDATE-CONTENTS.
   IF REC NOT EQUAL SPACES
       SET GOOD-REC TO TRUE
   END-IF
.
OPEN-FILES.
   PERFORM OPEN-FILE1
   PERFORM OPEN-FILE2
   PERFORM OPEN-FILE3
.
DO-THE-THINGS.
   CONTINUE
.

我知道这个程序很愚蠢而且没有任何意义,但是对于这个例子来说没关系。尝试遵循该程序的流程。如果我们为每个段落的开头和一个分配一个数字并递增(因此 CLOSE-FILE 为 1,PROCESS-DATA 为 2...),那么主线就像这样跳跃:

5

4

2、6

3

1

对于像这样的小程序来说,“ok”,因为我们仍然可以找到自己的方式。现在想象你的程序有数千行长,而且一切都乱了套。是的,你可以弄清楚,但如果它看起来像这样会不会容易得多:

PROCEDURE DIVSION.
0000-MAINLINE.
   PERFORM A0000-OPEN-FILES
   PERFORM B0000-VALIDATE-CONTENTS
   PERFORM C0000-PROCESS-DATA
   PERFORM D0000-WRITE-REPORTS
   PERFORM E0000-CLOSE-FILES
.
A0000-OPEN-FILES.
   PERFORM OPEN-FILE1
   PERFORM OPEN-FILE2
   PERFORM OPEN-FILE3
.
B0000-VALIDATE-CONTENTS.
   IF REC NOT EQUAL SPACES
       SET GOOD-REC TO TRUE
   END-IF
.
C0000-PROCESS-DATA.
   PERFORM VARYING X 
              FROM 1 BY 1
             UNTIL X > C1000-NUMBER-OF-RECS
      PERFORM DO-THE-THINGS
   END-PERFORM
.
C1000-DO-THE-THINGS.
   CONTINUE
.
D0000-WRITE-REPORTS.
   DISPLAY 'THIS IS MY REPOR'.
.
E0000-CLOSE-FILE.
   PERFORM CLOSE-FILE1
   PERFORM CLOSE-FILE2
   PERFORM CLOSE-FILE3
.

在我的商店中,我们的做法是主线中的所有内容都以字母开头(因此为 A0000)。如果 A0000 调用某段内容,则该段落将被称为 A1000。如果 A1000 调用某个东西,它将是 A1100。所以我们用字符来表示嵌套。所以我可能会有这样的东西:

PROCEDURE DIVSION.
0000-MAINLINE.
   PERFORM A0000-DO-SOMETHING
   PERFORM B0000-SHUTDOWN
.
A0000-DO-SOMETHING.
   PERFORM A1000-DO-MORE
   PERFORM A2000-VALIDATE-STUFF
.
A1000-DO-MORE.
   PERFORM A1100-DO-THING1
   PERFORM A1200-DO-THING2
   PERFORM A1300-DO-THING3
.

简而言之,它仅有助于导航和跟踪程序。没有什么可以阻止您省略数字,但是一旦程序变得更大并且需要其他人维护它,数字将是一个很大的帮助。我讨厌处理结构不正确的程序,因为它使调试和学习程序变得更加困难。特别是当我使用终端模拟器并且一次只能看到 20 行时。

【讨论】:

【参考方案3】:

段落名称只是标签。你可以使用任何你喜欢的格式。然而,为了有用,你应该使用一些标准——你可能会被你的商店标准强迫。编号可以反映您编写它们的顺序、执行的顺序、调用的深度(para1 执行 para2 执行 para3 等),或者您可以使用 alpha 表示。由你(和你的老板)决定。

【讨论】:

以上是关于COBOL 段落编号背后的逻辑是啥?的主要内容,如果未能解决你的问题,请参考以下文章

它的输出背后的逻辑是啥?它为 Break 和 continue 提供相同的输出

Weaviate的KNN分类算法背后的逻辑是啥?

Asp.net 寻呼机点击事件未触发,其背后的逻辑是啥?

TypeScript 错误“'delete' 运算符的操作数必须是可选的”背后的逻辑是啥?

编号 Pipe - Angular 2 的参数是啥

在COBOL中,是不是可以递归调用一个段落?