首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在cobol中添加两个整数,给出不需要的结果

在cobol中添加两个整数,给出不需要的结果
EN

Stack Overflow用户
提问于 2020-09-21 08:45:39
回答 1查看 196关注 0票数 1

我正在将一个文件读取到一个表中,注意第一行不是表的一部分。

代码语言:javascript
复制
1000
MS 1 - Join Grps    Group Project       5             5             
Four Programs       Programming         15            9             
Quiz 1              Quizzes             10            7             
FORTRAN             Programming         25            18            
Quiz 2              Quizzes             10            9             
HW 1 - Looplang     Homework            20            15            

在代码中,表表示如下:

代码语言:javascript
复制
01     GRADES.
05         GRADE OCCURS 1 TO 100 TIMES DEPENDING ON RECORD-COUNT INDEXED BY J.
10            ASSIGNMENT-NAME   PIC X(20).
10            CATEGORY          PIC X(20).
10            POINTS-POSSIBLE   PIC 9(14).
10            POINTS-EARNED     PIC 9(14).

我还有几个其他的累加器变量,用来计算以后的总和/百分比。

代码语言:javascript
复制
01     RECORD-COUNT             PIC 9(8) VALUE 0.
01     TOTAL-EARNED-POINTS      PIC 9(14).
01     TOTAL-POSSIBLE-POINTS    PIC 9(14) VALUE 0.

我的问题是,当我逐行阅读记录时,我想做以下工作:

代码语言:javascript
复制
ADD POINTS-EARNED(RECORD-COUNT) TO TOTAL-EARNED-POINTS

其中RECORD-COUNT是迭代中的当前位置。我期望第一次迭代后的TOTAL-EARNED-POINTS值只是5,对吗?但是,当我DISPLAY总分的值时,控制台会读到:

代码语言:javascript
复制
50000000000000

这是50万亿吗?或者它是数字5的一个滑稽的表示法?我怎么写这个,这样我才能用它做正确的数学来打印一份适当的分数报告?

编辑:我知道可能有更好的方法来编写这个程序,但在尝试编写这个程序之前,我从未使用过cobol,而且我可能不会再使用它,或者至少在很长一段时间内。这是一个类,所以只要我能正确地打印我的输出,我就很好。到目前为止,完整代码:

代码语言:javascript
复制
IDENTIFICATION DIVISION.
PROGRAM-ID. GRADEREPORT.
AUTHOR. JORDAN RENAUD.
DATE-WRITTEN. 09/18/2020.

ENVIRONMENT DIVISION.
INPUT-OUTPUT SECTION.
FILE-CONTROL.
       SELECT GRADES-FILE ASSIGN TO "bill"
           ORGANIZATION IS LINE SEQUENTIAL
           ACCESS IS SEQUENTIAL.

DATA DIVISION.
FILE SECTION.
FD GRADES-FILE.
01     INPUT-TOTAL-POINTS       PIC 9(4).
01     INPUT-GRADES.
05         INPUT-GRADE OCCURS 1 to 100 TIMES DEPENDING ON RECORD-COUNT INDEXED BY I.
10            INPUT-ASSIGNMENT-NAME   PIC X(20).
10            INPUT-CATEGORY          PIC X(20).
10            INPUT-POINTS-POSSIBLE   PIC 9(14).
10            INPUT-POINTS-EARNED     PIC 9(14).

WORKING-STORAGE SECTION.
77     GRADES-FILE-EOF          PIC 9.
01     RECORD-COUNT             PIC 9(8) VALUE 0.
01     TOTAL-EARNED-POINTS      PIC 9(4) VALUE ZERO.
01     TOTAL-POSSIBLE-POINTS    PIC 9(14) VALUE 5.
01     K                        PIC 9(14) VALUE 1.
01     TMP                      PIC 9(14).
01     CURRENT-CATEGORY         PIC X(20).
01     CATEGORY-WEIGHT          PIC X(3).
01     LAST-CATEGORY            PIC X(20).
01     TOTAL-POINTS             PIC 9(4).
01     GRADES.
05         GRADE OCCURS 1 TO 100 TIMES DEPENDING ON RECORD-COUNT INDEXED BY J.
10            ASSIGNMENT-NAME   PIC X(20).
10            CATEGORY          PIC X(20).
10            POINTS-POSSIBLE   PIC 9(14).
10            POINTS-EARNED     PIC 9(14).

