SlideShare a Scribd company logo
Lifting The Veil – Reading Java Byte
        Code During Lunchtime



          Alexander Shopov
          Cisco Lunch&Learn
Alexander Shopov
By day: Software Engineer at Cisco
By night: OSS contributor
Coordinator of Bulgarian Gnome TP

                    Contacts:
E-mail: ash@kambanaria.org
Jabber: al_shopov@jabber.minus273.org
LinkedIn: http://www.linkedin.com/in/alshopov
Google: Just search “al_shopov“
Please Learn And Share




       License: CC-BY v3.0
Creative Commons Attribution v3.0
Disclaimer




My opinions, knowledge and experience!
          Not my employer's.
Contents
●   Why read?
●   How to read?
    ●   JVM Internals;
    ●   JVM Data Types;
    ●   JVM Opcodes.
●   Let's read some code.
●   What next?
Why Read Byte code?
●   Understand your platform
●   It is interesting and not too hard
●   How does Java function? How does X function?
●   Job interviews
●   Catch compiler bugs/optimizations
●   Learn to read before you write
●   Source may not correspond to binary
●   C/C++ people know their assembler
●   Java language evolution vs. Java platform evolution
Bad News And Good News

  Bad:          Good:
We will be     Easiest
 reading      assembler
assembler      in world
What Is The JVM?
●   Stack based, byte oriented virtual machine
    without registers easily implementable on 32 bit
    hardware.
●   206 (<256) instructions that are easy to group
    and there is no need to remember them all
●   Some leeway in implementations (even with
    Oracle)
Dramatis Personæ
●   The JVM
●   The threads
●   The frames
●   The stacks – LIFO
●   The local variables – array of slots
●   The runtime constant pool – array of values
●   The bytecode – the instructions
●   Class files – serialized form of constants and byte
    code
Enter JVM




JVM OS process
Thread A

Thread B

Thread C
           Enter Threads




Thread D
Enter Frames

F4




                       Thread C

                                  Thread D
Thread A

            Thread B
F3                                F3

F2          F2                    F2

F1          F1         F1         F1

F0          F0         F0         F0
Enter Frames, Really!
          F0
                 F0        F2

F3                         F3
                F0
      F2              F1
F1                         F1
     F1         F0         F4
           F2
What Is A Frame Actually?




           F0
Let's Peek Inside A Frame




     F0
Enter Local Variables

0   1   2 3   4   5   6 …


           Local variables

           F0
Enter Stack

0     1     2 3   4   5   6 …


              Local variables

              F0



    Stack
Enter Pool Of Constants

0     1     2 3   4   5   6 …


              Local variables

              F0
                                 Pool of
                                constants

    Stack
Where Is The Code?

0     1     2 3   4   5   6 …


              Local variables

              F0
                                  Pool of
                                 constants

    Stack
Where Is The Code?
                           JVM (heap)
0     1     2 3   4   5   6 …


              Local variables

              F0
                                 Pool of
                                constants

    Stack
Where Is The Code?
                           JVM (heap)
0     1     2 3   4   5   6 …           Class
                                PC
              Local variables        Method code


              F0




                                         Class
                                        Pool of
                                       constants

    Stack
Where is the code?
                            JVM (heap)
0     1     2 3   4   5   6 …           Class
6
                                PC
              Local variables        Method code


              F0




                                         Class
                                        Pool of
                                       constants

    Stack
Load
                                     JVM (heap)
0     1     2 3   4   5   6 …            Class
6
                                PC
              Local variables         Method code


              F0




                                          Class
                                         Pool of
                                        constants
     6
    Stack
Load
                                     JVM (heap)
0     1     2 3   4   5   6 …            Class
6
                                PC
              Local variables         Method code


              F0




                                          Class
                                         Pool of
                                        constants
     6
    Stack
And…
                                     JVM (heap)
0     1     2 3   4   5   6 …            Class
6
                                PC
              Local variables         Method code


              F0




                                          Class
                                         Pool of
     8                                  constants
     6
    Stack
Store
                                     JVM (heap)
0     1     2 3   4   5   6 …            Class
6     8
              Local variables   PC    Method code


              F0




                                          Class
                                         Pool of
     8                                  constants
     6
    Stack
JVM Datatypes
●   Primitive types
    ●   Java { numeric – integral: byte (±8), short (±16),
        int (±32), long (±64), char (+16), floating point:
        float (±32), double (±64); boolean (int or byte) }
    ●   returnAddress – pointers to the opcodes of JVM
        (jumps - loops)
●   Reference types
    ●   class, array, interface
    ●   null
