执行外部函数后printf无法正常工作

时间:2014-01-03 15:07:16

标签: c cobol

我有以下c代码调用cobol程序:

#include <stdio.h>
#include "libcob.h"
//#pragma linkage (verkoop, COBOL)

extern void VERKOOP(char *productid, char *aantal, char*resultaat);

main(int argc, char *argv[])
{
    int return_status;
    COB_RTD = cob_get_rtd();
    char *productid = "20    ";
    char *aantal = "000020";
    char resultaat[30];
    cob_init(rtd, 0, NULL);
    printf("hallo");//prints
    VERKOOP(productid, aantal, resultaat);
    printf("hallo");//doesn't print
    printf("resultaat:%s", resultaat);// doesn't print
    cob_stop_run (rtd, return_status);
}

我正在使用printf来查看是否已正确分配了resultaat。但是,VERKOOP之后的两行都不会因某种原因打印出来。

这是VERKOOP的COBOL代码(他在这里正确填写了LS-RESULTAAT,我用DISPLAY试了一下这个部分有效):

*************************************************************
* VERKOOP  
*************************************************************
       IDENTIFICATION DIVISION.
       PROGRAM-ID. VERKOOP.

       ENVIRONMENT DIVISION.
       INPUT-OUTPUT SECTION.
       FILE-CONTROL.
       SELECT PRODUCTEN ASSIGN TO "BESTANDEN/LIJSTPRODUCTEN"
           ACCESS MODE IS RANDOM
           ORGANIZATION IS INDEXED
           RECORD KEY IS PRODUCTID
           FILE STATUS IS WS-FILE-STATUS.

       DATA DIVISION.
       FILE SECTION.
       FD  PRODUCTEN BLOCK CONTAINS 10 RECORDS.
       01  PRODUCT.
           02 PRODUCTID PIC X(6).
           02 LEVERANCIERID PIC X(6).
           02 AANTAL PIC 9(6).
       WORKING-STORAGE SECTION.
       77  FOUT PIC X.
           88 PRODUCT-NIET-GEVONDEN VALUE 1.
       77 WS-PRODUCTID PIC X(6).
       77 WS-AANTAL PIC 9(6).
       77 WS-FILE-STATUS PIC XX.
       77 WS-RESULTAAT PIC X(30).
       LINKAGE SECTION.
       01 LS-PRODUCTID PIC X(6).
       01 LS-AANTAL PIC 9(6).
       01 LS-RESULTAAT PIC X(30).
       PROCEDURE DIVISION USING LS-PRODUCTID, LS-AANTAL, LS-RESULTAAT.

       MAIN.
           PERFORM INITIALISEER
           PERFORM LEES-PRODUCT-IN
           PERFORM LEES-BESTAND
           PERFORM SLUIT-BESTAND
           STOP RUN.

       INITIALISEER.
           OPEN I-O PRODUCTEN.
*          DISPLAY WS-FILE-STATUS..

       LEES-PRODUCT-IN.
           MOVE LS-PRODUCTID TO WS-PRODUCTID
           MOVE LS-AANTAL TO WS-AANTAL
           MOVE 'OK' TO WS-RESULTAAT
*          DISPLAY WS-RESULTAAT
           MOVE WS-RESULTAAT TO LS-RESULTAAT.       
*          DISPLAY "GEEF PRODUCTID OP: "
*          ACCEPT WS-PRODUCTID
*          DISPLAY "GEEF AANTAL OP: "
*          ACCEPT WS-AANTAL.

       LEES-BESTAND.
*      DISPLAY "LEES-BESTAND"
       MOVE WS-PRODUCTID TO PRODUCTID
*      DISPLAY PRODUCTID
*      DISPLAY WS-FILE-STATUS
       READ PRODUCTEN INVALID KEY SET PRODUCT-NIET-GEVONDEN TO TRUE
       END-READ 
       IF PRODUCT-NIET-GEVONDEN PERFORM FOUTJE    
       ELSE 
*      MOVE WS-PRODUCTID TO PRODUCTID
       SUBTRACT WS-AANTAL FROM AANTAL   
       PERFORM UPDATE-PRODUCT
       END-IF.


      UPDATE-PRODUCT.
        REWRITE PRODUCT INVALID KEY PERFORM FOUTJE.

        SLUIT-BESTAND.
*       DISPLAY "SLUIT-BESTAND"
           CLOSE PRODUCTEN.

        FOUTJE.
           DISPLAY "ER IS EEN FOUT OPGETREDEN"
           DISPLAY WS-FILE-STATUS
           STOP RUN.

更新:我尝试删除“STOP RUN”,但是现在由于某种原因,他减去40而不是20并打印“ER IS EEN FOUT OPGETREDEN”。所以他出于某种原因两次运行COBOL程序。

更新:通过GOBACK替换STOP RUN后,它可以完美地运行

1 个答案:

答案 0 :(得分:0)

你的STOP RUN在这里返回,cob_stop_run(rtd,return_status),所以在调用COBOL程序之后你的先前代码没有运行。

如果EXIT PROGRAM位于&#34; main&#34;程序(至少在pragma-usage的情况下,它似乎就是你所拥有的)然后它被视为与STOP RUN相同。

GOBACK正在将控制权返回到您期望的位置。

如果您使用COBOL-IT API,就像已经建议的那样,那么EXIT PROGRAM的行为可能会有所不同。也许不是。

您正在使用未记录的方式来调用COBOL-IT程序。对于没有COBOL-IT和相同操作系统的人,以及以非显而易见的方式做某事的耐心,对于其行为的确切行为并不为人所知。

如果建议您忽略这些内容,则很难回答您的问题。

同样,你有一个作业。 Assignment要求您使用API​​。您应该使用API​​并使您的程序正常运行。如果您以后有时间,可以查看pragma-usage以实现互操作性。