CBL_MEM_VALIDATE

メモリ割り当てを検証し、解放メモリを監視して、オペレーティング システムでサポートされている場合にはメモリ ヒープを圧縮します。
制約事項: このルーチンはネイティブ COBOL でのみサポートされます。

構文:

call "CBL_MEM_VALIDATE" using by value     flags
                              by reference param
                              returning    status-code

パラメーター:

flags
呼び出しプロトタイプ使用時 (「説明の読み方」を参照):cblt-x4-comp-5
PIC:pic x(4) comp-5
param
次のように定義されている集団:
01 cblt-mem-validate-param
   03 cblte-mv-version  cblt-x4-comp-5 *> pic x(4) comp-5.
   03 cblte-mv-flags    cblt-x4-comp-5 *> pic x(4) comp-5.
   03 cblte-mv-type     cblt-x4-comp-5 *> pic x(4) comp-5.
   03 cblte-mv-size     cblt-os-size   *>32-bit: pic x(4) comp-5.
                                       *>64-bit: pic x(8) comp-5.
   03 cblte-mv-address  cblt-pointer   *> pointer

入力パラメーター:

flags
検証の制御フラグ:
ビット 0
0 何も実行しません。
1 すべてのメモリ割り当てを検証します。
ビット 1
0 何も実行しません。
1 すべての解放メモリを検証します。
2 から 30 将来使用するために予約されています。ゼロに設定する必要があります。
ビット 31
0 何も実行しません。
1 メモリを圧縮します。
cblte-mv-version
パラメーター ブロックのバージョン。ゼロにする必要があります。

出力パラメーター:

param
ルーチンが 1000 を返した場合にのみフィールドが設定されます。
cblte-mv-flags
情報フラグ:
ビット 0
0 cblte-mv-address が設定されていません。
1 cblte-mv-address に、破損したメモリ ブロックのアドレスが含まれています。
ビット 1
0 cblte-mv-address はユーザー データのアドレスです。
1 cblte-mv-address はメモリ ヘッダーのアドレスです。
ビット 2
0 cblte-mv-size が設定されていません。
1 cblte-mv-size に、破損したメモリ ブロックのサイズが含まれています。
ビット 3
0 cblte-mv-type が設定されていません。
1 cblte-mv-type に、破損したメモリ ブロックのタイプが含まれています。
ビット 4
0 割り当てメモリに破損があります。
1 解放メモリに破損があります。
ビット 5
0 ランタイム システムによって破損が検出されました。
1 オペレーティング システムによって破損が検出されました。
ビット 6 から 31
将来使用するために予約されています。
status-code
処理状態を示すコード。
0 すべてのメモリ割り当てが正常です。
1000 メモリの破損が検出されました。
1009 指定されたパラメーターが無効です。

説明:

このルーチンを使用すると、メモリ割り当てを検証し、解放メモリを監視して、オペレーティング システムでサポートされている場合にはメモリ ヒープを圧縮できます。メモリの検証ストラテジについては、このルーチンを優先して、memory_strategy ランタイム チューナーの使用を設定してください。

メモリを圧縮するようにフラグを設定した場合は、オペレーティング システムで許容される範囲でメモリが圧縮されます。この結果を示す情報フラグの設定はありません。

例:

       program-id. CblMemValidateExample as "CblMemValidateExample".

       environment division.
       configuration section.

       data division.
       working-storage section.
       01 cbl-mem-flags pic x(4) comp-5 value zero.
        01 cbl-mem-params.
           05  cbl-mem-version pic x(4) comp-5 value zero.
           05  cbl-mem-mv-flags pic x(4) comp-5 value zero.
           05  cbl-mem-mv-type pic x(4) comp-5 value zero.
           05  cbl-mem-mv-size pic x(4) comp-5 value zero.
           05  cbl-mem-mv-addr usage pointer value null.
       01 cbl-mem-return-code pic x(2) comp-5 value zero.
       01 any-key pic x.
       
       procedure division.
           
	  *Call directly setting the bits
           call 'CBL_MEM_VALIDATE' using by value H'00000001'
                                         by reference cbl-mem-params
                                   returning cbl-mem-return-code.
           display 'CBL_MEM_VALIDATE setting bits returned: '
                   cbl-mem-return-code.
           
	  *Same call using variable to set flags
       move 1 to cbl-mem-flags 
           call 'CBL_MEM_VALIDATE' using by value cbl-mem-flags
                                         by reference cbl-mem-params
                                   returning cbl-mem-return-code.
           display 'CBL_MEM_VALIDATE using variable returned: '
                   cbl-mem-return-code.
       accept any-key.
       
           goback.

       end program CblMemValidateExample.