Interface StoreInstruction
- All Superinterfaces:
ClassFileElement
,CodeElement
,Instruction
Models a local variable store instruction in the
where
code
array of a
Code
attribute. Corresponding opcodes have a kind of
Opcode.Kind.STORE
. Delivered as a CodeElement
when
traversing the elements of a CodeModel
.
A local variable store instruction is composite:
StoreInstruction
(
TypeKind typeKind
,
int slot
)
TypeKind
is computational, and slot
is within [0, 65535]
.
astore
series of instructions, or reference
type store
instructions, can also operate on the returnAddress
type from discontinued jump subroutine instructions.
- Since:
- 24
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptionstatic StoreInstruction
Returns a local variable store instruction.static StoreInstruction
Returns a local variable store instruction.int
slot()
Returns the local variable slot to store to.typeKind()
Returns the computational type of the value to be stored.Methods declared in interface java.lang.classfile.Instruction
opcode, sizeInBytes
-
Method Details
-
slot
int slot()Returns the local variable slot to store to. The value is within[0, 65535]
.- Returns:
- the local variable slot to store to
-
typeKind
TypeKind typeKind()Returns the computational type of the value to be stored. Thereference
type store instructions also operate on thereturnAddress
type, which does not apply toreference
type load instructions.- Returns:
- the computational type of the value to be stored
-
of
Returns a local variable store instruction.kind
is converted to its computational type.slot
must be within[0, 65535]
.- Parameters:
kind
- the type of the value to be storedslot
- the local variable slot to store to- Returns:
- a local variable store instruction
- Throws:
IllegalArgumentException
- ifkind
isvoid
orslot
is out of range
-
of
Returns a local variable store instruction.The range of
slot
is restricted by theop
and its size:- If
op
has size 1,slot
must be exactly the slot value implied by the opcode. - If
op
has size 2,slot
must be within[0, 255]
. - If
op
has size 4,slot
must be within[0, 65535]
.
- API Note:
- The explicit
op
argument allows creatingwide
or regular store instructions when theslot
can be encoded with more optimized store instructions. - Parameters:
op
- the opcode for the specific type of store instruction, which must be of kindOpcode.Kind.STORE
slot
- the local variable slot to store to- Returns:
- a local variable store instruction
- Throws:
IllegalArgumentException
- if the opcode kind is notOpcode.Kind.STORE
orslot
is out of range
- If
-