> Java > java지도 시간 > 본문

예제와 함께 Java의 액세스 권한 수정자에 대한 자세한 설명

高洛峰
풀어 주다: 2017-01-24 15:36:29
원래의
2323명이 탐색했습니다.

액세스 권한 기호:
(1) 공개:
회원의 경우: 동일한 패키지에 있든 다른 패키지에 있든 다른 클래스에서 액세스할 수 있습니다.
수업의 경우: 마찬가지입니다.
(2)Friendly:
구성원의 경우, 클래스 구성원에게 권한 수정이 없으면 기본 패키지 액세스 권한을 갖게 되며, 이는 Friendly로 표시됩니다.

친절함 Java의 키워드는 아니며, 제가 표현하고 싶은 방식일 뿐입니다. 같은 패키지에 있는 다른 클래스는 액세스할 수 있지만 패키지 외부의

액세스할 수 없습니다. 패키지를 사용하지 않는 동일한 폴더에 있는 클래스의 경우 Java는 먼저 이러한 클래스를

디렉터리에 속하는 기본 패키지로 자동으로 인식하고 클래스의 친숙한 멤버를 서로 호출할 수 있습니다. 예를 들어 다음 두 클래스는 동일한 폴더의

두 파일에 포함되어 있지만 패키지는 도입되지 않았지만 동일한 기본 패키지에 속합니다.

class Sundae{
//以下两个方法缺省为friendly
Sundae(){}
Void f() {System.out.println(“Sundae.f()”);
}
public class IceCream{
public static void main(String[] args){
Sundae x = new Sundae();
x.f();
}
}
로그인 후 복사

클래스의 경우: 동일한 패키지의 클래스를 사용할 수 있습니다. 즉, 클래스는 공개 또는 친화적으로만 선언할 수 있습니다.
(3)private:
회원의 경우 : 해당 회원이 속한 클래스에서만 접근이 가능합니다.

class Sundae{
   private Sundae(){}//只能在Sundae class中被调用
   Sundae(int i) {}
   static Sundae makASundae() {
   return new Sundae();
   }
   }
   public class IceCream{
   public static void main(String[] args){
   // Sundae class中构造函数Sundae()是private,
   // 所以不能用它进行初始化
   //Sundae x = new Sundae();
   Sundae y = new Sundae(1);//Sundae(int)是friendly,可以在此调用
   Sundae z = Sundae.makASundae();
   }
   }
로그인 후 복사

수업의 경우: 수업을 비공개로 선언할 수 없습니다.

(4)protected:
멤버의 경우: 동일한 패키지의 클래스에 액세스할 수 있습니다(패키지 액세스 권한). 기본 클래스는 protected를 통해 파생 클래스에 기본 클래스 멤버의 액세스 권한을 부여합니다. 모든 클래스(파생 클래스 액세스)가 아닙니다.

(5)default(기본 권한)
클래스, 데이터 멤버, 생성자 및 메서드 멤버는 모두 기본 권한을 사용할 수 있습니다. 즉, 키워드를 쓰지 않습니다. 기본 권한은 동일한 패키지 내의 권한입니다. 동일한 패키지 내의 권한을 가진 요소는 해당 요소가 정의된 클래스와 동일한 패키지 내의 클래스에서만 호출할 수 있습니다.

예: package c05.local;

import pack1.Cookie;
//注意:在这里ChocolateChip继承了类Cookie,按道理bite()方法也在
//ChocolateChip中,可以用x.bite直接调用,但是不可以的,因为类ChocolateChip
//和Cookie类不在一个包中,各自具有包访问权限,为了能够使用x.bite()必须要把
//Cookie方法的访问权限换成public或者protected,但是一旦换成public所有的人就
//可以访问了,这样达不到隐私的要求,所以设置成protected最好,既可以顺利访问,也可以
//避免外面的类调用,保护好隐私的作用
public class ChocolateChip extends Cookie {
  
  public ChocolateChip() {
   System.out.println("ChocolateChip constructor");
  }
  public static void main(String[] args) {
   ChocolateChip x = new ChocolateChip();
   x.bite(); // Can't access bite
   
  }
} ///:~
로그인 후 복사
package pack1;
 
public class Cookie {
public Cookie()
{
System.out.println("Cookie constructor");
}
 
protected void bite(){System.out.println("bite");}
 
}
로그인 후 복사

클래스의 경우: 클래스를 보호된 것으로 선언할 수 없습니다.

클래스 권한 수정의 경우 다음과 같습니다. 더 나은 설명은 다음과 같습니다.

수업 수업 접근 권한:
공개: 모든 수업에서 접근할 수 있습니다.
기본값: 기본값은 친숙하다고 할 수 있습니다. 그러나 Java 언어에는 친숙한 수정자가 없습니다. 이 이름은 C++에서 가져와야 합니다. 기본 액세스 권한은 패키지 수준 액세스 권한입니다.
즉, 접근권한 수정자를 쓰지 않고 클래스를 작성하면 기본 접근권한이 되며, 클래스를 인스턴스화할 수 있더라도 동일한 패키지에 속한 모든 클래스가 접근할 수 있습니다
(물론 , 이 클래스에 인스턴스화 기능을 제외하고(예를 들어 클래스가 공용 생성자를 제공하지 않는 경우)

참고:
1. 각 컴파일 단위(클래스 파일)는 하나의 공개 클래스만 가질 수 있습니다
2. 공개 클래스의 이름(대소문자 포함)은 다음과 같아야 합니다. 해당 클래스 파일.
3. 클래스 파일(*.java)에는 Public 클래스가 존재할 필요가 없습니다.
이 형식이 존재하는 시나리오: 패키지에 클래스를 작성하는 경우 동일한 패키지에 있는 다른 클래스와 함께 작업하기 위한 것이며
고객에게 문서를 작성하고 싶지 않습니다(반드시 그런 것은 아닙니다). 실제 고객이라면 이 클래스를 호출하는 클래스일 수도 있습니다.) 보기에도 벅차고 일정 시간이 지나면
원래 접근 방식을 완전히 바꾸고 기존 접근 방식을 완전히 버릴 수도 있습니다. 버전을 삭제하고 새로운 버전으로 교체하세요.
4. 수업은 비공개이거나 보호될 수 없습니다.
5. 특정 클래스의 객체가 생성되지 않도록 하려면 해당 클래스의 모든 생성자를 비공개로 설정하면 됩니다. 그러나 이러한 방식으로도 이 클래스의 개체가 생성될 수 있습니다. 즉, 클래스의 정적 멤버(속성 및 메서드)가 이를 수행할 수 있습니다.

종합 예:
First.java:

package Number;
import Test.*;
  
public class Frist extends Test
{
protected String s1 = "你好";
public static void main( String[] args)
{
String s2 = "java";
//System.out.println(s1);
System.out.println(s2);
  
Frist t = new Frist();
System.out.println(t.s);
t.show();
return;
}
  
}
  
Test.java:
package Test;
  
  
public class Test 
{
protected String s = "hello test"; //可以被同包中的类访问以及子类访问,该子类可以是与包Test不同
public void show()
{
Test1 t1 = new Test1();
return;
}
  
  
}
  
class Test1
{
Test1()
{
Test t = new Test();
System.out.println(t.s);
}
}
로그인 후 복사

출력:

java
hello test
hello test
로그인 후 복사

Java의 추가 예 기사용 접근 권한 수정자 관련 내용은 PHP 중국어 웹사이트를 참고하세요!


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