베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • 알고리즘
    • 스프링시큐리티
    • 운영체제
    • 함수형인터페이스
    • 자바8
    • 스레드
    • 스프링
    • 자바
    • BFS
    • 데이터베이스
    • java
    • 이펙티브자바
    • leetcode
    • dfs
    • 코드업
    • Spring
    • jpa
    • C++
    • 토비스프링
    • 백준

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    개발서적/Effective Java

    [Effective Java] public 클래스에서는 public 필드가 아닌 접근자 메서드를 사용하라

    2023. 5. 25. 01:22

    퇴보한 클래스

    class Point {
        public double x;
        public double y;
    }

    다음과 같은 클래스는 필드에 직접 접근할 수 있으니 캡슐화의 이점을 제공하지 못한다. 이 클래스는 API를 수정하지 않고는 내부 표현을 바꿀 수 없고, 불변식을 보장할 수 없으며, 유효성 검사와 같은 부가 작업이 어려워진다.

    private필드와 접근자(getter)를 추가한다.

    객체 지향 프로그래밍에서는 필드를 모두 private으로 바꾸고 public 접근자를 추가하는 것이 좋다.

    class Point {
        private double x;
        private double y;
    
        public Point(double x, double y) {
            this.x = x;
            this.y = y;
        }
    
        public double getX() {
            // 부가 작업 
            return x;
        }
        public double getY() {}
    }
    저작자표시 비영리 변경금지 (새창열림)
      '개발서적/Effective Java' 카테고리의 다른 글
      • [Effective Java] 상속보다는 컴포지션을 사용하라
      • [Effective Java] 변경 가능성을 최소화하라
      • [Effective Java] 클래스와 멤버의 접근 권한을 최소화하라
      • [Effective Java] Comparable을 구현할지 고려하라
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바