PROCEDURE DIVISION.
       OPEN INPUT GRADES-FILE.
       READ GRADES-FILE INTO TOTAL-POINTS.
       DISPLAY TOTAL-EARNED-POINTS
       PERFORM UNTIL GRADES-FILE-EOF = 1
           READ GRADES-FILE
              AT END SET
              GRADES-FILE-EOF TO 1
              NOT AT END
                 ADD 1 TO RECORD-COUNT
                 MOVE INPUT-GRADES TO GRADE(RECORD-COUNT)
                 SET TOTAL-EARNED-POINTS UP BY POINTS-EARNED(RECORD-COUNT)
                 DISPLAY TOTAL-EARNED-POINTS
           END-READ
       END-PERFORM.
       CLOSE GRADES-FILE.
       DISPLAY TOTAL-EARNED-POINTS.
       SORT GRADE ASCENDING CATEGORY.
       MOVE CATEGORY(1) TO LAST-CATEGORY.
       PERFORM RECORD-COUNT TIMES
           MOVE CATEGORY(K) TO CURRENT-CATEGORY
           IF CURRENT-CATEGORY = LAST-CATEGORY THEN
              DISPLAY "SAME CATEGORY"
           ELSE
              DISPLAY "NEW CATEGORY"
              MOVE LAST-CATEGORY TO CURRENT-CATEGORY
           END-IF
           SET K UP BY 1
       END-PERFORM
       DISPLAY GRADES.
       STOP RUN.

编辑2:在实现给定的答案以将输入从文件转换为数字表单时,表的第一行读得很好,但从那时起,它都是空值。下面是READ块的新代码,我不确定是否有一种更有效的方法来读取和转换组字段中的特定字段,但我假设应该这样做。

代码语言:javascript
复制
PERFORM UNTIL GRADES-FILE-EOF = 1
           READ GRADES-FILE
              AT END SET
              GRADES-FILE-EOF TO 1
              NOT AT END
                 ADD 1 TO RECORD-COUNT

                 MOVE INPUT-ASSIGNMENT-NAME(RECORD-COUNT) TO ASSIGNMENT-NAME(RECORD-COUNT)
                 DISPLAY INPUT-ASSIGNMENT-NAME(RECORD-COUNT)
                 DISPLAY ASSIGNMENT-NAME(RECORD-COUNT)

                 MOVE INPUT-CATEGORY(RECORD-COUNT) TO CATEGORY(RECORD-COUNT)
                 DISPLAY INPUT-CATEGORY(RECORD-COUNT)
                 DISPLAY CATEGORY(RECORD-COUNT)

                 MOVE FUNCTION NUMVAL (INPUT-POINTS-POSSIBLE(RECORD-COUNT)) TO POINTS-POSSIBLE(RECORD-COUNT)
                 DISPLAY INPUT-POINTS-POSSIBLE(RECORD-COUNT)
                 DISPLAY POINTS-POSSIBLE(RECORD-COUNT)

                 MOVE FUNCTION NUMVAL (INPUT-POINTS-EARNED(RECORD-COUNT)) TO POINTS-EARNED(RECORD-COUNT)
                 DISPLAY INPUT-POINTS-EARNED(RECORD-COUNT)
                 DISPLAY POINTS-EARNED(RECORD-COUNT)

                 COMPUTE TOTAL-EARNED-POINTS = TOTAL-EARNED-POINTS + POINTS-EARNED(RECORD-COUNT)
                 DISPLAY TOTAL-EARNED-POINTS
           END-READ
       END-PERFORM.
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-21 10:39:03

是数字5的一个滑稽的表示法吗?

不,这是一个未经检查的致命异常:EC-DATA-INCOMPATIBLE

原因是:

您的数据定义和记录定义不匹配:

10分-赢得的事先知情同意9(14)。

将会是

代码语言:javascript
复制
 "00000000000005"

代码语言:javascript
复制
 "5             "

看起来更好的定义是

代码语言:javascript
复制
10 SOME-POSSIBILY-NUMERIC-DATA PIC X(14).

如果您按照标记所建议的那样使用GnuCOBOL,那么将-debug添加到编译命令中,您将看到停止程序的致命异常(在我看来,COBOL标准定义默认关闭所有异常检查:由于遗留和性能的原因,但至少对于开发和测试来说,在大多数情况下激活它们是非常合理的,在测试结束时让程序结束而不是做错误的数学操作更为合理)。

与任何计算机语言一样,您应该非常肯定地拥有有效的数据(永远不要信任外部数据,不管它是块链的一部分还是读取的文本文件的一部分)。

,我怎么写这个,这样我才能用它做正确的数学来打印一份正确的分数报告?

如果您想使用“只忽略坏数据”(在这里可能是合适的),只需转换它:

代码语言:javascript
复制
MOVE FUNCTION NUMVAL (SOME-POSSIBILY-NUMERIC-DATA)
  TO POINTS-EARNED(RECORD-COUNT)

否则,执行显式检查(完全数字本身的检查,或数字与左/右FUNCTION TEST-NUMVAL的可能空格),并停止程序/跳过坏行与DISPLAY ... UPON SYSERR或任何适合您的。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63988919

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档