스프링 핵심 원리 이해 1 - 예제 만들
·
BackEnd/스프링 핵심 원리 - 기본편
비즈니스 요구사항 설계 회원 회원을 가입하고 조회할 수 있다. 회원은 일반과 VIP 두 가지 등급이 있다. 회원 데이터는 자체 DB를 구축할 수 있고, 외부 시스템과 연동할 수 있다. (미확정) -> interface 주문과 할인 정책 회원은 상품을 주문할 수 있다 회원 등급에 따라 할인 정책을 적용할 수 있다. 할인 정책은 모든 VIP는 1000원을 할인해주는 고정 금액 할인을 적용해달라. (나중에 변경 될 수 있다.) 할인 정책은 변경 가능성이 높다. 회사의 기본 할인 정책을 아직 정하지 못했고, 오픈 직전까지 고민을 미루고 싶다. 최악의 경우 할인을 적용하지 않을 수 도 있다. (미확정) -> interface 인터페이스를 만들고 구현체를 언제든지 갈아끼울 수 있도록 설계하자!! 회원 도메인 설계(..
좋은 객체 지향 설계의 5가지 원칙(SOLID)
·
BackEnd/스프링 핵심 원리 - 기본편
SOLID SRP : 단일 책임 원칙(single responsibility principle) OCP : 개방-폐쇄 원칙 (Open/closed principle) LSP : 리스코프 치환 원칙 (Liskov substitution principle) ISP : 인터페이스 분리 원칙 (Interface segregation principle) DIP : 의존관계 역전 원칙 (Dependency inversion principle) SRP 단일 책임 원칙 한 클래스는 하나의 책임만 가져야 한다. 하나의 책임이라는 것은 모호하다. 책임이 클 수도 있고, 작을 수도 있다. 문맥과 상황에 따라 다르다. 중요한 기준은 변경이다. 변경이 있을 때 파급 효과가 적으면 단일 책임 원칙을 잘 따른 것이다. OCP 개방..
좋은 객체 지향 프로그래밍이란?
·
BackEnd/스프링 핵심 원리 - 기본편
객체 지향 프로그래밍이란? 객체 지향 프로그래밍은 컴퓨터 프로그램을 명령어의 목록으로 보는 시각에서 벗어나 여러 개의 독립된 단위, 즉 "객체"들의 모임으로 파악하고자 하는 것이다. 각각의 객체는 메시지를 주고받고, 데이터를 처리할 수 있다. (협력) 객체 지향 프로그래밍은 프로그램을 유연하고 변경이 용이하게 만들기 때문에 대규모 소프 트웨어 개발에 많이 사용된다 다형성 실세계와 객체 지향을 1:1로 매칭하지 않는다. 그래도 실세계의 비유로 이해하기에는 좋다. 역할과 구현으로 세상을 구분한다. 마치 자동차를 다른 것으로 바꿔도 운전면허를 새로 안 따도 되는 것과 비슷하다. 대상을 바꾸지 않고 새로운 자동차를 만들 수 있다. 즉 client의 영향을 주지 않고 새로운 기능을 줄 수 있다. 역할과 구현을 분..
벨만-포드 알고리즘, 타임머신(백준_11657)
·
BackEnd/알고리즘 공부
https://www.acmicpc.net/problem/11657 11657번: 타임머신 첫째 줄에 도시의 개수 N (1 ≤ N ≤ 500), 버스 노선의 개수 M (1 ≤ M ≤ 6,000)이 주어진다. 둘째 줄부터 M개의 줄에는 버스 노선의 정보 A, B, C (1 ≤ A, B ≤ N, -10,000 ≤ C ≤ 10,000)가 주어진다. www.acmicpc.net 문제 설명 1번 도시에서 출발해서 나머지 도시로 가는 가장 빠른 시간을 구하는 것이다. 그래프 간 가중치가 음수가 존재한다. 1번 도시에서 출발해 어떤 도시로 가는 과정에서 시간을 무한히 오래전으로 되돌릴 수 있다면 -1을 출력 도시 순서대로 걸린 시간을 출력 해당 도시로 가는 경로가 없다면 -1을 출력 문제에 대한 아이디어 최단거리를 ..
나머지 기능들
·
BackEnd/스프링 데이터 JPA
Specifications(명세) 스프링 데이터 JPA는 JPA Criteria를 활용해서 이 개념을 사용할 수 있도록 지원한다. 술어(predicate) 참 또는 거짓으로 평가한다. AND OR 같은 연산자로 조합해서 다양한 검색조건을 쉽게 생성한다. (컴포지트 패턴) 스프링 데이터 JPA는 org.springframework.data.jpa.domain.Specification 클래스로 정의한다. 실무에서는 JPA Criteria를 거의 사용하지 않고 QueryDsl을 사용한다고 한다! Query By Example @SpringBootTest @Transactional public class QueryByExampleTest { @Autowired MemberRepository memberRepos..
위상정렬, 줄 세우기(백준_2252)
·
BackEnd/알고리즘 공부
https://www.acmicpc.net/problem/2252 2252번: 줄 세우기 첫째 줄에 N(1 ≤ N ≤ 32,000), M(1 ≤ M ≤ 100,000)이 주어진다. M은 키를 비교한 회수이다. 다음 M개의 줄에는 키를 비교한 두 학생의 번호 A, B가 주어진다. 이는 학생 A가 학생 B의 앞에 서야 한다는 의 www.acmicpc.net 문제 설명 일부 학생의 키를 비교하여 줄을 세우는 프로그램을 작성하는 것이다. 입력을 보면 1은 3보다 앞 2도 3보다 앞이다. 그래서 1 2 3 이 되는 것이다. 문제에 대한 아이디어 각 학생들을 노드라고 생각하면 노드들의 순서를 구하는 문제이다. 그래프에서 노드들의 순서를 구할 때 사용 하는 알고리즘은 위상정렬이다. 단, 그래프는 사이클이 존재하면 안..