別々のプロジェクト内にある Java と COBOL を使用する場合は、「Java での COBOL 作業場所節へのアクセス (別個のプロジェクト)」を参照してください。
[Properties for <project-name>] ダイアログ ボックスが表示されます。
この例では、[Java Interoperability Output Path] を src に設定し、プロジェクトを単一のネイティブ ライブラリ ファイルにビルドするなど、他の設定も必要ですが、これらはデフォルトの設定であるためすでに設定されています。
プログラムがエディターで開きます。
$set sourceformat(variable)
program-id. demo2 as "demo2".
working-storage section.
>>JAVA-SHAREABLE ON
01 grp1.
03 i1 pic 9(8) comp-5 value 88888888.
03 i2 pic 9(8) comp-5 value 12345678.
>>JAVA-SHAREABLE OFF
01 grp2.
03 p1 pic x.
03 p2 pic 9.
procedure division.
display "start".
display "value of shared CBL grp is: "
display grp1::i1.
display grp1::i2.
end program demo2.
自動的にビルドするようにワークスペースが設定されている場合、プログラムがコンパイルされます。自動的にビルドするようにワークスペースが設定されていない場合は、[Project] メニューの [Build Project] をクリックします。
プログラムがエディターで開きます。
package com.mycompany.demo2;
public class Demo2
{
public static void main(String[] args)
{
System.out.println("--COBOL items now accessible in Java--");
int i1 = strg.demo2.grp1.i1.get();
int i2 = strg.demo2.grp1.i2.get();
System.out.println("-- COBOL item i1 = " + i1);
System.out.println("-- COBOL item i2 = " + i2);
strg.demo2.grp1.i1.put(77777777);
System.out.println("-- i1 updated from Java = " + strg.demo2.grp1.i1.get());
}
}
自動的にビルドするようにワークスペースが設定されている場合、プログラムがコンパイルされます。自動的にビルドするようにワークスペースが設定されていない場合は、[Project] メニューの [Build Project] をクリックします。
新しい構成が右側のペインに表示されます。
-Djava.library.path="<path-to-COBOL-output-folder>"
<path-to-COBOL-output-folder> は、COBOL プロジェクトの出力フォルダーのフル パス名に置き換えます。
--COBOL items now accessible in Java-- -- COBOL item i1 = 88888888 -- COBOL item i2 = 12345678 -- i1 updated from Java = 77777777
このコードおよび出力は、この COBOL プログラムでは、2 つの PIC 9 COMP-5 項目を Java プログラムと共有していることを示しています。Java プログラムで get メソッドを使用して COBOL データの値を表示しました (これを行うために「COBOL 項目と Java 型のマッピング」に従って COMP-5 項目を int 型にマップしています)。さらに、Java プログラムで put メソッドを使用して COBOL 項目の値を変更しました (ここでも内部でマッピング処理を使用しています)。