2020. 5. 18. 19:58ㆍ프로그래밍/Java
제어자
제어자는 클래스 변수 또는 메서드의 선언부에 함께 사용되어 부가적인 의미를 부여합니다 제어자의 종류는 크게 접근 제어자와 그외 제어자로 나눌수 있습니다
- 접근 제어자: public, protected,default,private
- 그외 :static, final,abstract,native,transient,synchronized,volatile,strictfp
제어자는 클래스나 멤버 변수와 메서드에 주로 사용되며 사나의 대상에 대해서 여러 제어자를 조합하여 사용하는것이 가능합니다 단 접근 제어자는 한 번에 네가지 중에 하나만 선택해서 사용할 수 있습니다 즉 하나의 대상에 대해서 public과 private을 함께 사용할수 없습니다.
접근제어자
객체지향 에서 정보은닉은 사용자가 굳이 알 필요가 없는 정보를 사용자로부터 숨겨야 한다는 개념입니다 그렇게 함으로 써 사용자는 언제나 최소한의 정보만으로 프로그램을 손쉽게 사용할 수 있게 됩니다.
자바에서는 이러한 정보은닉을 위해 접근제어 자라는 기능을 제공하고 있으며 총 4가지의 접근제어자를 제공합니다.
접근 제어자 | 특징 |
public | 접근 제한이 전혀없습니다. |
default | 같은 패키지 내에서만 접근이 가능합니다 |
private | 같은 클래스 내에서만 접근이 가능합니다 |
protected | 같은 패키지 내에서 그리고 다른 패키지의 자손클랫에서 접근가능합니다 |
접근 제어자 | 같은 클래스 | 같은 패키지 | 자손클래스 | 전체 |
public | O | O | O | O |
protected | O | O | O | |
(default) | O | O | ||
private | O |
접근범위: public>protected>(default)>private
접근제어자를 사용하는 이유는 외부로부터 데이터를 보호하는 것과 외부에서는 불필요한 내부적으로만 사용되는 부분을 감추기 위해서 사용이 됩니다.
public 접근 제어자
public 접근 제어자를 사용하여 선언된 클래스 멤버는 외부로 공개되며, 해당 객체를 사용하는 프로그램 어디에서나 직접 접근할 수 있습니다. 자바 프로그램은 public 메서드를 통해서만 해당 객체의 private 멤버에 접근할 수 있습니다.
class E01{
public String var = "누구든지 허용"; // public 필드
public String getVar() { // public 메소드
return this.var;
}
}
default 접근 제어
자바에서는 클래스 및 클래스 멤버의 접근 제어의 기본값으로 default 접근 제어를 별도로 명시하고 있습니다.
이러한 default를 위한 접근 제어자는 따로 존재하지 않으며, 접근 제어자가 지정되지 않으면 자동적으로 default 접근 제어를 가지게 됩니다.
default 접근 제어를 가지는 멤버는 같은 클래스의 멤버와 같은 패키지에 속하는 멤버에서만 접근할 수 있습니다.
package src.com.bit.day09;
public class Ex01 {
String sameVar = "같은 패키지는 허용"; // default 필드
}
package src.com.bit.day09;
public class Ex01 {
String var = "다른 패키지는 접근 불가"; // default 필드
public static void main(String[] args) {
SamePackage sp = new SamePackage();
System.out.println(sp.sameVar); // 같은 패키지는 허용
}
}
private 접근 제어자
private 접근 제어자를 사용하여 선언된 클래스 멤버는 외부에 공개되지 않으며, 외부에서는 직접 접근할 수 없습니다.
즉, 자바 프로그램은 private 멤버에 직접 접근할 수 없으며, 해당 객체의 public 메소드를 통해서만 접근할 수 있습니다.
따라서 private 멤버는 public 인터페이스를 직접 구성하지 않고, 클래스 내부의 세부적인 동작을 구현하는 데 사용됩니다.
class Ex01{
private String var = "같은 클래스만 허용"; // private 필드
private String getVar() { // private 메소드
return this.var;
}
}
캡슐화
클래스나 멤버 주로 멤버에 접근제어자를 사용하는 이유는 클래스 내부에 선언된 데이터를 보호하기 위함입니다 데이터가 유효한 값을 유지하도록 또는 비밀번호와 같은 데이터를 외부에서 함부로 변경하지 못하도록 하기 위해서는 외부로부터의 접근을 제한하는 것이 필요합니다.
이것을 데이터 감추기(data hiding)이라고 하며 객체지향의 개념으로는 캡슐화에 해당이 되는 내용입니다. 또 다른 이유는 클래스 내에서만 사용되는 내부 작업을 위해 임시로 사용되는 멤버 변수나 부분 작업을 처리하기 위한 메서드 등의 멤버들을 클래스 내부에 감추기 위해서입니다
외부에서 접근할 필요가 없는 멤버들을 위에서 설명한 private으로 지정하여 외부에 노출을 시키지 않음으로써 복잡성을 줄일 수 있습니다. 이것 역시 캡슐화에 해당합니다.