JavaLib.storeField

システム関数 JavaLib.storeField は、クラス・フィールドまたはオブジェクト・フィールドの値を EGL Java™ オブジェクト・スペースに格納します。オブジェクトの保管に使用する ID がすでにオブジェクト・スペース内に存在している場合は、次のステップと同等のアクションが実行されます。

クラス・フィールドまたはオブジェクト・フィールドに、オブジェクトではなく Java プリミティブが含まれる場合、EGL は、プリミティブを表すオブジェクトを保管します。例えば、フィールドに int が含まれる場合、EGL は、java.lang.Integer 型のオブジェクトを保管します。


JavaLib.storeField の構文図
storeId
オブジェクトとともに保管する ID。

この引き数は、文字列リテラル、または CHAR 型、DBCHAR 型、MBCHAR 型、UNICODE 型の項目です。ID は、後述の例のように、objID にキャストする必要があります。EGL は、大文字小文字の区別がある引き数値の先頭と最後から、1 バイトのブランクと 2 バイトのブランクを削除します。

identifierOrClass
この引き数は、次のエンティティーのいずれかです。
  • オブジェクト・スペース内のオブジェクトを参照する ID
  • Java クラスの完全修飾名

この引き数は、文字列リテラル、または CHAR 型、DBCHAR 型、MBCHAR 型、UNICODE 型の項目です。オブジェクトの ID を指定する場合は、後述の例のように、その ID を objID にキャストする必要があります。次の引き数に static フィールドを指定する場合は、この引き数にクラスを指定することをお勧めします。

EGL は、大文字小文字の区別がある引き数値の先頭と最後から、1 バイトのブランクと 2 バイトのブランクを削除します。

field
オブジェクトを参照するフィールドの名前。

この引き数は、文字列リテラル、または CHAR 型、DBCHAR 型、MBCHAR 型、UNICODE 型の項目です。大文字小文字の区別があるストリングの先頭と最後から、1 バイトのブランクと 2 バイトのブランクが削除されます。

以下に例を示します。
  JavaLib.storeField( (objId)"myStoreId", 
    (objId)"myId", "myField");

JavaLib.storeField の処理中にエラーが発生すると、sysVar.errorCode は以下の表の値に設定されます。

sysVar.errorCode の値 説明
00001000 呼び出されたメソッドによって、またはクラスの初期化の結果として、例外がスローされました。
00001001 オブジェクトが NULL でした。または指定された ID がオブジェクト・スペース内にありませんでした。
00001002 指定された名前の public メソッド、フィールド、またはクラスが存在しないか、ロードできません。
00001007 メソッドまたはフィールドに関する情報の取得中に、SecurityException または IllegalAccessException がスローされました。または、final 宣言されたフィールドの値を設定しようとしました。
00001009 クラス名ではなく、ID を指定する必要があります。メソッドまたはフィールドが静的ではありません。

関連する概念

関連するタスク
構文図

関連する参照項目
EGL ライブラリー JavaLib
JavaLib.getField
JavaLib.invoke
JavaLib.isNull
JavaLib.isObjID
JavaLib.qualifiedTypeName
JavaLib.remove
JavaLib.removeAll
JavaLib.setField
JavaLib.store
JavaLib.storeCopy
JavaLib.storeNew

ご利用条件 | フィードバック
(C) Copyright IBM Corporation 2000, 2005. All Rights Reserved.(C) Copyright IBM Japan 2005.