Java에서 C 'friend' 개념 복제
객체 지향 프로그래밍에서 'friend' 개념을 사용하면 다양한 패키지의 클래스에서 서로의 비공개 메서드에 액세스합니다. C에서 이 기능은 'friend' 키워드를 통해 구현됩니다.
도전:
Java에서는 'friend' 개념에 직접적으로 상응하는 것이 없습니다. Java 프로그래머가 이 기능을 복제하여 비공개 메소드에 대한 패키지 간 액세스를 허용할 수 있습니까?
해결책:
Java에는 내장된 '친구'가 없지만 기능을 사용하면 유사한 동작을 달성하기 위해 영리한 기술을 사용할 수 있습니다.
중첩 클래스를 사용한 서명 보안:
공유 비밀을 나타내는 각 대상 클래스 내에 중첩 클래스를 생성하거나 ' 서명.' 이러한 클래스는 생성자에 대한 액세스가 제한되어 있어 승인된 인스턴스만 생성될 수 있습니다.
예:
다른 패키지에 있는 Romeo와 Juliet라는 두 클래스를 생각해 보세요. Romeo가 Juliet의 비공개 메서드에 액세스할 수 있도록 하기 위해 Juliet은 개인 생성자를 사용하여 중첩 클래스 TrueLove를 선언합니다.
// Juliet public class Juliet { private static class TrueLove {} public void cuddle(TrueLove love) { // Access to this method is restricted to Romeo through the TrueLove instance } }
서명에 대한 액세스 제한:
Romeo 공개 생성자를 사용하여 자체 중첩 클래스 Proposal을 정의합니다. 그러나 Juliet의 TrueLove 클래스에 대한 정적 참조도 포함되어 있어 서명에 대한 제어된 액세스를 제공합니다.
// Romeo public class Romeo { private static class Proposal { private static final TrueLove love = new TrueLove(); } public static void cuddleJuliet() { Juliet.cuddle(Proposal.love); } }
확인 및 보안:
Romeo가 cuddleJuliet을 호출할 때( ), Proposal.love의 인스턴스를 전달하여 Juliet의 비공개 메서드에 액세스할 수 있는 권한이 있는지 확인합니다. 다른 클래스가 TrueLove에 직접 액세스하려고 하면 개인 생성자로 인해 실패하므로 보안이 보장됩니다.
이 기술을 사용하면 Java 프로그래머는 중첩 클래스를 사용하여 공유 클래스에 대한 액세스를 제한함으로써 C '친구' 개념을 시뮬레이션할 수 있습니다. 발신자의 비밀을 확인하고 진위 여부를 확인합니다.
위 내용은 패키지 간 액세스를 위한 Java Mimic C의 'Friend' 개념이 가능합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!