JVM Datatypes Descriptors
Java type           Type descriptor
boolean             Z
char                C
byte                B
short               S
int                 I
float               F
long                J
double              D
Object              Ljava/lang/Object;
byte[]              [B
String[][]          [[Ljava/lang/String;
void                V
JVM Method Descriptors
Source Code Method       Method Descriptor
declaration
void m1(int i, double d, (IDF)V
float f)
byte[] m2(String s)      (Ljava/lang/String;)[B
Object m3(int[][][] i)   ([[[I)Ljava/lang/Object;
boolean[] m4()
JVM Method Descriptors
Source Code Method       Method Descriptor
declaration
void m1(int i, double d, (IDF)V
float f)
byte[] m2(String s)      (Ljava/lang/String;)[B
Object m3(int[][][] i)   ([[[I)Ljava/lang/Object;
boolean[] m4()           ()[B
                         (Ljava/lang/Object;Ljava/lang/Long;)J
JVM Method Descriptors
Source Code Method       Method Descriptor
declaration
void m1(int i, double d, (IDF)V
float f)
byte[] m2(String s)      (Ljava/lang/String;)[B
Object m3(int[][][] i)   ([[[I)Ljava/lang/Object;
boolean[] m4()           ()[B
long m5(Object, Long)    (Ljava/lang/Object;Ljava/lang/Long;)J
206 instructions




DON'T PANIC!
Level 1 – Do Nothing/1
●   nop
Level 2 – Load Constants/20
●   aconst_null,
●   iconst_m1, iconst_0, iconst_1, iconst_2, iconst_3,
    iconst_4, iconst_5
●   lconst_0, lconst_1,
●   fconst_0, fconst_1, fconst_2
●   dconst_0, dconst_1
●   bipush, sipush – 1, 2 bytes
●   ldc, ldc_w, ldc2_w – load from index in constant
    pool 1,2,2 bytes for index
Level 3 – Load Variables/33
●   iload, lload, fload, dload, aload
●   iload_0, iload_1, iload_2, iload_3, lload_0,
    lload_1, lload_2, lload_3, fload_0, fload_1,
    fload_2, fload_3, dload_0, dload_1, dload_2,
    dload_3, aload_0, aload_1, aload_2, aload_3
●   iaload, laload, faload, daload, aaload, baload,
    caload, saload – consume reference to array
    and int index in it
Level 4 – Conversions/15
●   i2l, i2f, i2d, l2i, l2f, l2d, f2i, f2l, f2d, d2i, d2l, d2f,
    i2b, i2c, i2s
Level 6 – Maths/37
●   iadd, ladd, fadd, dadd, isub, lsub, fsub, dsub,
    imul, lmul, fmul, dmul, idiv, ldiv, fdiv, ddiv, irem,
    lrem, frem, drem, ineg, lneg, fneg, dneg, ishl,
    lshl, ishr, lshr, iushr, lushr, iand, land, ior, lor,
    ixor, lxor
●   Iinc - increment local variable #index by signed
    byte const
Level 7 – Stores/33
●   istore, lstore, fstore, dstore, astore, istore_0,
    istore_1, istore_2, istore_3, lstore_0, lstore_1,
    lstore_2, lstore_3, fstore_0, fstore_1, fstore_2,
    fstore_3, dstore_0, dstore_1, dstore_2,
    dstore_3, astore_0, astore_1, astore_2,
    astore_3, iastore, lastore, fastore, dastore,
    aastore, bastore, castore, sastore
Level 8 – No-branch Comparisons/5
●   lcmp, fcmpl, fcmpg, dcmpl, dcmpg (beware
    NaN)
Level 9 – Objects/15
●   getstatic, putstatic
●   getfield, putfield
●   invokevirtual, invokespecial, invokestatic,
    invokeinterface
●   new, newarray, anewarray
●   arraylength
●   athrow
●   checkcast, instanceof (difference is treatment of
    null)
Level 10 – Return/6
●   ireturn, lreturn, freturn, dreturn, areturn, return
165 of 206




81%
We Have Enough Mana/Resources!




Let's dive in bytecode!
Enter Bytecode
       javap – your only true friend now



javap -classpath PATH -p -c -l -s CLASS
Example 1
public static int whatIsThis(int, int, int);
  Signature: (III)I
  Code:
    0: iload_0
    1: iload_1
    2: iadd
    3: istore_3
    4: iload_3
    5: iload_2
    6: iadd
    7: istore_3
    8: iload_3
    9: ireturn
Example 1
                                       JVM (heap)
0     1     2 3                              Class
                                  PC    0:   iload_0
3     7     4                           1:   iload_1
                                        2:   iadd
                Local variables         3:   istore_3
                                        4:   iload_3
                                        5:   iload_2
                F0




                                              Class
                                        6:   iadd
                                        7:   istore_3
                                        8:   iload_3
                                        9:   ireturn

                                              Pool of
                                             constants
    Stack
Example 1
                                       JVM (heap)
0     1     2 3                              Class
                                        0:   iload_0
3     7     4                     PC    1:   iload_1
                                        2:   iadd
                Local variables         3:   istore_3
                                        4:   iload_3
                                        5:   iload_2
                F0




                                              Class
                                        6:   iadd
                                        7:   istore_3
                                        8:   iload_3
                                        9:   ireturn

                                              Pool of
     3                                       constants
    Stack
Example 1
                                       JVM (heap)
0     1     2 3                              Class
                                        0:   iload_0
3     7     4                           1:   iload_1
                                  PC    2:   iadd
                Local variables         3:   istore_3
                                        4:   iload_3
                                        5:   iload_2
                F0




                                              Class
                                        6:   iadd
                                        7:   istore_3
                                        8:   iload_3
                                        9:   ireturn
     7                                        Pool of
     3                                       constants
    Stack
Example 1
                                       JVM (heap)
0     1     2 3                              Class
                                        0:   iload_0
3     7     4                           1:   iload_1
                                        2:   iadd
                Local variables   PC    3:   istore_3
                                        4:   iload_3
                                        5:   iload_2
                F0




                                              Class
                                        6:   iadd
                                        7:   istore_3
                                        8:   iload_3
                                        9:   ireturn

                                              Pool of
    10                                       constants
    Stack
Example 1
                                      JVM (heap)
0     1     2 3                             Class
                                       0:   iload_0
3     7     4 10                       1:   iload_1
                                       2:   iadd
               Local variables         3:   istore_3
                                 PC    4:   iload_3
                                       5:   iload_2
               F0




                                             Class
                                       6:   iadd
                                       7:   istore_3
                                       8:   iload_3
                                       9:   ireturn

                                             Pool of
                                            constants
    Stack
Example 1
                                      JVM (heap)
0     1     2 3                             Class
                                       0:   iload_0
3     7     4 10                       1:   iload_1
                                       2:   iadd
               Local variables         3:   istore_3
                                       4:   iload_3
                                 PC    5:   iload_2
               F0




                                             Class
                                       6:   iadd
                                       7:   istore_3
                                       8:   iload_3
                                       9:   ireturn

                                             Pool of
    10                                      constants
    Stack
Example 1
                                      JVM (heap)
0     1     2 3                             Class
                                       0:   iload_0
3     7     4 10                       1:   iload_1
                                       2:   iadd
               Local variables         3:   istore_3
                                       4:   iload_3
                                       5:   iload_2
               F0




                                             Class
                                 PC    6:   iadd
                                       7:   istore_3
                                       8:   iload_3
                                       9:   ireturn
     4                                       Pool of
    10                                      constants
    Stack
Example 1
                                      JVM (heap)
0     1     2 3                             Class
                                       0:   iload_0
3     7     4 10                       1:   iload_1
                                       2:   iadd
               Local variables         3:   istore_3
                                       4:   iload_3
                                       5:   iload_2
               F0




                                             Class
                                       6:   iadd
                                 PC    7:   istore_3
                                       8:   iload_3
                                       9:   ireturn

                                             Pool of
    14                                      constants
    Stack
Example 1
                                      JVM (heap)
0     1     2 3                             Class
                                       0:   iload_0
3     7     4 14                       1:   iload_1
                                       2:   iadd
               Local variables         3:   istore_3
                                       4:   iload_3
                                       5:   iload_2
               F0




                                             Class
                                       6:   iadd
                                       7:   istore_3
                                 PC    8:   iload_3
                                       9:   ireturn

                                             Pool of
                                            constants
    Stack
Example 1
                                      JVM (heap)
0     1     2 3                             Class
                                       0:   iload_0
3     7     4 14                       1:   iload_1
                                       2:   iadd
               Local variables         3:   istore_3
                                       4:   iload_3
                                       5:   iload_2
               F0




                                             Class
                                       6:   iadd
                                       7:   istore_3
                                       8:   iload_3
                                 PC    9:   ireturn

                                             Pool of
    14                                      constants
    Stack
Example 1
public static int whatIsThis(int, int, int);
  Signature: (III)I
  Code:
    0: iload_0
    1: iload_1
    2: iadd
    3: istore_3
    4: iload_3
    5: iload_2
                       public static int //
    6: iadd            whatIsThis(int a, int b, int c) {
    7: istore_3          int result = a + b;
    8: iload_3           result += c;
    9: ireturn           return result;
                       }
Example 2
public static int whatIsThis(int, int, int);
  Signature: (III)I
  Code:
    0: iload_0
    1: iload_1
    2: iadd
    3: iload_2
    4: iadd
    5: ireturn
Example 2
public static int whatIsThis(int, int, int);
  Signature: (III)I
  Code:
    0: iload_0
    1: iload_1
    2: iadd
    3: iload_2
    4: iadd
    5: ireturn
                       public static int //
                       whatIsThis(int a, int b, int c) {
                         return a + b + c;
                       }
Example 3
public static int whatIsThis(int, float, double);
  Signature: (IFD)I
  Code:
    0: iload_0
    1: i2f
    2: fload_1
    3: fadd
    4: f2d
    5: dload_2
    6: dadd
    7: d2i
    8: ireturn
  LineNumberTable:
    line 6: 0
  LocalVariableTable:
    Start Length Slot Name      Signature
            0       9    0     a   I
            0       9    1     b   F
            0       9    2     c   D
Example 3
public static int whatIsThis(int, float, double);
  Signature: (IFD)I
  Code:
    0: iload_0
    1: i2f
    2: fload_1
    3: fadd
    4: f2d
    5: dload_2
    6: dadd
    7: d2i
    8: ireturn
  LineNumberTable:               public static int    //
    line 6: 0                    whatIsThis(int a,    float b, //
  LocalVariableTable:                   double c) {
    Start Length Slot Name      Signature
            0       9    0     a
                                   return (int) (a
                                   I
                                                      + b + c);
            0       9    1     b} F
            0       9    2     c   D
Example 4
public static void main(java.lang.String[]);
 Code:
  0: getstatic     #16
                       // Field java/lang/System.out:Ljava/io/PrintStream;
  3: ldc           #22 // String There
  5: invokevirtual #24
               // Method java/io/PrintStream.println:(Ljava/lang/String;)V
  8: return
More verbosity




javap -v -classpath PATH -p -c -l -s
                                CLASS
Example 4
Constant pool:

    #1=Class      #2     // org/kambanaria/readbytecode/bgoug/Example4

    #2=Utf8       org/kambanaria/readbytecode/bgoug/Example4

…

 #16=Fieldref     #17.#19 // java/lang/System.out:Ljava/io/PrintStream;

 #17=Class        #18     // java/lang/System

 #18=Utf8         java/lang/System

 #19=NameAndType #20:#21 // out:Ljava/io/PrintStream;

 #20=Utf8         out

 #21=Utf8         Ljava/io/PrintStream;

…

 #22=String      #23     // There

 #23=Utf8        There

 #24=Methodref   #25.#27 //java/io/PrintStream.println:(Ljava/lang/String;)V

…
Example 4
public static void main(java.lang.String[]);
 Code:
  0: getstatic     #16
                       // Field java/lang/System.out:Ljava/io/PrintStream;
  3: ldc           #22 // String There
  5: invokevirtual #24
               // Method java/io/PrintStream.println:(Ljava/lang/String;)V
  8: return




                               public static void //
                               main(String[] args) {
                                 System.out.println("There");
                               }

                               // Hello There!
Example 4
public static void main(java.lang.String[]);
 Code:
  0: getstatic     #16
                       // Field java/lang/System.out:Ljava/io/PrintStream;
  3: ldc           #22 // String There
  5: invokevirtual #24
               // Method java/io/PrintStream.println:(Ljava/lang/String;)V
  8: return
Example 4
 0:   getstatic     #16   getstatic = 0xb2,     16 = 0x00 10
 3:   ldc           #22   ldc = 0x12,           22 = 0x16
 5:   invokevirtual #24   invokevirtual = 0xb6, 24 = 0x00 18
 8:   return              return = 0xb1


b2 00 10 12 16 b6 00 18 b1


od -t x1 Example4.class | tail    -6
0001000 00 0e 00 0f 00 01 00 07   00   00   00   37   00   02   00   01
0001020 00 00 00 09 b2 00 10 12   16   b6   00   18   b1   00   00   00
0001040 02 00 0a 00 00 00 0a 00   02   00   00   00   07   00   08   00
0001060 08 00 0b 00 00 00 0c 00   01   00   00   00   09   00   1e   00
0001100 1f 00 00 00 01 00 20 00   00   00   02   00   21
0001115
Example 5
public char[] whatIsThis();
  Code:
   0:aload_0
   1:getfield      #12 // Field content:[C
   4:areturn

public static void   main(java.lang.String[]);
  Code:
   0:getstatic       #22 // Field java/lang/System.out:Ljava/io/PrintStream;
   3:new             #1 // class org/kambanaria/readbytecode/bgoug/Example5
   6:dup
   7:invokespecial   #28   //   Method   "<init>":()V
  10:invokevirtual   #29   //   Method   whatIsThis:()[C
  13:invokestatic    #31   //   Method   java/util/Arrays.toString:([C)Ljava/lang/String;
  16:invokevirtual   #37   //   Method   java/io/PrintStream.println:(Ljava/lang/String;)V
  19: return
Example 5
                                                  public char[] whatIsThis() {
public char[] whatIsThis();                         return this.content;
  Code:                                           }
   0:aload_0
   1:getfield      #12 // Field content:[C
   4:areturn

public static void   main(java.lang.String[]);
  Code:
   0:getstatic       #22 // Field java/lang/System.out:Ljava/io/PrintStream;
   3:new             #1 // class org/kambanaria/readbytecode/bgoug/Example5
   6:dup
   7:invokespecial   #28   //   Method   "<init>":()V
  10:invokevirtual   #29   //   Method   whatIsThis:()[C
  13:invokestatic    #31   //   Method   java/util/Arrays.toString:([C)Ljava/lang/String;
  16:invokevirtual   #37   //   Method   java/io/PrintStream.println:(Ljava/lang/String;)V
  19: return
Example 5
                                                        public static void    //
public char[] whatIsThis();
                                                        main(String[] args) {
  Code:                                                   System.out.println( //
   0:aload_0                                                Arrays.toString( //
   1:getfield      #12 // Field content:[C                    new Example5() //
   4:areturn                                                   .whatIsThis()));
public static void   main(java.lang.String[]);
                                                        }
  Code:
   0:getstatic       #22 // Field java/lang/System.out:Ljava/io/PrintStream;
   3:new             #1 // class org/kambanaria/readbytecode/bgoug/Example5
   6:dup
   7:invokespecial   #28   //   Method   "<init>":()V
  10:invokevirtual   #29   //   Method   whatIsThis:()[C
  13:invokestatic    #31   //   Method   java/util/Arrays.toString:([C)Ljava/lang/String;
  16:invokevirtual   #37   //   Method   java/io/PrintStream.println:(Ljava/lang/String;)V
  19: return
Level 11 – Stack/9
●   pop        a       ➔
●   pop2       ba      ➔
●   dup        a       ➔aa
●   dup_x1     ba      ➔aba
●   dup_x2     cba     ➔acba
●   dup2       ba      ➔baba
●   dup2_x1    cba     ➔bacba
●   dup2_x2    dcba    ➔badcba
●   swap       ba      ➔ab
Example 6
public void whatIsThis(java.lang.String);
 Code:
   0: aload_1
   1: ifnonnull     12
   4: new           #18 // class java/lang/NullPointerException
   7: dup
   8: invokespecial #20 // Method
                    java/lang/NullPointerException."<init>":()V
  11: athrow
  12: aload_0
  13: aload_1
  14: putfield      #21 // Field s:Ljava/lang/String;
  17: return
Example 6
public void whatIsThis(java.lang.String);
 Code:
   0: aload_1
   1: ifnonnull     12
   4: new           #18 // class java/lang/NullPointerException
   7: dup
   8: invokespecial #20 // Method
                    java/lang/NullPointerException."<init>":()V
  11: athrow
  12: aload_0
  13: aload_1
  14: putfield      #21 public void //
                         // Field s:Ljava/lang/String;
  17: return            whatIsThis(String s) {
                           if (null == s) {
                             throw new NullPointerException();
                           }
                           this.s = s;
                       }
Level 12 – conditions, branches,
                loops/19
●   ifeq, ifne, iflt, ifge, ifgt, ifle
●   if_icmpeq, if_icmpne, if_icmplt, if_icmpge,
    if_icmpgt, if_icmple
●   if_acmpeq, if_acmpne
●   ifnull, ifnonnull
●   goto, jsr, ret
193 of 206




94%
Example 7
public static int parse(java.lang.String);
  Code:
    0: aload_0
    1: invokestatic #16     // Method
                java/lang/Integer.parseInt:(Ljava/lang/String;)I
    4: ireturn
    5: astore_1
    6: iconst_0
    7: ireturn
  Exception table:
    from    to target type
        0    4      5   Class java/lang/NumberFormatException
                      public static int parse(String s) {
                        try {
                          return Integer.parseInt(s);
                        } catch (NumberFormatException e) {
                          return 0;
                      }
Example 8
public class org.kambanaria.readbytecode.bgoug.Example8 {
  static final boolean $assertionsDisabled;

 static {};
   Code:
     0: ldc             #1 // class org/kambanaria/readbytecode/bgoug/Example8
     2: invokevirtual   #10 // Method java/lang/Class.desiredAssertionStatus:()Z
     5: ifne            12
     8: iconst_1
     9: goto            13
    12: iconst_0
    13: putstatic       #16 // Field $assertionsDisabled:Z
    16: return



                     public class Example8 {
                       private static String repeat(String s) {
                         assert s != null;
                         return s + s;
                       }
                     }
Example 8
private static java.lang.String repeat(java.lang.String);
  Code:
    0:getstatic     #16 // Field $assertionsDisabled:Z
    3:ifne          18
    6:aload_0
    7:ifnonnull     18
   10:new           #28 // class java/lang/AssertionError
   13:dup
   14:invokespecial #30 // Method java/lang/AssertionError."<init>":()V
   17:athrow
   18:new           #31 // class java/lang/StringBuilder
   21:dup
   22:aload_0
   23:invokestatic #33 // Method
                         java/lang/String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
   26:invokespecial #39 // Method
                                  java/lang/StringBuilder."<init>":(Ljava/lang/String;)V
   29:aload_0
   30:invokevirtual #42 // Method
            java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
   33:invokevirtual #46 // Method
                                   java/lang/StringBuilder.toString:()Ljava/lang/String;
   36:areturn
}
Now You Know




Beware Asserts In Public
      Methods!
Example 9
    package org.kambanaria.readbytecode.bgoug;

    public class Example9 {
      public class Inner {}

        public static void //
        main(String[] args) throws Exception {
          Example9 exmpl = Example9.class.newInstance();
          Inner innr = Inner.class.newInstance();
        }
    }
java -cp bin/ org.kambanaria.readbytecode.bgoug.Example9
Exception in thread "main" java.lang.InstantiationException:
                        org.kambanaria.readbytecode.bgoug.Example9$Inner
    at java.lang.Class.newInstance0(Class.java:357)
    at java.lang.Class.newInstance(Class.java:325)
    at org.kambanaria.readbytecode.bgoug.Example9.main(Example9.java:9)
Example 9
public class org.kambanaria.readbytecode.bgoug.Example9 {
  public OKRB.Example9();
   Code:
    0:aload_0
    1:invokespecial #8 // Method java/lang/Object."<init>":()V
    4:return
…
}

public class org.kambanaria.readbytecode.bgoug.Example9$Inner {
  final OKRB.Example9 this$0;
  public OKRB.Example9$Inner(OKRB.Example9);
   Code:
    0:aload_0
    1:aload_1
    2:putfield      #10 //Field this$0:Lorg/kambanaria/readbytecode/bgoug/Example9;
    5:aload_0
    6:invokespecial #12 // Method java/lang/Object."<init>":()V
    9:return
}
Example 9
package org.kambanaria.readbytecode.bgoug;

public class Example9 {
  public class Inner {}

    public static void //
    main(String[] args) throws Exception {
      Example9 exmpl = new Example9();
      Inner innr = exmpl.new Inner();
    }
}
Further resources
●   Oracle: The JVM Specification, Java SE 7 Edition
●   A. Arhipov:
    Java Bytecode For Discriminating Developers
●   Wikipedia: Java Bytecode Instruction Listings
●   S. H. Park Understanding JVM Internals
●   C. McGlone: Looking "Under the Hood" with javap
●   P. Haggar: Java bytecode
●   C. Nutter: JVM Bytecode for Dummies
Presentation background
●   Alexander Wilms: Hexagons

More Related Content

ODP
I Know Kung Fu - Juggling Java Bytecode
PDF
In Vogue Dynamic
PDF
Mixing Source and Bytecode: A Case for Compilation By Normalization (OOPSLA 2...
PDF
Ruby Presentation
PDF
What is new and cool j2se & java
PDF
Inc0gnito 2015 Android DEX Analysis Technique
PDF
LinkedIn - Disassembling Dalvik Bytecode
PPTX
Dancing with dalvik
I Know Kung Fu - Juggling Java Bytecode
In Vogue Dynamic
Mixing Source and Bytecode: A Case for Compilation By Normalization (OOPSLA 2...
Ruby Presentation
What is new and cool j2se & java
Inc0gnito 2015 Android DEX Analysis Technique
LinkedIn - Disassembling Dalvik Bytecode
Dancing with dalvik

What's hot (17)

PDF
NDK Primer (Wearable DevCon 2014)
PDF
Ruby Programming Introduction
PDF
A bridge between php and ruby
PDF
Introduction to Ruby
PDF
Understanding the Dalvik bytecode with the Dedexer tool
PDF
TypeProf for IDE: Enrich Development Experience without Annotations
KEY
High Performance Ruby - Golden Gate RubyConf 2012
PDF
Groovy Up Your Code
PDF
NDK Primer (AnDevCon Boston 2014)
PDF
Type Profiler: Ambitious Type Inference for Ruby 3
PDF
Handling inline assembly in Clang and LLVM
KEY
Tew4 Yatce presentation
KEY
TEW4 Yatce deprecated slides
PDF
不深不淺,帶你認識 LLVM (Found LLVM in your life)
PDF
March2004-CPerlRun
PDF
LLVM Compiler - Link Time Optimization
PDF
Ruby Presentation - Beamer
NDK Primer (Wearable DevCon 2014)
Ruby Programming Introduction
A bridge between php and ruby
Introduction to Ruby
Understanding the Dalvik bytecode with the Dedexer tool
TypeProf for IDE: Enrich Development Experience without Annotations
High Performance Ruby - Golden Gate RubyConf 2012
Groovy Up Your Code
NDK Primer (AnDevCon Boston 2014)
Type Profiler: Ambitious Type Inference for Ruby 3
Handling inline assembly in Clang and LLVM
Tew4 Yatce presentation
TEW4 Yatce deprecated slides
不深不淺,帶你認識 LLVM (Found LLVM in your life)
March2004-CPerlRun
LLVM Compiler - Link Time Optimization
Ruby Presentation - Beamer
Ad

Viewers also liked (10)

DOCX
Chapter 1 nature of company
PDF
company law - lifting the corporate veil - akash
PPTX
nature and definition of a company
PPTX
Definition and nature of company law
PPTX
Lifting the Corporate Veil
PPTX
Lifting the veil of corporate personality
PPT
Lifting the Corporate Veil
PPTX
Company Law - Piercing the Corporate Veil
PPTX
Nature of company
PPTX
Lifting of corporate veil
Chapter 1 nature of company
company law - lifting the corporate veil - akash
nature and definition of a company
Definition and nature of company law
Lifting the Corporate Veil
Lifting the veil of corporate personality
Lifting the Corporate Veil
Company Law - Piercing the Corporate Veil
Nature of company
Lifting of corporate veil
Ad

Similar to Lifting The Veil - Reading Java Bytecode During Lunchtime (20)

PDF
Lifting The Veil - Reading Java Bytecode
PDF
FTD JVM Internals
PDF
Java Runtime: повседневные обязанности JVM
PPTX
JAVA BYTE CODE
PDF
Javascript engine performance
PPTX
Dissecting the Hotspot JVM
PDF
Code lifecycle in the jvm - TopConf Linz
PDF
Jvm internals
PPT
Byte code jvm
PDF
Specialized Compiler for Hash Cracking
PPTX
Turbo charging v8 engine
PPTX
PDF
XS Boston 2008 Paravirt Ops in Linux IA64
PDF
JNA - Let's C what it's worth
PDF
Java Full Throttle
PDF
Java%20 programming%20guide%20 %20quick%20reference
PDF
Java programming guide - quick reference
PDF
Java Programming Guide Quick Reference
PDF
Java%20 programming%20guide%20 %20quick%20reference
PDF
Java cheat sheet
Lifting The Veil - Reading Java Bytecode
FTD JVM Internals
Java Runtime: повседневные обязанности JVM
JAVA BYTE CODE
Javascript engine performance
Dissecting the Hotspot JVM
Code lifecycle in the jvm - TopConf Linz
Jvm internals
Byte code jvm
Specialized Compiler for Hash Cracking
Turbo charging v8 engine
XS Boston 2008 Paravirt Ops in Linux IA64
JNA - Let's C what it's worth
Java Full Throttle
Java%20 programming%20guide%20 %20quick%20reference
Java programming guide - quick reference
Java Programming Guide Quick Reference
Java%20 programming%20guide%20 %20quick%20reference
Java cheat sheet

More from Alexander Shopov (7)

ODP
700 Tons of Code Later
ODP
Knots - the Lazy Data Transfer Objects for Dealing with the Microservices Craze
ODP
Нови приключения на преводачите
PDF
Bundling Packages and Deploying Applications with RPM
PDF
Beyond the Final Frontier of jQuery Selectors
PDF
Oracle's Take On NoSQL
PDF
Caching in HTTP
700 Tons of Code Later
Knots - the Lazy Data Transfer Objects for Dealing with the Microservices Craze
Нови приключения на преводачите
Bundling Packages and Deploying Applications with RPM
Beyond the Final Frontier of jQuery Selectors
Oracle's Take On NoSQL
Caching in HTTP

Recently uploaded (20)

PDF
Machine learning based COVID-19 study performance prediction
PPTX
A Presentation on Artificial Intelligence
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Empathic Computing: Creating Shared Understanding
PDF
KodekX | Application Modernization Development
PDF
Modernizing your data center with Dell and AMD
PDF
Spectral efficient network and resource selection model in 5G networks
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PPTX
Cloud computing and distributed systems.
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PPT
Teaching material agriculture food technology
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Encapsulation theory and applications.pdf
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PPTX
MYSQL Presentation for SQL database connectivity
Machine learning based COVID-19 study performance prediction
A Presentation on Artificial Intelligence
CIFDAQ's Market Insight: SEC Turns Pro Crypto
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Empathic Computing: Creating Shared Understanding
KodekX | Application Modernization Development
Modernizing your data center with Dell and AMD
Spectral efficient network and resource selection model in 5G networks
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Cloud computing and distributed systems.
NewMind AI Weekly Chronicles - August'25 Week I
Teaching material agriculture food technology
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Encapsulation theory and applications.pdf
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
MYSQL Presentation for SQL database connectivity

Lifting The Veil - Reading Java Bytecode During Lunchtime

  • 1. Lifting The Veil – Reading Java Byte Code During Lunchtime Alexander Shopov Cisco Lunch&Learn
  • 2. Alexander Shopov By day: Software Engineer at Cisco By night: OSS contributor Coordinator of Bulgarian Gnome TP Contacts: E-mail: ash@kambanaria.org Jabber: al_shopov@jabber.minus273.org LinkedIn: http://www.linkedin.com/in/alshopov Google: Just search “al_shopov“
  • 3. Please Learn And Share License: CC-BY v3.0 Creative Commons Attribution v3.0
  • 4. Disclaimer My opinions, knowledge and experience! Not my employer's.
  • 5. Contents ● Why read? ● How to read? ● JVM Internals; ● JVM Data Types; ● JVM Opcodes. ● Let's read some code. ● What next?
  • 6. Why Read Byte code? ● Understand your platform ● It is interesting and not too hard ● How does Java function? How does X function? ● Job interviews ● Catch compiler bugs/optimizations ● Learn to read before you write ● Source may not correspond to binary ● C/C++ people know their assembler ● Java language evolution vs. Java platform evolution
  • 7. Bad News And Good News Bad: Good: We will be Easiest reading assembler assembler in world
  • 8. What Is The JVM? ● Stack based, byte oriented virtual machine without registers easily implementable on 32 bit hardware. ● 206 (<256) instructions that are easy to group and there is no need to remember them all ● Some leeway in implementations (even with Oracle)
  • 9. Dramatis Personæ ● The JVM ● The threads ● The frames ● The stacks – LIFO ● The local variables – array of slots ● The runtime constant pool – array of values ● The bytecode – the instructions ● Class files – serialized form of constants and byte code
  • 10. Enter JVM JVM OS process
  • 11. Thread A Thread B Thread C Enter Threads Thread D
  • 12. Enter Frames F4 Thread C Thread D Thread A Thread B F3 F3 F2 F2 F2 F1 F1 F1 F1 F0 F0 F0 F0
  • 13. Enter Frames, Really! F0 F0 F2 F3 F3 F0 F2 F1 F1 F1 F1 F0 F4 F2
  • 14. What Is A Frame Actually? F0
  • 15. Let's Peek Inside A Frame F0
  • 16. Enter Local Variables 0 1 2 3 4 5 6 … Local variables F0
  • 17. Enter Stack 0 1 2 3 4 5 6 … Local variables F0 Stack
  • 18. Enter Pool Of Constants 0 1 2 3 4 5 6 … Local variables F0 Pool of constants Stack
  • 19. Where Is The Code? 0 1 2 3 4 5 6 … Local variables F0 Pool of constants Stack
  • 20. Where Is The Code? JVM (heap) 0 1 2 3 4 5 6 … Local variables F0 Pool of constants Stack
  • 21. Where Is The Code? JVM (heap) 0 1 2 3 4 5 6 … Class PC Local variables Method code F0 Class Pool of constants Stack
  • 22. Where is the code? JVM (heap) 0 1 2 3 4 5 6 … Class 6 PC Local variables Method code F0 Class Pool of constants Stack
  • 23. Load JVM (heap) 0 1 2 3 4 5 6 … Class 6 PC Local variables Method code F0 Class Pool of constants 6 Stack
  • 24. Load JVM (heap) 0 1 2 3 4 5 6 … Class 6 PC Local variables Method code F0 Class Pool of constants 6 Stack
  • 25. And… JVM (heap) 0 1 2 3 4 5 6 … Class 6 PC Local variables Method code F0 Class Pool of 8 constants 6 Stack
  • 26. Store JVM (heap) 0 1 2 3 4 5 6 … Class 6 8 Local variables PC Method code F0 Class Pool of 8 constants 6 Stack
  • 27. JVM Datatypes ● Primitive types ● Java { numeric – integral: byte (±8), short (±16), int (±32), long (±64), char (+16), floating point: float (±32), double (±64); boolean (int or byte) } ● returnAddress – pointers to the opcodes of JVM (jumps - loops) ● Reference types ● class, array, interface ● null
  • 28. JVM Datatypes Descriptors Java type Type descriptor boolean Z char C byte B short S int I float F long J double D Object Ljava/lang/Object; byte[] [B String[][] [[Ljava/lang/String; void V
  • 29. JVM Method Descriptors Source Code Method Method Descriptor declaration void m1(int i, double d, (IDF)V float f) byte[] m2(String s) (Ljava/lang/String;)[B Object m3(int[][][] i) ([[[I)Ljava/lang/Object; boolean[] m4()
  • 30. JVM Method Descriptors Source Code Method Method Descriptor declaration void m1(int i, double d, (IDF)V float f) byte[] m2(String s) (Ljava/lang/String;)[B Object m3(int[][][] i) ([[[I)Ljava/lang/Object; boolean[] m4() ()[B (Ljava/lang/Object;Ljava/lang/Long;)J
  • 31. JVM Method Descriptors Source Code Method Method Descriptor declaration void m1(int i, double d, (IDF)V float f) byte[] m2(String s) (Ljava/lang/String;)[B Object m3(int[][][] i) ([[[I)Ljava/lang/Object; boolean[] m4() ()[B long m5(Object, Long) (Ljava/lang/Object;Ljava/lang/Long;)J
  • 33. Level 1 – Do Nothing/1 ● nop
  • 34. Level 2 – Load Constants/20 ● aconst_null, ● iconst_m1, iconst_0, iconst_1, iconst_2, iconst_3, iconst_4, iconst_5 ● lconst_0, lconst_1, ● fconst_0, fconst_1, fconst_2 ● dconst_0, dconst_1 ● bipush, sipush – 1, 2 bytes ● ldc, ldc_w, ldc2_w – load from index in constant pool 1,2,2 bytes for index
  • 35. Level 3 – Load Variables/33 ● iload, lload, fload, dload, aload ● iload_0, iload_1, iload_2, iload_3, lload_0, lload_1, lload_2, lload_3, fload_0, fload_1, fload_2, fload_3, dload_0, dload_1, dload_2, dload_3, aload_0, aload_1, aload_2, aload_3 ● iaload, laload, faload, daload, aaload, baload, caload, saload – consume reference to array and int index in it
  • 36. Level 4 – Conversions/15 ● i2l, i2f, i2d, l2i, l2f, l2d, f2i, f2l, f2d, d2i, d2l, d2f, i2b, i2c, i2s
  • 37. Level 6 – Maths/37 ● iadd, ladd, fadd, dadd, isub, lsub, fsub, dsub, imul, lmul, fmul, dmul, idiv, ldiv, fdiv, ddiv, irem, lrem, frem, drem, ineg, lneg, fneg, dneg, ishl, lshl, ishr, lshr, iushr, lushr, iand, land, ior, lor, ixor, lxor ● Iinc - increment local variable #index by signed byte const
  • 38. Level 7 – Stores/33 ● istore, lstore, fstore, dstore, astore, istore_0, istore_1, istore_2, istore_3, lstore_0, lstore_1, lstore_2, lstore_3, fstore_0, fstore_1, fstore_2, fstore_3, dstore_0, dstore_1, dstore_2, dstore_3, astore_0, astore_1, astore_2, astore_3, iastore, lastore, fastore, dastore, aastore, bastore, castore, sastore
  • 39. Level 8 – No-branch Comparisons/5 ● lcmp, fcmpl, fcmpg, dcmpl, dcmpg (beware NaN)
  • 40. Level 9 – Objects/15 ● getstatic, putstatic ● getfield, putfield ● invokevirtual, invokespecial, invokestatic, invokeinterface ● new, newarray, anewarray ● arraylength ● athrow ● checkcast, instanceof (difference is treatment of null)
  • 41. Level 10 – Return/6 ● ireturn, lreturn, freturn, dreturn, areturn, return
  • 43. We Have Enough Mana/Resources! Let's dive in bytecode!
  • 44. Enter Bytecode javap – your only true friend now javap -classpath PATH -p -c -l -s CLASS
  • 45. Example 1 public static int whatIsThis(int, int, int); Signature: (III)I Code: 0: iload_0 1: iload_1 2: iadd 3: istore_3 4: iload_3 5: iload_2 6: iadd 7: istore_3 8: iload_3 9: ireturn
  • 46. Example 1 JVM (heap) 0 1 2 3 Class PC 0: iload_0 3 7 4 1: iload_1 2: iadd Local variables 3: istore_3 4: iload_3 5: iload_2 F0 Class 6: iadd 7: istore_3 8: iload_3 9: ireturn Pool of constants Stack
  • 47. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 PC 1: iload_1 2: iadd Local variables 3: istore_3 4: iload_3 5: iload_2 F0 Class 6: iadd 7: istore_3 8: iload_3 9: ireturn Pool of 3 constants Stack
  • 48. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 1: iload_1 PC 2: iadd Local variables 3: istore_3 4: iload_3 5: iload_2 F0 Class 6: iadd 7: istore_3 8: iload_3 9: ireturn 7 Pool of 3 constants Stack
  • 49. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 1: iload_1 2: iadd Local variables PC 3: istore_3 4: iload_3 5: iload_2 F0 Class 6: iadd 7: istore_3 8: iload_3 9: ireturn Pool of 10 constants Stack
  • 50. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 10 1: iload_1 2: iadd Local variables 3: istore_3 PC 4: iload_3 5: iload_2 F0 Class 6: iadd 7: istore_3 8: iload_3 9: ireturn Pool of constants Stack
  • 51. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 10 1: iload_1 2: iadd Local variables 3: istore_3 4: iload_3 PC 5: iload_2 F0 Class 6: iadd 7: istore_3 8: iload_3 9: ireturn Pool of 10 constants Stack
  • 52. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 10 1: iload_1 2: iadd Local variables 3: istore_3 4: iload_3 5: iload_2 F0 Class PC 6: iadd 7: istore_3 8: iload_3 9: ireturn 4 Pool of 10 constants Stack
  • 53. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 10 1: iload_1 2: iadd Local variables 3: istore_3 4: iload_3 5: iload_2 F0 Class 6: iadd PC 7: istore_3 8: iload_3 9: ireturn Pool of 14 constants Stack
  • 54. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 14 1: iload_1 2: iadd Local variables 3: istore_3 4: iload_3 5: iload_2 F0 Class 6: iadd 7: istore_3 PC 8: iload_3 9: ireturn Pool of constants Stack
  • 55. Example 1 JVM (heap) 0 1 2 3 Class 0: iload_0 3 7 4 14 1: iload_1 2: iadd Local variables 3: istore_3 4: iload_3 5: iload_2 F0 Class 6: iadd 7: istore_3 8: iload_3 PC 9: ireturn Pool of 14 constants Stack
  • 56. Example 1 public static int whatIsThis(int, int, int); Signature: (III)I Code: 0: iload_0 1: iload_1 2: iadd 3: istore_3 4: iload_3 5: iload_2 public static int // 6: iadd whatIsThis(int a, int b, int c) { 7: istore_3 int result = a + b; 8: iload_3 result += c; 9: ireturn return result; }
  • 57. Example 2 public static int whatIsThis(int, int, int); Signature: (III)I Code: 0: iload_0 1: iload_1 2: iadd 3: iload_2 4: iadd 5: ireturn
  • 58. Example 2 public static int whatIsThis(int, int, int); Signature: (III)I Code: 0: iload_0 1: iload_1 2: iadd 3: iload_2 4: iadd 5: ireturn public static int // whatIsThis(int a, int b, int c) { return a + b + c; }
  • 59. Example 3 public static int whatIsThis(int, float, double); Signature: (IFD)I Code: 0: iload_0 1: i2f 2: fload_1 3: fadd 4: f2d 5: dload_2 6: dadd 7: d2i 8: ireturn LineNumberTable: line 6: 0 LocalVariableTable: Start Length Slot Name Signature 0 9 0 a I 0 9 1 b F 0 9 2 c D
  • 60. Example 3 public static int whatIsThis(int, float, double); Signature: (IFD)I Code: 0: iload_0 1: i2f 2: fload_1 3: fadd 4: f2d 5: dload_2 6: dadd 7: d2i 8: ireturn LineNumberTable: public static int // line 6: 0 whatIsThis(int a, float b, // LocalVariableTable: double c) { Start Length Slot Name Signature 0 9 0 a return (int) (a I + b + c); 0 9 1 b} F 0 9 2 c D
  • 61. Example 4 public static void main(java.lang.String[]); Code: 0: getstatic #16 // Field java/lang/System.out:Ljava/io/PrintStream; 3: ldc #22 // String There 5: invokevirtual #24 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 8: return
  • 62. More verbosity javap -v -classpath PATH -p -c -l -s CLASS
  • 63. Example 4 Constant pool: #1=Class #2 // org/kambanaria/readbytecode/bgoug/Example4 #2=Utf8 org/kambanaria/readbytecode/bgoug/Example4 … #16=Fieldref #17.#19 // java/lang/System.out:Ljava/io/PrintStream; #17=Class #18 // java/lang/System #18=Utf8 java/lang/System #19=NameAndType #20:#21 // out:Ljava/io/PrintStream; #20=Utf8 out #21=Utf8 Ljava/io/PrintStream; … #22=String #23 // There #23=Utf8 There #24=Methodref #25.#27 //java/io/PrintStream.println:(Ljava/lang/String;)V …
  • 64. Example 4 public static void main(java.lang.String[]); Code: 0: getstatic #16 // Field java/lang/System.out:Ljava/io/PrintStream; 3: ldc #22 // String There 5: invokevirtual #24 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 8: return public static void // main(String[] args) { System.out.println("There"); } // Hello There!
  • 65. Example 4 public static void main(java.lang.String[]); Code: 0: getstatic #16 // Field java/lang/System.out:Ljava/io/PrintStream; 3: ldc #22 // String There 5: invokevirtual #24 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 8: return
  • 66. Example 4 0: getstatic #16 getstatic = 0xb2, 16 = 0x00 10 3: ldc #22 ldc = 0x12, 22 = 0x16 5: invokevirtual #24 invokevirtual = 0xb6, 24 = 0x00 18 8: return return = 0xb1 b2 00 10 12 16 b6 00 18 b1 od -t x1 Example4.class | tail -6 0001000 00 0e 00 0f 00 01 00 07 00 00 00 37 00 02 00 01 0001020 00 00 00 09 b2 00 10 12 16 b6 00 18 b1 00 00 00 0001040 02 00 0a 00 00 00 0a 00 02 00 00 00 07 00 08 00 0001060 08 00 0b 00 00 00 0c 00 01 00 00 00 09 00 1e 00 0001100 1f 00 00 00 01 00 20 00 00 00 02 00 21 0001115
  • 67. Example 5 public char[] whatIsThis(); Code: 0:aload_0 1:getfield #12 // Field content:[C 4:areturn public static void main(java.lang.String[]); Code: 0:getstatic #22 // Field java/lang/System.out:Ljava/io/PrintStream; 3:new #1 // class org/kambanaria/readbytecode/bgoug/Example5 6:dup 7:invokespecial #28 // Method "<init>":()V 10:invokevirtual #29 // Method whatIsThis:()[C 13:invokestatic #31 // Method java/util/Arrays.toString:([C)Ljava/lang/String; 16:invokevirtual #37 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 19: return
  • 68. Example 5 public char[] whatIsThis() { public char[] whatIsThis(); return this.content; Code: } 0:aload_0 1:getfield #12 // Field content:[C 4:areturn public static void main(java.lang.String[]); Code: 0:getstatic #22 // Field java/lang/System.out:Ljava/io/PrintStream; 3:new #1 // class org/kambanaria/readbytecode/bgoug/Example5 6:dup 7:invokespecial #28 // Method "<init>":()V 10:invokevirtual #29 // Method whatIsThis:()[C 13:invokestatic #31 // Method java/util/Arrays.toString:([C)Ljava/lang/String; 16:invokevirtual #37 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 19: return
  • 69. Example 5 public static void // public char[] whatIsThis(); main(String[] args) { Code: System.out.println( // 0:aload_0 Arrays.toString( // 1:getfield #12 // Field content:[C new Example5() // 4:areturn .whatIsThis())); public static void main(java.lang.String[]); } Code: 0:getstatic #22 // Field java/lang/System.out:Ljava/io/PrintStream; 3:new #1 // class org/kambanaria/readbytecode/bgoug/Example5 6:dup 7:invokespecial #28 // Method "<init>":()V 10:invokevirtual #29 // Method whatIsThis:()[C 13:invokestatic #31 // Method java/util/Arrays.toString:([C)Ljava/lang/String; 16:invokevirtual #37 // Method java/io/PrintStream.println:(Ljava/lang/String;)V 19: return
  • 70. Level 11 – Stack/9 ● pop a ➔ ● pop2 ba ➔ ● dup a ➔aa ● dup_x1 ba ➔aba ● dup_x2 cba ➔acba ● dup2 ba ➔baba ● dup2_x1 cba ➔bacba ● dup2_x2 dcba ➔badcba ● swap ba ➔ab
  • 71. Example 6 public void whatIsThis(java.lang.String); Code: 0: aload_1 1: ifnonnull 12 4: new #18 // class java/lang/NullPointerException 7: dup 8: invokespecial #20 // Method java/lang/NullPointerException."<init>":()V 11: athrow 12: aload_0 13: aload_1 14: putfield #21 // Field s:Ljava/lang/String; 17: return
  • 72. Example 6 public void whatIsThis(java.lang.String); Code: 0: aload_1 1: ifnonnull 12 4: new #18 // class java/lang/NullPointerException 7: dup 8: invokespecial #20 // Method java/lang/NullPointerException."<init>":()V 11: athrow 12: aload_0 13: aload_1 14: putfield #21 public void // // Field s:Ljava/lang/String; 17: return whatIsThis(String s) { if (null == s) { throw new NullPointerException(); } this.s = s; }
  • 73. Level 12 – conditions, branches, loops/19 ● ifeq, ifne, iflt, ifge, ifgt, ifle ● if_icmpeq, if_icmpne, if_icmplt, if_icmpge, if_icmpgt, if_icmple ● if_acmpeq, if_acmpne ● ifnull, ifnonnull ● goto, jsr, ret
  • 75. Example 7 public static int parse(java.lang.String); Code: 0: aload_0 1: invokestatic #16 // Method java/lang/Integer.parseInt:(Ljava/lang/String;)I 4: ireturn 5: astore_1 6: iconst_0 7: ireturn Exception table: from to target type 0 4 5 Class java/lang/NumberFormatException public static int parse(String s) { try { return Integer.parseInt(s); } catch (NumberFormatException e) { return 0; }
  • 76. Example 8 public class org.kambanaria.readbytecode.bgoug.Example8 { static final boolean $assertionsDisabled; static {}; Code: 0: ldc #1 // class org/kambanaria/readbytecode/bgoug/Example8 2: invokevirtual #10 // Method java/lang/Class.desiredAssertionStatus:()Z 5: ifne 12 8: iconst_1 9: goto 13 12: iconst_0 13: putstatic #16 // Field $assertionsDisabled:Z 16: return public class Example8 { private static String repeat(String s) { assert s != null; return s + s; } }
  • 77. Example 8 private static java.lang.String repeat(java.lang.String); Code: 0:getstatic #16 // Field $assertionsDisabled:Z 3:ifne 18 6:aload_0 7:ifnonnull 18 10:new #28 // class java/lang/AssertionError 13:dup 14:invokespecial #30 // Method java/lang/AssertionError."<init>":()V 17:athrow 18:new #31 // class java/lang/StringBuilder 21:dup 22:aload_0 23:invokestatic #33 // Method java/lang/String.valueOf:(Ljava/lang/Object;)Ljava/lang/String; 26:invokespecial #39 // Method java/lang/StringBuilder."<init>":(Ljava/lang/String;)V 29:aload_0 30:invokevirtual #42 // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder; 33:invokevirtual #46 // Method java/lang/StringBuilder.toString:()Ljava/lang/String; 36:areturn }
  • 78. Now You Know Beware Asserts In Public Methods!
  • 79. Example 9 package org.kambanaria.readbytecode.bgoug; public class Example9 { public class Inner {} public static void // main(String[] args) throws Exception { Example9 exmpl = Example9.class.newInstance(); Inner innr = Inner.class.newInstance(); } } java -cp bin/ org.kambanaria.readbytecode.bgoug.Example9 Exception in thread "main" java.lang.InstantiationException: org.kambanaria.readbytecode.bgoug.Example9$Inner at java.lang.Class.newInstance0(Class.java:357) at java.lang.Class.newInstance(Class.java:325) at org.kambanaria.readbytecode.bgoug.Example9.main(Example9.java:9)
  • 80. Example 9 public class org.kambanaria.readbytecode.bgoug.Example9 { public OKRB.Example9(); Code: 0:aload_0 1:invokespecial #8 // Method java/lang/Object."<init>":()V 4:return … } public class org.kambanaria.readbytecode.bgoug.Example9$Inner { final OKRB.Example9 this$0; public OKRB.Example9$Inner(OKRB.Example9); Code: 0:aload_0 1:aload_1 2:putfield #10 //Field this$0:Lorg/kambanaria/readbytecode/bgoug/Example9; 5:aload_0 6:invokespecial #12 // Method java/lang/Object."<init>":()V 9:return }
  • 81. Example 9 package org.kambanaria.readbytecode.bgoug; public class Example9 { public class Inner {} public static void // main(String[] args) throws Exception { Example9 exmpl = new Example9(); Inner innr = exmpl.new Inner(); } }
  • 82. Further resources ● Oracle: The JVM Specification, Java SE 7 Edition ● A. Arhipov: Java Bytecode For Discriminating Developers ● Wikipedia: Java Bytecode Instruction Listings ● S. H. Park Understanding JVM Internals ● C. McGlone: Looking "Under the Hood" with javap ● P. Haggar: Java bytecode ● C. Nutter: JVM Bytecode for Dummies
  • 83. Presentation background ● Alexander Wilms: Hexagons