
오늘은 2장에 이어 스칼라 두번째 걸음을 학습해 보도록 하겠습니다. 이번장에서는 배열과 튜플같은 자료형을 익히고 함수형 스타일을 알아보는 시간이 될 것 같습니다. 2,3 장을 한번 훑어보고 뒤에서 더욱 자세히 배워 나간다면 스칼라에 대해 이해하기 수월할 것입니다. 7단계 : 배열에 타입 파라미터를 지정해보자. val big = new java.math.BigInteger("12345") new를 사용하여 객체를 인스턴스화 합니다. 객체를 인스턴스화 할 때, 값과 타입을 파라미터로 넘길 수 있습니다.(이를 파라미터화, Parameterization라고 합니다.) val 배열은 변경이 불가능하지만 원소는 변경이 가능합니다. 아래의 예시처럼 Array안의 원소는 변경이 가능합니다. val greetString..

오늘은 2장 스칼라 첫걸음을 학습해 보도록 하겠습니다. 이번장과 다음장 3장까지 스칼라의 전반적인 내용을 살펴 봅니다. 간단하게 알고 넘어가지 좋은 부분이니 가벼운 마음으로 학습해 보겠습니다. 1단계: 스칼라 인터프리터 사용법을 익히자 ※ 스칼라 인터프리터란? 스칼라 표현식과 프로그램을 쓸 수 있는 대화형 셸(Shell)로, 스칼라의 대화형 셸은 scala라고 부릅니다. scala> 1 + 2 res0: Int = 3 계산 결과 값의 이름은 res0으로 0번째 결과라는 뜻 결과의 타입 → Int 입력 표현식을 계산해서 얻은 결과값 → 3 Int 타입은 scala 패키지의 Int 클래스를 의미합니다. 'res번호' 식별자(identifier)는 나중에 재사용할 수 있습니다. 아래 예시에서 확인할 수 있습니..
오늘은 JVM의 대한 개념이 부족한 것 같아 이 부분에 대해 학습해 보려고 한다. JVM이란 무엇은 하는 것인지, 필요한 부분들을 하나씩 알아보자. 1. JVM(Java Virtual Machine) 이란? 자바 가상 머신은 자바 바이트코드(.class)를 실행할 수 있는 주체이다. 자바와 운영체제 사이에서 중개자 역할을 수행하며, 자바가 운영체제에 구애 받지 않고 프로그램을 실행할 수 있도록 도와준다. 자바가 컴파일 되어 바이트코드, 즉 class 파일을 만들면 이 코드가 자바 가상 머신 환경에서 실행된다. 정리해 보면 바이트코드(.class)가 어느 운영체제에서든 돌아갈 수 있도록 해 주는 것이 JVM의 역할이라는 뜻이다. 참고로 JVM은 JRE(Java Runtime Environment)에 포함되..

드디어 Spring 시작해보기의 마지막 ! 오늘은 AOP에 대해 알아보려고 한다. AOP는 나도 어려운 개념이었고, 실제로 개념만 듣고 보면 이해하기 어려운거 같다. 그러니 최대한 이해하기 쉽게 풀어 나가 보자 ! 먼저 AOP가 필요한 상황에 대해 먼저 알아보자. 모든 메서드의 호출 시간을 측정하고 싶을 때, 공통 관심 사항(cross-cutting concern) vs 핵심 관리 사항(core concern)이 겹친다면? 실제로 모든 메서드의 호출 시간을 측정하고 싶을 때는 아래와 같이 메서드 마다 일일이 호출 시간을 출력해 줘야 한다. 이렇게 되면 메서드가 너무 많을 때 처리하기 힘들 것이다. 위에서 시간을 측정하는 로직은 핵심 기능이 아니라 공통적으로 있는 관심 사항이다. 그리고 핵심기능과 공통기능..

스프링 부트와 JPA만 사용해도 개발 생산성이 정말 많이 증가하고, 개발해야할 코드도 확연히 줄어든다. 여기에 Spring Data JPA를 사용하면, 기존의 한계를 넘어 리포지토리에 구현 클래스 없이 인터페이스 만으로 개발을 완료할 수 있다. 그리고 반복 개발해 온 기본 CRUD 기능도 스프링 데이터 JPA가 모두 제공한다. 스프링 부트와 JPA라는 기반 위에, 스프링 데이터 JPA라는 프레임워크를 더하면, 지금까지 조금이라도 단순하고 반복이라고 생각했던 개발 코드들이 확연하게 줄어든다. 따라서 개발자는 핵심 비즈니스 로직을 개발하는데 집중할 수 있다. 실무에서 관계형 데이터베이스를 사용한다면 스프링 데이터 JPA는 이제 선택이 아닌 필수라고해도 과언이 아니다 ! 이제 구현을 진행해 보자. 기본 초기 ..

어제 MariaDB와 연결 하였으니 오늘은 JPA에 대해 알아보려고 한다. 회사에서 JPA 말고 MyBatis를 사용하긴 했지만 JPA는 중요하고 좋은 기술이니까 잘 알아보도록 하자! 앞서 JDBC Template이 JDBC 보다 편리하긴 했지만 여전히 SQL문을 직접 입력해 주어야 한다는 불편사항이 있다. 그런데 JPA를 사용하면 SQL 쿼리도 자동으로 처리를 해준다. JPA를 사용하면 SQL과 데이터 중심의 설계에서 객체 중심의 설계로 패러다임을 전환할 수 있다고 한다. 그래서 개발의 생산성을 높일 수 있다! 우선 build.gradle에서 JPA관련 의존성을 추가해 주자. implementation 'org.springframework.boot:spring-boot-starter-data-jpa' ..

오늘은 DB와 직접 연동하는 것을 해보려고 한다. 나는 open source인 MariaDB를 사용할 예정이다. db tool로는 DBeaver를 사용한 것이다. db 설치와 tool 사용법 등은 여기에 적진 않겠다. 우선 member 테이블을 하나 생성해 보도록 하자. 사용하는 db 문법에 맞게 sql문을 작성해 주면 된다. 그러면 아래와 같이 테이블이 생성된 것을 확인할 수 있을 것이다. create table member ( id bigint AUTO_INCREMENT, name VARCHAR(255), PRIMARY KEY (id) ); 위 SQL문에서 AUTO_INCREMENT는 값을 세팅하지 않고 insert 하면 자동으로 값이 증가하는 일련번호가 매겨 진다. 이제 데이터를 조금 넣어 보자. ..

오늘은 화면과 함께 Controller를 통해서 회원을 등록하고 조회하는 예제를 만들어 보자. 우선 홈 화면을 추가한다. 이때 HomeController도 생성해 준다. 소스는 아래와 같이 구성하고 8080 도메인만 입력했을 때 진입하는 화면이 될 것이다. package com.demoproject.demo.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; @Controller public class HomeController { @GetMapping("/") public String home() { return "home"; } } ret..