Skip to content

스프링 핵심편 Section2

SH-Seol edited this page May 6, 2024 · 1 revision

비즈니스 요구사항과 설계

  • 회원
    • 회원을 가입하고 조회할 수 있다.
    • 회원은 일반과 VIP 두 가지 등급이 있다.
    • 회원 데이터는 자체 DB를 구축할 수 있고, 외부 시스템과 연동할 수 있다. (미확정)
  • 주문과 할인 정책
    • 회원은 상품을 주문할 수 있다.
    • 회원 등급에 따라 할인 정책을 적용할 수 있다.
    • 할인 정책은 모든 VIP는 1000원을 할인해주는 고정 금액 할인을 적용해달라. (나중에 변경 될 수 있다.)
    • 할인 정책은 변경 가능성이 높다. 회사의 기본 할인 정책을 아직 정하지 못했고, 오픈 직전까지 고민을 미루고 싶다. 최악의 경우 할인을 적용하지 않을 수 도 있다. (미확정)

회원 도메인 설계

  • 회원 도메인 요구사항
    • 회원을 가입하고 조회할 수 있다.
    • 회원은 일반과 VIP 두 가지 등급이 있다.
    • 회원 데이터는 자체 DB를 구축할 수 있고, 외부 시스템과 연동할 수 있다. (미확정)

Untitled

Class Diagram

Untitled

회원 저장소를 인터페이스로 구현

메모리 회원 저장소 → 메모리에만 있으니 휘발성. 전원을 껐다 키면 다 날라감

회원 객체 다이어그램

Untitled

클래스 다이어그램만으로 판단하기 어려운 것이 있어 객체 다이어그램이 존재

클래스 다이어그램 정적, 객체 다이어그램 동적으로 연관관계가 맺어지는 것

주문서비스 구현체에서 메모리가 아닌 DB, 정액이 아닌 정률 할인 정책으로 바뀌어도 클라이언트는 몰라도 됨

✉️ Override와 Overload의 차이

Overloading: 메소드가 같은 이름을 갖고 있지만, signature(parameter의 수자료형)가 다른 것을 ****중복으로 선언

****Overriding: 상위 class의 메소드의 **동작 방법을 변경(재정의)**하여 우선적으로 사용하는 것

실무에서 돈과 관련된 것들은 경계값 테스트 등을 포함하여 여러 테스트를 거침