자바 60

[Java] 코딩테스트 BufferedReader, BufferedWriter 을 쓰는 이유

코딩 테스트를 보다가 어떠한 문제의 답에서 Scanner 와 System.out.print 함수를 사용하지 않고 BufferedReader 와 BufferedWriter 을 사용하는 것을 발견했습니다. 그런데 왜 이 두 클래스를 사용해야 하는 것일까요? 그래서 InputStream 부터, InputStreamReader, BufferedReader 을 알아보려고 합니다. 물론 OutputStream, OutputSreamReader, BufferedWriter 도 알아보구요. 그리고 코딩테스트에서 BufferdReader 와 BufferedWriter 을 사용해야 하는 이유도 알아봅시다. InputStream / OutputStream 바이트 단위 입출력을 위한 최상위 입출력 스트림 클래스 InputSt..

스택 & 큐 - 자바 백준 스택수열: 1874 오큰수: 17298

Stack 스택은 삽입과 삭제가 LIFO(Last-in First-out = 후입선출) 로 이루어지는 자료구조입니다. LIFO 는 삽입과 삭제가 한쪽에서 만 일어나는 특징이 있습니다. top: 삽입과 삭제가 일어나는 위치 push: top 위치에 새로운 데이터를 삽입하는 연산 pop: top 위치에 현재 있는 데이터를 삭제하고 확인하는 연산 peek: top 위치에 현재 있는 데이터를 단순 확인하는 연산. Stack 은 DFS(Depth First Search = 깊이 우선 탐색), 백트래킹 종류의 코딩 테스트에 효과적이므로 반드시 알아두어야 합니다. LIFO 는 개념 자체가 재귀함수 알고리즘 원리와 일맥상통하기 때문입니다. Queue 큐는 삽입과 삭제 연산이 FIFO(First-in First-out ..

10. 스프링 트랜잭션 전파 - 활용(2)

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. 전파 커밋 전파 롤백 복구 REQUIRED 복구 REQUIRES_NEW 3. 전파 커밋 스프링은 @Transactional이 적용되어 있으면 기본으로 REQUIRED라는 전파 옵션을 사용합니다. 이 옵션은 이전 글에서도 설명했듯 기존 트랜잭션이 없으면 트랜잭션을 생성하고, 기존 트랜잭션이 있으면 기존 트랜잭션에 참여합니다. 참여한다는 뜻은 해당 트랜잭션을 그대로 따른다는 뜻이고, 동시에 같은 동기화 커넥션을 사용한다는 의미입니다. 이렇게 둘 이상의 트랜잭션이 하나의 물리 트랜잭션에 묶이게 되면 둘을 구분하기 ..

10. 스프링 트랜잭션 전파 - 활용(1)

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. 프로젝트 설정 커밋, 롤백 단일 트랜잭션 0. 프로젝트 설정 비즈니스 요구사항 회원을 등록하고 조회하는 기능을 가집니다. 회원에 대한 변경 이력을 추적할 수 있도록 회원 데이터가 변경될 때 변경 이력을 DB LOG 테이블에 남겨야 합니다. 예제를 단순화 하기 위해 회원 등록시에만 DB LOG 테이블에 남기도록 하겠습니다. Member @Entity @Getter @Setter public class Member { @Id @GeneratedValue private Long id; private String u..

9. 스프링 트랜잭션 전파 - 기본

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. 커밋, 롤백 트랜잭션 전파란? 트랜잭션 전파 동작 순서 롤백 트랜잭션 전파 동작 순서 내부 롤백에도 외부에 영향주지 않는 방법 스프링 트랜잭션 전파 옵션 종류 스프링에서 트랜잭션은 부모와 자식 사이에 전파가 됩니다. 트랜잭션 전파에서도 여러 전파 수준이 있습니다. 먼저 트랜잭션의 커밋과 롤백을 되짚어보면서 트랜잭션 전파을 알아봅시다. 커밋, 롤백 트랜잭션 시작시 Hikari 에서 커넥션(Connection)을 가져오고 커밋을 하면 Hikari 에 커넥션을 반납합니다. 또한 롤백도 마찬가지로 반영된 내용을 모두..

8. 스프링 트랜잭션 이해(3)

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. 트랜잭션 옵션 소개 예외와 트랜잭션 커밋, 롤백 - 기본 예외와 트랜잭션 커밋, 롤백 - 활용 6. 트랜잭션 옵션 소개 @Transactional public @interface Transactional { String value() default ""; String transactionManager() default ""; Class

8. 스프링 트랜잭션 이해(2) 주의사항, 프록시, 초기화 시점

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. 트랜잭션 AOP 주의 사항 - 프록시 내부 호출 트랜잭션 AOP 주의 사항 - 초기화 시점 4. 트랜잭션 AOP 주의 사항 - 프록시 내부 호출 프록시 내부 호출 @Transactional을 사용하면 스프링의 트랜잭션 AOP가 적용됩니다. 트랜잭션 AOP는 기본적으로 프록시 방식의 AOP를 사용합니다. @Transactional을 적용하면 프록시 객체가 요청을 먼저 받아서 트랜잭션을 처리하고 실제 객체를 호출합니다. 따라서 트랜잭션을 적용하려면 항상 프록시를 통해서 대상 객체(Target)을 호출해야 합니다...

8. 스프링 트랜잭션 이해(1) - 소개, 적용

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. 스프링 트랜잭션 소개 트랜잭션 적용 확인 트랜잭션 적용 위치 앞서 “스프링 문제 해결 - 트랜잭션” 을 통해서 스프링이 제공하는 트랜잭션 기능이 왜 필요하고 어떻게 동작하는지 내부 원리를 알아보았습니다. https://sh1mj1-log.tistory.com/94 https://sh1mj1-log.tistory.com/95 이번에는 스프링 트랜잭션을 더 깊이있게 학습하고, 또 스프링 트랜잭션이 제공하는 다양한 기능들을 자세히 알아봅시다. 먼저 본격적인 기능 설명 이전에 이전에 학습한 내용을 복습해봅시다. 1...

7. 데이터 접근 기술 - 활용 방안 (JPA, JdbcTemplate, MyBatis 조합)

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. 스프링 데이터 JPA 예제와 트레이드 오프 실용적인 구조 다양한 데이터 접근 기술 조합 이전 글 https://sh1mj1-log.tistory.com/107 의 코드, 구성을 바탕으로 설명합니다. 1. 스프링 데이터 JPA 예제와 트레이드 오프 클래스 의존 관계 런타임 객체 의존 관계 중간에서 JpaItemRepositoryV2가 어댑터 역할을 해준 덕분에 MemberService가 사용하는 MemberRepository 인터페이스를 그대로 유지할 수 있고 클라이언트인 MemberService 의 코드를 변..

6. 데이터 접근 기술 - Querydsl

이 글은 배민 기술이사 김영한 이사님의 인프런 강의 "스프링 DB 2편 - 데이터 접근 활용 기술" 을 기반으로 작성되었습니다. 문제 시 삭제 조치하겠습니다. 아래와 같은 순서로 공부를 진행합니다. Querydsl 소개1 - 기존 방식의 문제점 Querydsl 소개2 - 해결 Querydsl 설정 Querydsl 적용 1. Querydsl 소개 1 - 기존 방식의 문제점 기존 방식의 문제점 Querydsl 을 사용하기 전 JPA 을 사용했을 때의 문제점부터 정리해 봅시다. QUERY의 문제점 QUERY는 문자이므로 Type-check 가 불가능합니다. 또 실행하기 전까지 작동여부를 확인할 수 없습니다. JPA에서 QUERY 방법은 크게 3가지가 있었습니다. 1. JPQL(HQL) 장점 SQL QUERY와..