일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- bootstrap
- dependency
- 무한
- 루프
- maven
- Short
- 언박싱
- Jenkins
- 싱글톤
- 컬렉션
- 빌드
- 인텔리제이
- unboxing
- Java
- 클래스
- https://start.spring.io
- start.spring.io
- 콜렉션
- boxing
- 자동형변환
- suvlet
- 제네릭
- wrapper
- Scanner
- 메소드
- 내장객체
- 싱글턴
- 박싱
- 제너릭
- 스프링
- Today
- Total
목록인프런 김영한님 강의 (23)
Developer Gonie
스프링 빈(Spring Bean) Spring에 의해서 자동으로 필요한 곳에 사용되고, 관리되는 '객체'를 Spring Bean이라고 부른다. 더 정확히는 Spring IoC 컨테이너가 관리중인 객체들을 말한다. 그냥 new 클래스이름 해서 객체를 생성하면, 이 객체는 스프링에 의해 자동으로 관리되지 않는다. 특정 객체가 Spring IoC 컨테이너에 의해 자동으로 관리되도록 등록하기 위해서는 별도의 과정이 필요한데 여기에는 2가지 방법이 있다. 두 가지 방법 모두 알고 있어야 한다. 이건 맨 마지막에 알아보자. 그럼 왜 굳이 객체를 등록해서 Spring IoC 컨테이너가 관리하도록 하는 것일까? 특정 클래스의 생성자가 파라미터로 외부의 객체를 받아들이는 코드가 있고, 나는 이 최종 클래스의 객체를 생성..
스프링빈을 등록하는 2가지 방법 * 두가지 방법을 모두 알고 있어야 한다. 방법1. 컴포넌트 스캔과 자동 의존관계 설정 방법2. 자바 코드로 직접 스프링빈 등록하기 이번 게시물에서는 방법1 을 배워보고, 다음 게시물에서 방법2 를 배워본다. MemberController가 MemberService를 통해 회원가입하고, MemberService를 통해 데이터를 조회할 수 있어야 한다. 이런 관계를 서로 의존관계가 있다 라고 표현하는데 MemberController가 MemberService에 의존한다라고 말한다. 이제 이 작업을 스프링 스럽게 해볼 것이다. 1. MemberController 클래스 추가 2. MemberController 클래스에 @Controller 어노테이션 부착 여기까지 해두면 기능..
이번 게시물 흐름 요약 service 패키지 위치에서 생성한 MemberService 클래스 내의 메서드 들을 테스트 한다. 특히 join (회원가입) 메소드에서 중복 이름을 가진 회원을 등록하려는 경우 예외가 발생 하는지, 그리고 그 예외에서 발생시킨 에러 메세지가 예측한 것과 같은지를 체크함 테스트 코드 관련해서 추가적으로 알려주신 부분 * 테스트 코드 기본틀을 자동으로 생성하는 방법 클래스 내부 - 오른쪽 마우스 - Generate... - Test..., Testing library는 JUnit5 선택, 테스트 코드 작성할 메소드 선택 후 OK 이러면 내가 지정한 클래스의 폴더구조까지 같게 테스트 클래스가 생성된다. * 테스트 메소드의 이름은 과감하게 한글로 바꿔도 된다. 실제 프로덕션 코드에 대..
* 서비스 코드 작성시 메소드의 이름을 비지니스에서 가져온 용어들로 사용해야 하는 이유 service 패키지 내의 MemberService 클래스 내부의 메소드를 구현할 때, 비지니스에서 가져온 용어들로 사용하였다. 이는 이전에 repository 패키지 내의 클래스 내부의 메소드 이름을 지정한 것과 다른 점인데, 이래야 기획자들하고의 의사소통이 원활하기 때문이다. 예를들면, 기획자가 회원가입쪽이 이상해요 하면 join 메서드 쪽을 살펴봐야 하는구나 하고 바로 매칭이 되어 편리해진다. 1. java/hello.hellospring 아래에 service 패키지 생성 2. 위 패키지 내에 MemberService 클래스 생성 후 코드 작성 package hello.hellospring.service; imp..
MemoryMemberRepository 클래스 관련, 테스트 케이스 작성 * 테스트 케이스 작성이 필요한 이유 혼자 개발할 때는 괜찮은데 여러명에서 개발할 때, 혹은 코드가 몇만 라인을 넘어가면 테스트 코드 없이 개발하는게 거의 불가능하다고 한다. 물론 할 수 있지만 정말 문제가 많다는 말씀이다. 실무에서는 테스트를 빌드툴하고 묶어서 테스트 케이스를 통과하지 못하면 다음 단계로 못 넘어가게 막아버린다고 한다. 중요하니 꼭 '테스트' 관련해서 깊이있는 공부를 권장하심. 아래서 한 방식은 구현 클래스를 작성하고 나서 테스트 케이스를 작성한 것인데, 테스트 주도개발 방식이라고 불리는 TDD는 테스트 케이스를 먼저 작성하고 이거에 문제 없이 작동하도록 구현 클래스를 작성하는 것이다. 이런게 있다는 것 정도는 ..
스트림(Java 8부터 추가됨) * 스트림이란? Stream 반복자는 Iterator 반복자와 비슷하게 컬렉션(배열포함)의 저장 요소를 하나씩 참조하는 비슷한 역할을 하지만 다음과 같은 다른점을 가지고 있다.(여기서 말하는 컬렉션은 List, Set 인터페이스의 부모 인터페이스 Collection의 모든 자식들을 의미하는 것 같다. 애초에 Iterator를 사용할 수 있는 것들도 Collection 인터페이스의 자식들이었음) 스트림은 1) 하나씩 참조한 요소를 람다식으로 처리할 수 있도록 한다. 2) 내부 반복자를 사용하므로 병렬 처리가 쉽다. 3) 중간 처리와 최종 처리 작업을 수행할 수 있다. 각각의 다른점에 대한 얘기는 아래서 살펴보자. Java 8부터 Iterator 반복자를 대신해 사용할 수 있..
람다식(Java 8부터 추가됨) * 람다식이란? 람다식은 매개변수를 가진 코드블록으로 런타임 시에 이를 실행할 수 있도록 익명 구현 객체를 생성한다. 익명 함수를 생성하기 위한 식으로 '객체 지향 언어' 보다 '함수 지향 언어'에 가깝다. Lisp, Scheme와 같은 함수적 프로그래밍 언어들은 과거에 학계 외에 현업에서 큰 호응을 얻지 못하였는데, 최근에 들어와서 병렬처리와 이벤트 지향 프로그래밍에 적합해 다시 부각되고 있다. 함수적 프로그래밍과 객체 지향 프로그래밍은 다른데 이 둘을 혼합하여 사용하도록 프로그래밍 언어가 바뀌고 있는 것이다. * Java에서 람다식을 수용한 이유 자바 코드가 매우 간결해지고, 컬렉션의 요소를 필터링하거나 매핑해서 원하는 결과를 쉽게 집계할 수 있기 때문이다. (여기서 ..
이번 게시물 흐름 요약 아래의 과정은 회원의 정보를 담을 Member 클래스(도메인)를 만들고 회원의 정보를 담을 공간 및 회원등록, 검색, 등등의 메소드 들을 가지는 클래스가 필요한데 아직 어떤 DB를 사용할지 정하지 않은 상태여서 구현해야할 메소드를 MemberRepository 인터페이스에 정의해두고 MemoryMemberRepository 클래스로 위 인터페이스의 추상메소드들을 완성하며 회원의 정보를 담을 공간을 위해 HashMap을 갖도록 함. 더 요약하자면 1. Member 클래스 작성 2. MemberRepository 인터페이스 작성 3. MemoryMemberRepository 클래스로 위 인터페이스 구현 1. hello.hellospring 패키지 안에서 domain 패키지 생성 2. ..
* 아래의 과정을 서버에서 빌드 빛 실행까지 한다면 이게 바로 웹어플리케이션이 되는 것이다. 1. 빌드하여 빌드폴더 생성하기 프로젝트 폴더 위치에 보면 gradlew 라는 파일이 보이는데 cmd에서 해당 파일이 위치한 폴더까지 이동 후 아래의 명령어를 실행하면 build 폴더가 생겨난다. 2. 실행하기 생성된 build 폴더 아래 위치한 libs 폴더 안으로 이동하여 이 위치에 존재하는 jar 파일 실행 3. 접속해보기 IDE에서 실행한 것과 결과는 동일하다. 빌드폴더 삭제하는 방법 만들어진 빌드폴더는 삭제도 할 수 있는데 다음과 같이 하면 삭제된다.
* 옛날에는 View 인 html에서 모든걸 다 처리해주어 가독성도 떨어지고 유지보수가 힘들었던 반면 요즘에는 MVC 패턴으로 역할을 나누어 처리함. MVC각각이 의미하는 바 1. Controller 컨트롤러는 비지니스 로직과 관련되어있거나 내부적인걸 처리하는데 집중해야한다. 2. View 화면을 그리는데 모든 역량을 집중해야 하는 곳 3. Model 컨트롤러에 있는 메소드가 View 쪽으로 데이터를 넘겨주고자 할 때 Hashmap 방식같은 걸로 Key, Value의 Pair 들을 담고있는 객체
* 기존의 방식과, API 차이점 이전까지는 클라이언트로 부터 url 요청을 받아 다시 html 을 반환해주는 것을 실습하였다. 여기서 만들어 볼 것은 API인데 API는 html을 반환해주는게 아니라 데이터를 반환해준다. @GetMapping 에 의해 url을 받아 컨트롤러까지 찾아가는 것은 이전에 본것들과 같지만 메서드에 @ResponseBody 가 하나 더 붙어서 ViewResolver가 아니라 HttpMessageConverter가 돌아간다. 마지막에 결과를 반환해줄 때 Body부에 리턴하는 데이터를 직접 넣어주는 것이다. (여기서 말하는 Body는 html의 body 태그가 아니라 HTTP에서 말하는 Body 부분이다.) @ResponseBody 사용원리 문자를 return 하는 경우 Strin..