Item 16. public 클래스에서는 public 필드가 아닌 접근자 메서드를 사용하라
1. 들어가기
public 클래스에서 public 필드를 사용하면 어떻게 될까요?
public class Point {
public double x;
public double y;
}
Point 클래스는 public으로 선언된 공용 API인데 필드의 접근 범위 또한 public으로 선언하게 된다면
클라이언트에서 직접 필드를 수정할 수 있습니다.
그렇게 된다면 캡슐화의 이점을 제공하지 못하게 되고, 객체의 오용을 방지할 수 없게 됩니다.
그럼 어떻게 수정하면 좋을까요?
2. 해결 방법
이런 경우에는 필드를 모두 private으로 바꾸고 public 접근자를 추가하는 방법을 사용할 수 있습니다.
public class Point {
private double x;
private double y;
public double getX() { return x; }
public double getY() { return y; }
public void setX() { this.x = x; }
public void setY() { this.y = y; }
}
만약, public 클래스가 필드를 public으로 공개하게 된다면
이를 사용하는 클라이언트가 있을 수 있고 내부 표현방식을 마음대로 바꿀 수 없기 때문에
필드는 private으로 감추고 public 접근자를 통해서만 데이터를 주고 받을 수 있게 합니다.
하지만, package-private이나 private 중첩 클래스라면 데이터 필드를 public으로 노출한다해도
패키지 바깥에서 사용할 수 없기 때문에 public 접근자를 사용할 필요가 없습니다.
3. public 필드를 노출한 사례
자바 플랫폼 라이브러리에도 필드를 public으로 노출시킨 사례가 있습니다.
이 클래스들을 흉내 내지 말고, 타산지석으로 삼읍시다.
- Point 클래스
public class Point extends Point2D implements java.io.Serializable {
public int x;
public int y;
}
- Dimension 클래스
public class Dimension extends Dimension2D implements java.io.Serializable {
public int width;
public int height;
}
4. public 클래스 내부의 불변 필드
public 클래스 내부에 불변 필드는 괜찮을까요?
불변 필드라면 클라이언트가 직접 변경할 수도 없기 때문에 언뜻 보기에는 괜찮을 수 있습니다.
하지만 API를 변경하지 않고는 표현 방식을 바꿀 수 없고, 필드를 읽을 때 부수 작업을 수행할 수 없기 때문에
사용하지 않는 것이 좋습니다.
5. 정리
이번 포스트는 public 클래스에서 public 필드를 사용할 경우 수반되는 문제점에 대해 알아보았습니다.
공용 API가 아닌 경우에는 package-private이나 private 중첩으로 접근 범위를 줄이거나
공용 API인 경우에는 private 필드를 만들고 public 접근자를 통해 데이터를 주고 받는 방법을 선택합시다.
📕 개인 기록용 블로그입니다.
😊 오타나 잘못된 정보가 있을 경우 댓글이나 메일로 말씀해주시면 바로 수정하겠습니다! 😊
댓글남기기