5

コードのスニペットは次のとおりです。

public class Test {

    public static void main(String[] args) {

        class EnglishHelloThere {
              int a=10;
        }
    }

}

ローカル クラスを作成して、ローカル クラスの変数に対する修飾子がコンパイラから書き込まれていない場合にどのようなアクセス修飾子が取得されるかを確認しました。

これは私がJAVAPで得たものです

  Compiled from "Test.java"
class com.Test$1EnglishHelloThere
  SourceFile: "Test.java"
  EnclosingMethod: #21.#23                // com.Test.main
  InnerClasses:
       #27= #1; //EnglishHelloThere=class com/Test$1EnglishHelloThere
  minor version: 0
  major version: 51
  flags: ACC_SUPER
Constant pool:
   #1 = Class              #2             //  com/Test$1EnglishHelloThere
   #2 = Utf8               com/Test$1EnglishHelloThere
   #3 = Class              #4             //  java/lang/Object
   #4 = Utf8               java/lang/Object
   #5 = Utf8               a
   #6 = Utf8               I
   #7 = Utf8               <init>
   #8 = Utf8               ()V
   #9 = Utf8               Code
  #10 = Methodref          #3.#11         //  java/lang/Object."<init>":()V
  #11 = NameAndType        #7:#8          //  "<init>":()V
  #12 = Fieldref           #1.#13         //  com/Test$1EnglishHelloThere.a:I
  #13 = NameAndType        #5:#6          //  a:I
  #14 = Utf8               LineNumberTable
  #15 = Utf8               LocalVariableTable
  #16 = Utf8               this
  #17 = Utf8               Lcom/Test$1EnglishHelloThere;
  #18 = Utf8               SourceFile
  #19 = Utf8               Test.java
  #20 = Utf8               EnclosingMethod
  #21 = Class              #22            //  com/Test
  #22 = Utf8               com/Test
  #23 = NameAndType        #24:#25        //  main:([Ljava/lang/String;)V
  #24 = Utf8               main
  #25 = Utf8               ([Ljava/lang/String;)V
  #26 = Utf8               InnerClasses
  #27 = Utf8               EnglishHelloThere
{
  int a;
    flags:

  com.Test$1EnglishHelloThere();
    flags:
    Code:
      stack=2, locals=1, args_size=1
         0: aload_0
         1: invokespecial #10                 // Method java/lang/Object."<init>
":()V
         4: aload_0
         5: bipush        10
         7: putfield      #12                 // Field a:I
        10: return
      LineNumberTable:
        line 12: 0
        line 13: 4
        line 12: 10
      LocalVariableTable:
        Start  Length  Slot  Name   Signature
               0      11     0  this   Lcom/Test$1EnglishHelloThere;
}

基本的にフラグフィールドは空白のままなので、この変数がどのようなアクセス修飾子を取得するのか混乱しています

追加する private int a=10;public int a=10;取得する場合

public int a;
  flags: ACC_PUBLIC

また

protected int a;
  flags: ACC_PROTECTED

では、デフォルトで取得されるアクセス修飾子の種類は何ですか?

4

3 に答える 3

1

次の表は、各修飾子によって許可されるメンバーへのアクセスを示しています。

ここに画像の説明を入力

しかし、このアクセス修飾子は混乱を招く可能性があります「ここで許可されている用語に注意してください」。ローカル内部クラスはコードブロックに対してローカルであることに注意してください。これは、メソッドローカル内部クラスとも呼ばれるローカル内部クラスは、のクラスのメンバーではないことを意味します。コードは一部ですが、ローカル変数と同様に、それらが属するコード ブロックに対してローカルです。

それらが定義されているブロックの外からアクセスすることはできません。

たとえば、このコードを 1 つのパッケージで読み書きするとします。

package packageone.com;
public class HavingLocalClass {
    public HavingLocalClass() {
        // TODO Auto-generated constructor stub
    }
     void TestMethod(int a){
        class LocalClass{
            int localVar;
            public void display(){
            System.out.println(localVar);
            }

            public LocalClass(int localVar) {
                this.localVar=localVar;
                // TODO Auto-generated constructor stub
            }



            }

            LocalClass lc=new LocalClass(a);
            System.out.println(lc.localVar);
            /* If i directly try to print localVar here it will
                give me error */
            //System.out.println(localVar);//cannot be resolved into variable


    }
}

同じパッケージで印刷しようとすると、その方法でのみアクセスする必要があります。

package packageone.com;

public class TestingMain {
public static void main(String...strings){
HavingLocalClass tsp= new HavingLocalClass();
tsp.TestMethod(85);
}
}

出力85

于 2015-04-23T14:02:27.627 に答える
1

修飾子が存在しない場合のデフォルトは、package private (別名 package local) です。これにより、可視性が同じパッケージ内に制限されます。これは、クラスが定義されている場所 (トップレベル、内部、匿名、またはメソッド ローカル) に関係ありません。

とはいえ、メソッド ローカル クラスのフィールドの可視性は、メソッドのスコープに限定されているため、あまり重要ではありません。

于 2015-04-23T10:52:15.117 に答える
0

他の修飾子で指定されていない場合は、default/package-private 修飾子を取得します。また、ローカル変数を他の修飾子 (protected、public、または private) で割り当てることはできませんが、default.また、final で追加して制限することもできます。値の変更。詳細については

于 2015-04-23T11:10:56.450 に答える