Java Bytecode Instructions List
monic | Opcode (in hex) |
Other bytes | Stack [before]→[after] |
Description |
---|---|---|---|---|
aaload | 32 | arrayref, index → value | load onto the stack a reference from an array | |
aastore | 53 | arrayref, index, value → | store into a reference in an array | |
aconst_null | 01 | → null | push a null reference onto the stack | |
aload | 19 | 1: index | → objectref | load a reference onto the stack from a local variable #index |
aload_0 | 2a | → objectref | load a reference onto the stack from local variable 0 | |
aload_1 | 2b | → objectref | load a reference onto the stack from local variable 1 | |
aload_2 | 2c | → objectref | load a reference onto the stack from local variable 2 | |
aload_3 | 2d | → objectref | load a reference onto the stack from local variable 3 | |
anewarray | bd | 2: indexbyte1, indexbyte2 | count → arrayref | create a new array of references of length count and component type identified by the class referenceindex (indexbyte1 << 8 + indexbyte2) in the constant pool |
areturn | b0 | objectref → [empty] | return a reference from a method | |
arraylength | be | arrayref → length | get the length of an array | |
astore | 3a | 1: index | objectref → | store a reference into a local variable #index |
astore_0 | 4b | objectref → | store a reference into local variable 0 | |
astore_1 | 4c | objectref → | store a reference into local variable 1 | |
astore_2 | 4d | objectref → | store a reference into local variable 2 | |
astore_3 | 4e | objectref → | store a reference into local variable 3 | |
athrow | bf | objectref → [empty], objectref | throws an error or exception (notice that the rest of the stack is cleared, leaving only a reference to the Throwable) | |
baload | 33 | arrayref, index → value | load a byte or Boolean value from an array | |
bastore | 54 | arrayref, index, value → | store a byte or Boolean value into an array | |
bipush | 10 | 1: byte | → value | push a byte onto the stack as an integer value |
breakpoint | ca | reserved for breakpoints in Java debuggers; should not appear in any class file | ||
caload | 34 | arrayref, index → value | load a char from an array | |
castore | 55 | arrayref, index, value → | store a char into an array | |
checkcast | c0 | 2: indexbyte1, indexbyte2 | objectref → objectref | checks whether an objectref is of a certain type, the class reference of which is in the constant pool at index (indexbyte1 << 8 + indexbyte2) |
d2f | 90 | value → result | convert a double to a float | |
d2i | 8e | value → result | convert a double to an int | |
d2l | 8f | value → result | convert a double to a long | |
dadd | 63 | value1, value2 → result | add two doubles | |
daload | 31 | arrayref, index → value | load a double from an array | |
dastore | 52 | arrayref, index, value → | store a double into an array | |
dcmpg | 98 | value1, value2 → result | compare two doubles | |
dcmpl | 97 | value1, value2 → result | compare two doubles | |
dconst_0 | 0e | → 0.0 | push the constant 0.0 onto the stack | |
dconst_1 | 0f | → 1.0 | push the constant 1.0 onto the stack | |
ddiv | 6f | value1, value2 → result | divide two doubles | |
dload | 18 | 1: index | → value | load a double value from a local variable #index |
dload_0 | 26 | → value | load a double from local variable 0 | |
dload_1 | 27 | → value | load a double from local variable 1 | |
dload_2 | 28 | → value | load a double from local variable 2 | |
dload_3 | 29 | → value | load a double from local variable 3 | |
dmul | 6b | value1, value2 → result | multiply two doubles | |
dneg | 77 | value → result | negate a double | |
drem | 73 | value1, value2 → result | get the remainder from a division between two doubles | |
dreturn | af | value → [empty] | return a double from a method | |
dstore | 39 | 1: index | value → | store a double value into a local variable #index |
dstore_0 | 47 | value → | store a double into local variable 0 | |
dstore_1 | 48 | value → | store a double into local variable 1 | |
dstore_2 | 49 | value → | store a double into local variable 2 | |
dstore_3 | 4a | value → | store a double into local variable 3 | |
dsub | 67 | value1, value2 → result | subtract a double from another | |
dup | 59 | value → value, value | duplicate the value on top of the stack | |
dup_x1 | 5a | value2, value1 → value1, value2, value1 | insert a copy of the top value into the stack two values from the top. value1 and value2 must not be of the type double or long. | |
dup_x2 | 5b | value3, value2, value1 → value1, value3, value2, value1 | insert a copy of the top value into the stack two (if value2 is double or long it takes up the entry of value3, too) or three values (if value2 is neither double nor long) from the top | |
dup2 | 5c | {value2, value1} → {value2, value1}, {value2, value1} | duplicate top two stack words (two values, if value1 is not double nor long; a single value, if value1 is double or long) | |
dup2_x1 | 5d | value3, {value2, value1} → {value2, value1}, value3, {value2, value1} | duplicate two words and insert beneath third word (see explanation above) | |
dup2_x2 | 5e | {value4, value3}, {value2, value1} → {value2, value1}, {value4, value3}, {value2, value1} | duplicate two words and insert beneath fourth word | |
f2d | 8d | value → result | convert a float to a double | |
f2i | 8b | value → result | convert a float to an int | |
f2l | 8c | value → result | convert a float to a long | |
fadd | 62 | value1, value2 → result | add two floats | |
faload | 30 | arrayref, index → value | load a float from an array | |
fastore | 51 | arrayref, index, value → | store a float in an array | |
fcmpg | 96 | value1, value2 → result | compare two floats | |
fcmpl | 95 | value1, value2 → result | compare two floats | |
fconst_0 | 0b | → 0.0f | push 0.0f on the stack | |
fconst_1 | 0c | → 1.0f | push 1.0f on the stack | |
fconst_2 | 0d | → 2.0f | push 2.0f on the stack | |
fdiv | 6e | value1, value2 → result | divide two floats | |
fload | 17 | 1: index | → value | load a float value from a local variable #index |
fload_0 | 22 | → value | load a float value from local variable 0 | |
fload_1 | 23 | → value | load a float value from local variable 1 | |
fload_2 | 24 | → value | load a float value from local variable 2 | |
fload_3 | 25 | → value | load a float value from local variable 3 | |
fmul | 6a | value1, value2 → result | multiply two floats | |
fneg | 76 | value → result | negate a float | |
frem | 72 | value1, value2 → result | get the remainder from a division between two floats | |
freturn | ae | value → [empty] | return a float | |
fstore | 38 | 1: index | value → | store a float value into a local variable #index |
fstore_0 | 43 | value → | store a float value into local variable 0 | |
fstore_1 | 44 | value → | store a float value into local variable 1 | |
fstore_2 | 45 | value → | store a float value into local variable 2 | |
fstore_3 | 46 | value → | store a float value into local variable 3 | |
fsub | 66 | value1, value2 → result | subtract two floats | |
getfield | b4 | 2: index1, index2 | objectref → value | get a field value of an object objectref, where the field is identified by field reference in the constant pool index (index1 << 8 + index2) |
getstatic | b2 | 2: index1, index2 | → value | get a static field value of a class, where the field is identified by field reference in the constant pool index (index1 << 8 + index2) |
goto | a7 | 2: branchbyte1, branchbyte2 | [no change] | goes to another instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
goto_w | c8 | 4: branchbyte1, branchbyte2, branchbyte3, branchbyte4 | [no change] | goes to another instruction at branchoffset (signed int constructed from unsigned bytes branchbyte1 << 24 + branchbyte2 << 16 + branchbyte3 << 8 + branchbyte4) |
i2b | 91 | value → result | convert an int into a byte | |
i2c | 92 | value → result | convert an int into a character | |
i2d | 87 | value → result | convert an int into a double | |
i2f | 86 | value → result | convert an int into a float | |
i2l | 85 | value → result | convert an int into a long | |
i2s | 93 | value → result | convert an int into a short | |
iadd | 60 | value1, value2 → result | add two ints | |
iaload | 2e | arrayref, index → value | load an int from an array | |
iand | 7e | value1, value2 → result | perform a bitwise and on two integers | |
iastore | 4f | arrayref, index, value → | store an int into an array | |
iconst_m1 | 02 | → -1 | load the int value -1 onto the stack | |
iconst_0 | 03 | → 0 | load the int value 0 onto the stack | |
iconst_1 | 04 | → 1 | load the int value 1 onto the stack | |
iconst_2 | 05 | → 2 | load the int value 2 onto the stack | |
iconst_3 | 06 | → 3 | load the int value 3 onto the stack | |
iconst_4 | 07 | → 4 | load the int value 4 onto the stack | |
iconst_5 | 08 | → 5 | load the int value 5 onto the stack | |
idiv | 6c | value1, value2 → result | divide two integers | |
if_acmpeq | a5 | 2: branchbyte1, branchbyte2 | value1, value2 → | if references are equal, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
if_acmpne | a6 | 2: branchbyte1, branchbyte2 | value1, value2 → | if references are not equal, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
if_icmpeq | 9f | 2: branchbyte1, branchbyte2 | value1, value2 → | if ints are equal, branch to instruction at branchoffset (signed short constructed from unsigned bytesbranchbyte1 << 8 + branchbyte2) |
if_icmpge | a2 | 2: branchbyte1, branchbyte2 | value1, value2 → | if value1 is greater than or equal to value2, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
if_icmpgt | a3 | 2: branchbyte1, branchbyte2 | value1, value2 → | if value1 is greater than value2, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
if_icmple | a4 | 2: branchbyte1, branchbyte2 | value1, value2 → | if value1 is less than or equal to value2, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
if_icmplt | a1 | 2: branchbyte1, branchbyte2 | value1, value2 → | if value1 is less than value2, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
if_icmpne | a0 | 2: branchbyte1, branchbyte2 | value1, value2 → | if ints are not equal, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
ifeq | 99 | 2: branchbyte1, branchbyte2 | value → | if value is 0, branch to instruction at branchoffset (signed short constructed from unsigned bytesbranchbyte1 << 8 + branchbyte2) |
ifge | 9c | 2: branchbyte1, branchbyte2 | value → | if value is greater than or equal to 0, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
ifgt | 9d | 2: branchbyte1, branchbyte2 | value → | if value is greater than 0, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
ifle | 9e | 2: branchbyte1, branchbyte2 | value → | if value is less than or equal to 0, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
iflt | 9b | 2: branchbyte1, branchbyte2 | value → | if value is less than 0, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
ifne | 9a | 2: branchbyte1, branchbyte2 | value → | if value is not 0, branch to instruction at branchoffset (signed short constructed from unsigned bytesbranchbyte1 << 8 + branchbyte2) |
ifnonnull | c7 | 2: branchbyte1, branchbyte2 | value → | if value is not null, branch to instruction at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) |
ifnull | c6 | 2: branchbyte1, branchbyte2 | value → | if value is null, branch to instruction at branchoffset (signed short constructed from unsigned bytesbranchbyte1 << 8 + branchbyte2) |
iinc | 84 | 2: index, const | [No change] | increment local variable #index by signed byte const |
iload | 15 | 1: index | → value | load an int value from a local variable #index |
iload_0 | 1a | → value | load an int value from local variable 0 | |
iload_1 | 1b | → value | load an int value from local variable 1 | |
iload_2 | 1c | → value | load an int value from local variable 2 | |
iload_3 | 1d | → value | load an int value from local variable 3 | |
impdep1 | fe | reserved for implementation-dependent operations within debuggers; should not appear in any class file | ||
impdep2 | ff | reserved for implementation-dependent operations within debuggers; should not appear in any class file | ||
imul | 68 | value1, value2 → result | multiply two integers | |
ineg | 74 | value → result | negate int | |
instanceof | c1 | 2: indexbyte1, indexbyte2 | objectref → result | determines if an object objectref is of a given type, identified by class reference index in constant pool (indexbyte1 << 8 + indexbyte2) |
invokedynamic | ba | 4: indexbyte1, indexbyte2, 0, 0 | [arg1, [arg2 ...]] → | invokes a dynamic method identified by method reference index in constant pool (indexbyte1 << 8 + indexbyte2) |
invokeinterface | b9 | 4: indexbyte1, indexbyte2, count, 0 | objectref, [arg1, arg2, ...] → | invokes an interface method on object objectref, where the interface method is identified by method reference index in constant pool (indexbyte1 << 8 + indexbyte2) |
invokespecial | b7 | 2: indexbyte1, indexbyte2 | objectref, [arg1, arg2, ...] → | invoke instance method on object objectref, where the method is identified by method reference indexin constant pool (indexbyte1 << 8 + indexbyte2) |
invokestatic | b8 | 2: indexbyte1, indexbyte2 | [arg1, arg2, ...] → | invoke a static method, where the method is identified by method reference index in constant pool (indexbyte1 << 8 + indexbyte2) |
invokevirtual | b6 | 2: indexbyte1, indexbyte2 | objectref, [arg1, arg2, ...] → | invoke virtual method on object objectref, where the method is identified by method reference index in constant pool (indexbyte1 << 8 + indexbyte2) |
ior | 80 | value1, value2 → result | bitwise int or | |
irem | 70 | value1, value2 → result | logical int remainder | |
ireturn | ac | value → [empty] | return an integer from a method | |
ishl | 78 | value1, value2 → result | int shift left | |
ishr | 7a | value1, value2 → result | int arithmetic shift right | |
istore | 36 | 1: index | value → | store int value into variable #index |
istore_0 | 3b | value → | store int value into variable 0 | |
istore_1 | 3c | value → | store int value into variable 1 | |
istore_2 | 3d | value → | store int value into variable 2 | |
istore_3 | 3e | value → | store int value into variable 3 | |
isub | 64 | value1, value2 → result | int subtract | |
iushr | 7c | value1, value2 → result | int logical shift right | |
ixor | 82 | value1, value2 → result | int xor | |
jsr | a8 | 2: branchbyte1, branchbyte2 | → address | jump to subroutine at branchoffset (signed short constructed from unsigned bytes branchbyte1 << 8 + branchbyte2) and place the return address on the stack |
jsr_w | c9 | 4: branchbyte1, branchbyte2, branchbyte3, branchbyte4 | → address | jump to subroutine at branchoffset (signed int constructed from unsigned bytes branchbyte1 << 24 + branchbyte2 << 16 + branchbyte3 << 8 + branchbyte4) and place the return address on the stack |
l2d | 8a | value → result | convert a long to a double | |
l2f | 89 | value → result | convert a long to a float | |
l2i | 88 | value → result | convert a long to a int | |
ladd | 61 | value1, value2 → result | add two longs | |
laload | 2f | arrayref, index → value | load a long from an array | |
land | 7f | value1, value2 → result | bitwise and of two longs | |
lastore | 50 | arrayref, index, value → | store a long to an array | |
lcmp | 94 | value1, value2 → result | compare two longs values | |
lconst_0 | 09 | → 0L | push the long 0 onto the stack | |
lconst_1 | 0a | → 1L | push the long 1 onto the stack | |
ldc | 12 | 1: index | → value | push a constant #index from a constant pool (String, int or float) onto the stack |
ldc_w | 13 | 2: indexbyte1, indexbyte2 | → value | push a constant #index from a constant pool (String, int or float) onto the stack (wide index is constructed as indexbyte1 << 8 + indexbyte2) |
ldc2_w | 14 | 2: indexbyte1, indexbyte2 | → value | push a constant #index from a constant pool (double or long) onto the stack (wide index is constructed as indexbyte1 << 8 + indexbyte2) |
ldiv | 6d | value1, value2 → result | divide two longs | |
lload | 16 | 1: index | → value | load a long value from a local variable #index |
lload_0 | 1e | → value | load a long value from a local variable 0 | |
lload_1 | 1f | → value | load a long value from a local variable 1 | |
lload_2 | 20 | → value | load a long value from a local variable 2 | |
lload_3 | 21 | → value | load a long value from a local variable 3 | |
lmul | 69 | value1, value2 → result | multiply two longs | |
lneg | 75 | value → result | negate a long | |
lookupswitch | ab | 4+: <0-3 bytes padding>, defaultbyte1, defaultbyte2, defaultbyte3, defaultbyte4, npairs1, npairs2, npairs3, npairs4, match-offset pairs... | key → | a target address is looked up from a table using a key and execution continues from the instruction at that address |
lor | 81 | value1, value2 → result | bitwise or of two longs | |
lrem | 71 | value1, value2 → result | remainder of division of two longs | |
lreturn | ad | value → [empty] | return a long value | |
lshl | 79 | value1, value2 → result | bitwise shift left of a long value1 by value2 positions | |
lshr | 7b | value1, value2 → result | bitwise shift right of a long value1 by value2 positions | |
lstore | 37 | 1: index | value → | store a long value in a local variable #index |
lstore_0 | 3f | value → | store a long value in a local variable 0 | |
lstore_1 | 40 | value → | store a long value in a local variable 1 | |
lstore_2 | 41 | value → | store a long value in a local variable 2 | |
lstore_3 | 42 | value → | store a long value in a local variable 3 | |
lsub | 65 | value1, value2 → result | subtract two longs | |
lushr | 7d | value1, value2 → result | bitwise shift right of a long value1 by value2 positions, unsigned | |
lxor | 83 | value1, value2 → result | bitwise exclusive or of two longs | |
monitorenter | c2 | objectref → | enter monitor for object ("grab the lock" - start of synchronized() section) | |
monitorexit | c3 | objectref → | exit monitor for object ("release the lock" - end of synchronized() section) | |
multianewarray | c5 | 3: indexbyte1, indexbyte2, dimensions | count1, [count2,...] → arrayref | create a new array of dimensions dimensions with elements of type identified by class reference in constant pool index (indexbyte1 << 8 + indexbyte2); the sizes of each dimension is identified bycount1, [count2, etc.] |
new | bb | 2: indexbyte1, indexbyte2 | → objectref | create new object of type identified by class reference in constant pool index (indexbyte1 << 8 + indexbyte2) |
newarray | bc | 1: atype | count → arrayref | create new array with count elements of primitive type identified by atype |
nop | 00 | [No change] | perform no operation | |
pop | 57 | value → | discard the top value on the stack | |
pop2 | 58 | {value2, value1} → | discard the top two values on the stack (or one value, if it is a double or long) | |
putfield | b5 | 2: indexbyte1, indexbyte2 | objectref, value → | set field to value in an object objectref, where the field is identified by a field reference index in constant pool (indexbyte1 << 8 + indexbyte2) |
putstatic | b3 | 2: indexbyte1, indexbyte2 | value → | set static field to value in a class, where the field is identified by a field reference index in constant pool (indexbyte1 << 8 + indexbyte2) |
ret | a9 | 1: index | [No change] | continue execution from address taken from a local variable #index (the asymmetry with jsr is intentional) |
return | b1 | → [empty] | return void from method | |
saload | 35 | arrayref, index → value | load short from array | |
sastore | 56 | arrayref, index, value → | store short to array | |
sipush | 11 | 2: byte1, byte2 | → value | push a short onto the stack |
swap | 5f | value2, value1 → value1, value2 | swaps two top words on the stack (note that value1 and value2 must not be double or long) | |
tableswitch | aa | 4+: [0-3 bytes padding], defaultbyte1, defaultbyte2, defaultbyte3, defaultbyte4, lowbyte1, lowbyte2, lowbyte3, lowbyte4, highbyte1, highbyte2, highbyte3, highbyte4, jump offsets... | index → | continue execution from an address in the table at offset index |
wide | c4 | 3/5: opcode, indexbyte1, indexbyte2 or iinc, indexbyte1, indexbyte2, countbyte1, countbyte2 |
[same as for corresponding instructions] | execute opcode, where opcode is either iload, fload, aload, lload, dload, istore, fstore, astore, lstore, dstore, or ret, but assume the index is 16 bit; or execute iinc, where the index is 16 bits and the constant to increment by is a signed 16 bit short |
(no name) | cb-fd | these values are currently unassigned for opcodes and are reserved for future use |
Java Bytecode Instructions List的更多相关文章
- [转]Native Java Bytecode Debugging without Source Code
link from:http://www.crowdstrike.com/blog/native-java-bytecode-debugging-without-source-code/index.h ...
- java 程序运行的基础知识【Java bytecode】
聊聊文字,写一篇关于 java 基础知识的博文. JVM 线程栈 到 函数运行 每一个JVM线程来说启动的时候都会创建一个私有的线程栈.一个jvm线程栈用来存储栈帧,jvm线程栈和C语言中的栈很类似, ...
- [转载] 深入了解Java ClassLoader、Bytecode 、ASM、cglib
转载自http://www.iteye.com/topic/98178 一.Java ClassLoader 1,什么是ClassLoader 与 C 或 C++ 编写的程序不同,Java 程序并 ...
- The 11 advantages of Java -Why you choose this language
Java is never just a language.There are lots of programming languages out there, and few of them mak ...
- Java Garbage Collection Basics--转载
原文地址:http://www.oracle.com/webfolder/technetwork/tutorials/obe/java/gc01/index.html Overview Purpose ...
- Core Java Volume I — 1.2. The Java "White Paper" Buzzwords
1.2. The Java "White Paper" BuzzwordsThe authors of Java have written an influential White ...
- Getting Started with Java
“学前”说明:<Learn Java for Android>这本书内容很多,都是精华,建议大家看英文版的.在这里我不打算一一总结书中的内容,书中每章节后面的exercises都很好,非常 ...
- 115 Java Interview Questions and Answers – The ULTIMATE List--reference
In this tutorial we will discuss about different types of questions that can be used in a Java inter ...
- Java 8 Features – The ULTIMATE Guide--reference
Now, it is time to gather all the major Java 8 features under one reference post for your reading pl ...
随机推荐
- 体验CoreCLR的stack unwinding特性在Linux/Mac上的初步实现
有了stack unwinding特性,才能在.NET程序中获取调用堆栈(call stack)信息,才能在异常时显示调用堆栈信息.这个特性之前只在Windows上有实现,Linux/Mac上的实现最 ...
- 设计模式之美:Flyweight(享元)
索引 意图 结构 参与者 适用性 效果 相关模式 实现 实现方式(一):使用 FlyweightFactory 管理 Flyweight 对象. 意图 运用共享技术有效地支持大量细粒度的对象. Use ...
- 转载:开发者眼中最好的 22 款 GUI 测试工具
对于很多同学来说gui程序的测试是一个难点,所以我从网上转载了一篇关于gui测试的一篇文章,里面罗列的很多工具,大家可以尝试一下学习学习. 英文原文:22 best GUI testing tools ...
- hibernate date类型插入数据库时精度只到日期没有时间
由hibernate 的逆向工具从数据库表生成的*.hbm.xml ,对于数据库的date类型生成如下: <property name = "crttime" ...
- 收缩SQL Server日志不是那么简单的(翻译)
原文地址:http://rusanu.com/2012/07/27/how-to-shrink-the-sql-server-log/ 说明:本文为了更好的说明收缩的过程,在原文翻译的基础上增加了一些 ...
- JAVA软件开发职责
1.了解OO,AOP,SOA设计模式.J2EE的核心设计模式.应用架构模式和应用集成模式:2.熟练使用Spring.Hibernate/ibatis.Struts等通用性开源框架,并对其原理有深刻的理 ...
- CSS中一些不经意的细节问题1
CSS这样的语法,细节问题非常多,往往一些难以处理的问题,有可能是一些细节问题不到位,所以先记下一些,留给以后自己看看. 1.line-height:150%与line-height:1.5 的区别 ...
- paip . 解决spring No unique bean of type [com.mijie.homi.search.service.index.MoodUserIndexService]
paip . 解决spring No unique bean of type [com.mijie.homi.search.service.index.MoodUserIndexService] ...
- iOS开发-UITableView顶部图片下拉放大
关于顶部图片下拉放大,在用户展示的个人中心显示用户个人头像信息,设置UITableView的headerView实现,UITableView继承自UIScrollView,同样的设置UIScrollV ...
- java封装性
原先是class Person{ public string name; public int age } public void main{ Person person=new person(); ...