areturnStack
Before | After |
objectref | n/a |
... |
objectref is a reference to an object. It must be assignment compatible with the return type of the current method (See Chapter 7 for details of assignment compatibility). areturn pops objectref off the stack and pushes it onto the operand stack of the invoker (i.e. the method which used invokevirtual, invokespecial, invokestatic or invokeinterface to call the currently executing method). All other items on the current method's operand stack are discarded. If the current method is marked as synchronized, then an implicit monitorexit instruction is executed. Then the current method's frame is discarded, the invoker's frame is reinstated, and control returns to the invoker.
Example
.class Example .super java/lang/Object ; This method takes an integer parameter n, and returns a new array of ints of length n. .method public static makeIntArray(I)[I aload_0 ; push the array size (i.e. n) parameter onto the stack newarray int ; make the array areturn ; return the array .endmethod ; an example of calling makeIntArray to make a 10 element array of ints: bipush 10 invokestatic Example/makeIntArray(I)[I astore_1 ; store array in local variable 1Bytecode
Type | Description |
u1 | areturn opcode = 0xB0 (176) |
lreturn, freturn, dreturn, ireturn, return, invokevirtual, invokespecial, invokestatic, invokeinterface