아래의 내용은 토비님과 토비의 스프링 읽기를 하면서 얘기가 나온 부분을 개인적으로 공부한 후에 정리한 것입니다. 1. JUnit의 진화 과정과 public 접근 제어자 Java 진영에서 사용되는 테스트 프레임워크로는 JUnit이 있다. 오늘날 우리에게 익숙한 JUnit4와 5는 각각 2006년과 2016년에 출시되었다. 그리고 그 이전 버전들도 있는데, 이번에는 JUnit3부터 살펴보고자 한다. Junit3: 2007년 마지막 Release Junit4: 2006년 첫 Release Junit5: 2016년 첫 Release [ Junit3의 규칙과 관례 ] JUnit3를 사용해 테스트를 실행하기 위해서는 몇 가지 규칙 및 관례가 있는데, 크게 다음과 같다. 테스트 클래스는 TestCase 클래스를 상속..
이번에는 Integer.valueOf(127) == Integer.valueOf(127)가 True인 이유에 대해서 알아보도록 하겠습니다. 이 글은 Dzone의 글을 번역 및 정리한 내용입니다. 1. 문제 상황 소개 [ 문제 상황 소개 ] 다음과 같은 테스트 코드가 있다고 할 때, 출력 결과를 예상해보도록 하자. @Test void compareInteger() { Integer num1 = 128; System.out.println(num1 == Integer.valueOf(128)); Integer num2 = 127; System.out.println(num2 == Integer.valueOf(127)); System.out.println(Integer.valueOf(127) == Integer.v..
이번에는 자바8에 추가된 CompletableFuture에 대해 알아보도록 하겠습니다. 1. CompletableFuture에 대한 이해[ Future의 단점 및 한계 ]Java5에 Future가 추가되면서 비동기 작업에 대한 결과값을 반환 받을 수 있게 되었다. 하지만 Future는 다음과 같은 한계점이 있었다.외부에서 완료시킬 수 없고, get의 타임아웃 설정으로만 완료 가능블로킹 코드(get)를 통해서만 이후의 결과를 처리할 수 있음여러 Future를 조합할 수 없음 ex) 회원 정보를 가져오고, 알림을 발송하는 등여러 작업을 조합하거나 예외 처리할 수 없음 Future는 외부에서 작업을 완료시킬 수 없고, 작업 완료는 오직 get 호출 시에 타임아웃으로만 가능하다. 또한 비동기 작업의 응답에..
이번에는 자바5 부터 멀티 쓰레드 기반의 동시성 프로그래밍을 위해 추가된 Executor, ExecutorService, ScheduledExecutorService와 Callable, Future를 살펴보도록 하겠습니다. 1. Callable과 Future 인터페이스에 대한 이해 및 사용법[ Thread와 Runnable의 단점 및 한계 ]Thread와 Runnable을 직접 사용하는 방식은 다음과 같은 한계점이 있다. 지나치게 저수준의 API(쓰레드의 생성)에 의존함값의 반환이 불가능매번 쓰레드 생성과 종료하는 오버헤드가 발생쓰레드들의 관리가 어려움 먼저 쓰레드를 어떻게 만드는지는 애플리케이션 개발자의 관심과는 거리가 먼데, Thread와 Runnable를 통한 쓰레드의 생성과 실행은 너무 저수..
이번에는 자바 초기부터 멀티 쓰레드 기반의 동시성 프로그래밍을 위해 만들어졌던 Thread와 Runnable를 살펴보도록 하겠습니다. 1. Thread와 Runnable에 대한 이해 및 사용법 [ 쓰레드와 자바의 멀티 쓰레드 ] 쓰레드란 프로그램 실행의 가장 작은 단위이다. 일반적으로 자바 애플리케이션을 만들어 실행하면 1개의 메인(main) 쓰레드에 의해 프로그램이 실행된다. 하지만 1개의 쓰레드 만으로는 동시에 여러 작업을 할 수 없다. 동시에 여러 작업을 처리하고 싶다면, 별도의 쓰레드를 만들어 실행시켜줘야 하는데, 자바는 멀티 쓰레드 기반으로 동시성 프로그래밍을 지원하기 위한 방법들을 계속해서 발전시켜 왔다. 그 중에서 Thread와 Runnable은 자바 초기부터 멀티 쓰레드를 위해 제공되었던 ..