咦?不对,在OuterClass中我们并没有定义这两个方法
  static java.lang.String access$0(OuterClass);
  Code:
  0:  aload_0
  1:  getfield #15; //Field language:Ljava/lang/String;
  4:  areturn
  static java.lang.String access$1(OuterClass);
  Code:
  0:  aload_0
  1:  getfield #19; //Field region:Ljava/lang/String;
  4:  areturn
  }
  从给出来的注释来看,access$0返回outerClass的language属性;access$1返回outerClass的region属性。并且这两个方法都接受OuterClass的实例作为参数。这两个方法为什么生成呢,有什么作用呢?我们看一下内部类的反编译结果知道了。
  OuterClass$InnerClass的反编译结果
15:37 $ javap -c OuterClass$InnerClass
Compiled from "OuterClass.java"
public class OuterClass$InnerClass extends java.lang.Object{
final OuterClass this$0;
public OuterClass$InnerClass(OuterClass);
Code:
0:  aload_0
1:  aload_1
2:  putfield #10; //Field this$0:LOuterClass;
5:  aload_0
6:  invokespecial    #12; //Method java/lang/Object."<init>":()V
9:  return
public void printOuterClassPrivateFields();
Code:
0:  new  #20; //class java/lang/StringBuilder
3:  dup
4:  ldc  #22; //String language=
6:  invokespecial    #24; //Method java/lang/StringBuilder."<init>":(Ljava/lang/String;)V
9:  aload_0
10: getfield #10; //Field this$0:LOuterClass;
13: invokestatic #27; //Method OuterClass.access$0:(LOuterClass;)Ljava/lang/String;
16: invokevirtual    #33; //Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
19: ldc  #37; //String ;region=
21: invokevirtual    #33; //Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
24: aload_0
25: getfield #10; //Field this$0:LOuterClass;
28: invokestatic #39; //Method OuterClass.access$1:(LOuterClass;)Ljava/lang/String;
31: invokevirtual    #33; //Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
34: invokevirtual    #42; //Method java/lang/StringBuilder.toString:()Ljava/lang/String;
37: astore_1
38: getstatic    #46; //Field java/lang/System.out:Ljava/io/PrintStream;
41: aload_1
42: invokevirtual    #52; //Method java/io/PrintStream.println:(Ljava/lang/String;)V
45: return
}
  下面代码调用access$0的代码,其目的是得到OuterClass的language 私有属性。
  13:   invokestatic #27; //Method OuterClass.access$0:(LOuterClass;)Ljava/lang/String;
  下面代码调用了access$1的代码,其目的是得到OutherClass的region 私有属性。
  28:   invokestatic #39; //Method OuterClass.access$1:(LOuterClass;)Ljava/lang/String;
  注意:在内部类构造的时候,会将外部类的引用传递进来,并且作为内部类的一个属性,所以内部类会持有一个其外部类的引用。
  this$0是内部类持有的外部类引用,通过构造方法传递引用并赋值。
  final OuterClass this$0;
  public OuterClass$InnerClass(OuterClass);
  Code:
  0:  aload_0
  1:  aload_1
  2:  putfield #10; //Field this$0:LOuterClass;
  5:  aload_0
  6:  invokespecial    #12; //Method java/lang/Object."<init>":()V
  9:  return
  小结
  这部分private看上去失效可,实际上并没有失效,因为当内部类调用外部类的私有属性时,其真正的执行是调用了编译器生成的属性的静态方法(即acess$0,access$1等)来获取这些属性值。这一切都是编译器的特殊处理。
  这次也失效?
  如果说上面的写法很常用,那么这样的写法是不是很少接触,但是却可以运行。
  public class AnotherOuterClass {
  public static void main(String[] args) {
  InnerClass inner = new AnotherOuterClass().new InnerClass();
  System.out.println("InnerClass Filed = " + inner.x);
  }
  class InnerClass {
  private int x = 10;
  }
  }