로버트 C. 마틴의 클린코드 정리 _ 6장 (객체와 자료구조)

2023. 7. 11. 23:32·기술 학습/클린 코드

변수를 비공개로 정의하는 이유는?

  • 남들이 변수에 의존하지 않게 만들고 싶어서이다.
  • 충동, 변덕 등으로 변수 타입이나 구현을 마음대로 바꾸고 싶어서이다.

그렇다면 왜 많은 프로그래머는 조회/수정 함수를 당연하게 public 공개 함수를 통해 비공개 변수를 외부에 노출할까?

자료 추상화

첫번째 예제

  • 2차원 점을 표현하는 두 클래스를 비교해보자. 하나는 구현을 외부에 노출하고, 하나는 구현을 완전히 숨긴다.
class Point {
    var x: Double = 0.0
    var y: Double = 0.0
}

---

interface Point {
    fun getX(): Double
    fun getY(): Double
    fun setCartesian(x: Double, y: Double)
    fun getR(): Double
    fun getTheta(): Double
    fun setPolar(r: Double, theta: Double)
}

첫번째 클래스

  • 직교좌표계임 자료구조 임을 확실하게 알 수 있다.
  •  개별적으로 좌표값을 읽고 설정하도록 강제한다.
  • 변수를 private으로 감춘들 get/set 메서드를 제공한다면 구현을 외부에 노출하게 된다.

두번째 인터페이스

  • 해당 점이 직교좌표계를 사용하는지 극좌표계를 사용하는지 알 수 없으며, 둘 다 아닐 수도 있다.
  • 좌표값을 읽을 때는 개별적으로, 설정할 때는 두 값을 한꺼번에 하도록 강제한다.

변수사이에 함수 계층을 넣는다고 구현이 감춰지는게 아니다. 구현을 감추기 위해서는 추상화가 필요하다!

추상화 인터페이스를 제공하여 사용자가 구현을 모른 채 자료의 핵심을 조작할 수 있어야 진정한 의미의 클래스이다.

 

두번째 예제

interface Vehicle {
    fun getFuelTankCapacityInGallons()
    fun getGallonsOfGasoline()
}

---

interface Vehicle {
    fun getPercentFuelRemaining()
}

첫번째 Vehicle의 경우

  • 자동차 연료 상태를 구체적인 숫자 값으로 알려준다.
  • 두 함수가 변수값을 읽어 반환할 뿐이라는 사실이 거의 확실히 유추된다.

두번째 Vehicle의 경우

  • 자동차 연료 상태를 백분율이라는 추상적인 개념으로 알려준다.
  • 정보가 어디서 오는지 전혀 드러나지 않는다.

자료를 세세하기 공개하기보다 추상적인 개념으로 표현하는 편이 좋다. 인터페이스나 조회/함수를 사용한다고 추상화가 이뤄지지 않는다!

개발자는 객체가 포함하는 자료를 표현할 가장 좋은 방법을 심각하게 고민해야 한다. 아무 생각 없이 get/set 함수를 추가하는 방법이 가장 나쁘다.

자료/객체 비대칭

 

반응형
저작자표시 비영리 변경금지 (새창열림)

'기술 학습 > 클린 코드' 카테고리의 다른 글

로버트 C. 마틴의 클린코드 정리 _ 5장 (형식 맞추기)  (0) 2023.07.11
로버트 C. 마틴의 클린코드 정리 _ 4장 (주석)  (0) 2023.07.04
로버트 C. 마틴의 클린코드 정리 _ 1~3장 (깨끗한 코드, 의미 있는 이름, 함수)  (0) 2023.06.27
'기술 학습/클린 코드' 카테고리의 다른 글
  • 로버트 C. 마틴의 클린코드 정리 _ 5장 (형식 맞추기)
  • 로버트 C. 마틴의 클린코드 정리 _ 4장 (주석)
  • 로버트 C. 마틴의 클린코드 정리 _ 1~3장 (깨끗한 코드, 의미 있는 이름, 함수)
구름뭉치
구름뭉치
구름의 개발일기장
  • 구름뭉치
    구름 개발일기장
    구름뭉치
  • 전체
    오늘
    어제
    • ALL (283)
      • 프로젝트 (23)
        • 토스페이먼츠 PG 연동 시리즈 (12)
        • JWT 방식 인증&인가 시리즈 (6)
        • 스우미 웹 애플리케이션 프로젝트 (1)
        • 스프링부트 기본 보일러 플레이트 구축 시리즈 (2)
        • 마이크로서비스 아키텍쳐 시리즈 (1)
      • 스프링 (43)
        • 스프링부트 API 설계 정리 (8)
        • 스프링부트 RestAPI 프로젝트 (18)
        • 스프링부트 WebSocket 적용기 (3)
        • 스프링 JPA 정리 시리즈 (5)
        • 스프링 MVC (5)
        • 스프링 배치 (2)
        • 토비의 스프링 정리 (2)
      • 기술 학습 (28)
        • 아파치 카프카 (9)
        • 클린 코드 (4)
        • 디자인 패턴의 아름다움 (2)
        • 모던 자바 인 액션 (7)
        • JVM 스레드 딥다이브 (6)
      • Web (25)
        • 정리글 (20)
        • GraphQL 정리글 (2)
        • Jenkins 정리글 (3)
      • 취업 (6)
      • CS (77)
        • 네트워크 전공 수업 정리 (11)
        • OSI 7계층 정리 (12)
        • 운영체제 정리 (19)
        • 데이터베이스 정리 (5)
        • MySql 정리 (17)
        • GoF의 Design Pattern 정리 (12)
      • 알고리즘 (70)
        • 백준 (56)
        • 프로그래머스 (12)
        • 알고리즘 정리본 (1)
      • 기초 지식 정리 (2)
      • 일상 (8)
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    류블라냐
    동유럽
    마우스
    부다페스트
    크로아티아
    키보드 손목 받침대
    mx master s3 for mac
    레이저
    마우스 패드
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
구름뭉치
로버트 C. 마틴의 클린코드 정리 _ 6장 (객체와 자료구조)
상단으로

티스토리툴바