Java에서 C 'friend' 개념 시뮬레이션
Java에서 서로 다른 패키지의 클래스 간 비공개 메서드에 대한 직접 액세스 권한을 부여하려면 다음을 고려하세요. 다음 기술:
1단계: "보안 서명" 생성 클래스
접속하려는 클래스의 패키지 내에서 "보안 서명" 역할을 하는 공개 클래스를 정의합니다. 이 클래스는 해당 패키지 내에서만 액세스할 수 있어야 합니다.
2단계: 생성자 제한
보안 서명 클래스의 생성자를 비공개로 만듭니다. 이렇게 하면 해당 패키지 내의 클래스만 인스턴스화할 수 있습니다.
3단계: 정적 참조 생성
보안 서명 클래스 유형의 정적 변수를 선언합니다. 이를 통해 서명 개체에 쉽게 액세스할 수 있습니다.
4단계: 대상 메서드 정의
제한적인 액세스를 허용하려는 클래스에서 다음을 요구하는 메서드를 정의합니다. 보안 서명 클래스를 인수로 사용합니다. 이 메소드에는 public 또는 protected와 같은 적절한 액세스 권한이 있어야 합니다.
예:
Romeo 클래스(Montague 패키지에 있음)가 Juliet 클래스의 공개 메소드(패키지 내) Capulet).
Juliet.java:
package capulet; public class Juliet { public void cuddle(Romeo.Love love) { if (love == null) { throw new NullPointerException(); } System.out.println("O Romeo, Romeo, wherefore art thou Romeo?"); } }
Romeo.java:
package montague; public class Romeo { public static final class Love { private Love() {} } private static final Love love = new Love(); public void cuddleJuliet() { Juliet.cuddle(love); } }
이 예에서는 , Romeo.Love 클래스가 보안 서명 역할을 합니다. 개인 생성자로 인해 Romeo만이 이를 생성할 수 있습니다. Juliet의 cuddle 메서드를 실행하려면 Romeo가 제공할 수 있는 Romeo.Love의 인스턴스가 필요합니다. 이는 Montague 패키지 외부의 다른 클래스로부터의 무단 액세스를 방지합니다.
위 내용은 Java에서 C의 `friend` 기능을 어떻게 시뮬레이션할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!