![[Java] Arrays 클래스 메서드 (자바의 정석)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FOa0vg%2FbtspFmKckqK%2FPdMJ17fincKegey4H15xM0%2Fimg.png)
목차 개인적으로 코딩 테스트, 알고리즘 문제 풀이시 아래의 static method 필수로 알고 있는 것이 좋다고 생각한다 - Arrays.sort() - Arrays.fill() - Arrays.asList() - Arrays.stream() - Arrays.toString() - Arrays.copyOf() - Arrays.copyOfRange() 배열의 동일성 확인 (1) Arrays.equals(A, B) - 두 배열의 equlity(동일성) 확인 - primitive type의 경우 값이 동일, reference type의 경우 참조 주소값이 동일한지 확인 @DisplayName("") @Test void equalsTest() { // given int[] arr1 = {1, 2, 3}; in..
![[Java] String 클래스 메서드 (자바의 정석)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FnHbYu%2FbtspmKfBowO%2F7lG5ji1a3xFm8lXPUW2760%2Fimg.png)
String 클래스 특징 1) char[]와 메서드(기능)을 결합한 것이다 String 클래스 = char[] + 메서드(기능) - char[] : 문자열 배열 - String 클래스 생성시 heap에 실제 값(문자열)이 저장되고 stack 변수에는 참조 주소값을 가짐 2) 내용을 변경할 수 없다 (read only*) 문자의 결합을 하면 새로운 문자로 바뀌고 새로운 참조 주소를 가짐 String 클래스의 주요 메서드 참고. substring(int from, int to) "hamburger".substring(4, 8) returns "urge" "smiles".substring(1, 5) returns "mile" - 문자열 인덱스는 0번 부터 시작 - from : inclusive (포함) - t..
@FunctionalInterface - 단 하나의 추상 메서드(Single Abstract Method) 만을 가지는 인터페이스 - static / default method 선언 가능 (Java 8 부터) - java.lang.Runnable, java.util.Comparator 등 Function R apply(T t); BiFunction R apply(T t, U u); Supplier T get(); Consumer void accept(T t); T타입의 인자를 받아 로직 수행 (리턴 x) BiConsumer void accept(T t, U t); T, U 타입 인자를 받아 로직 수행 (리턴x) Predicate boolean test(T t); Comparator int compare(..
![[Java] Enum (이펙티브 자바 3판)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2Fpe3a2%2FbtspMktorp8%2FzRShaPqylEYkflNbmirNb1%2Fimg.png)
참고. Enum Method ordinal() 은 열거형 상수의 순서에 따라 변경되므로, 열거형 인스턴스의 상수 필드를 사용하는 것을 권장 (아이템 35) 아이템34. 상수 대신 열거 타입을 사용하라 정수 열거 패턴 (안티 패턴)public static final int APPLE_FUJI = 0;public static final int APPLE_PIPPIN = 1;public static final int APPLE_GRANNY_SMITH = 2;public static final int ORANGE_NAVEL = 0;public static final int ORANGE_TEMPLE = 1;public static final int ORANGE_BLOOD = 2;- 타입 안전을 보장할 방법이 없..
![[Java] Enum values 조회 (Baeldung)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FORpnq%2Fbtso10vi7R0%2F7cnIr2Z7MElJlrVInbCDHk%2Fimg.png)
1. Enum Month 클래스 생성 - 각 Month 인스턴스는 code와 number 값을 가짐 - Enum Constructor(생성자)는 기본적으로 private 로 생략가능하다. public enum Month { JANUARY("Jan", 1), FEBRUARY("Feb", 2), MARCH("Mar", 3), APRIL("Apr", 4), MAY("May", 5), JUNE("Jun", 6), JULY("Jul", 7), AUGUST("Aug", 7), SEPTEMBER("Sept", 7), OCTOBER("Oct", 10), NOVEMBER("Nov", 11), DECEMBER("Dec", 12); private final String code; private final int number..
![[Java] Enum values 배열을 리스트 변환 (Baeldung, Enum values to List)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FbyvlZI%2FbtsoYVOVu0U%2F6TdtKSkHP0appqGSWvK0O1%2Fimg.png)
Enum values to List 기본적으로 제공하는 values() method를 사용하게 되면 아래와 같이 배열[] 형태로 값이 반환된다. PizzaStatus[] values = PizzaStatus.values(); // [ORDERED, READY, DELIVERED] 개인적으로 values()와 forEach 구문을 활용하여 많이 사용했는데, Array -> List 로 변경하는 방식에 대해 Baeldung 포스팅이 있어서 내용을 정리해본다. 1. 클래스 타입 토큰을 인자로 전달받아 사용하는 static method 경우 static List enumValuesInList(Class enumClass) { T[] arr = enumClass.getEnumConstants(); // Enum ..
![[Java] Generics (제네릭) - 공변/무공변/반공변, PECS](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FoGQgI%2FbtsoSmk5rqq%2Fj59WO0Cs6EAli6TaUYbfnk%2Fimg.png)
요약. 제네릭의 무공변/공변/반공변- 제네릭은 기본적으로 무공변/불공변성을 가진다- 상한 경계(extends) 타입 변수 지정하여 제네릭은 공변성을 가질 수 있다- 하한 경계(super) 타입 변수 지정하여 제네릭은 반공변성을 가질 수 있다 공변은 인터페이스 구현이나 상속(부모-자식 관계)을 생각하고,반공변은 부모-자식관계가 반대로 된 것으로 생각하기 Generics 란?- 클래스 내부에서 사용할 데이터 타입을 외부에서 지정하는 기법- 타입을 클래스 정의하는 시점이 아닌, 실제 사용하는 생성 시점에 결정- Complie(컴파일) 단계에서 타입을 체크함으로써 코드의 안정성을 높임- 코드 중복 줄이고 재활용성 높임- JDK 1.5 부터 도입 Generics을 사용하는 이유Generics 타입 지정함..
![[Java] Annotation - 어노테이션 (자바의 정석)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FV8Fvr%2Fbtso5upjB35%2Fow2JWWevVgTr3or8bmC991%2Fimg.png)
자주 사용하는 표준 어노테이션 @Override - 오버라이딩을 올바르게 했는지 컴파일러가 체크 @Deprecated- 앞으로 사용하지 않을 것을 권장하는 필드나 메서드에 붙임 @FunctionalInterface- 함수형 인터페이스는 하나의 추상메서드만 가져야 한다는 제약이 있음- 함수형 인터페이스에 붙이면, 컴파일러가 제대로 작성했는지 체크- 함수형 인터페이스라고 명시적으로 알려줌 @SuppressWarnings- 컴파일러가 경고 메시지가 나타나지 않게 한다. - 명시적으로 경고를 확인하고 억제하기 위해 붙였다는 의미를 나타내기도 함# 한 가지@SuppressWarnings("unchecked")List list = new ArraysList(); // 제네릭 타입 지정하지 않아 발생하는 오류 표시..
![[Intellij] Custom VM options 잘못 설정하여 실행되지 않는 경우 : Invalid initial heap size](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FkSZw7%2FbtsnZDujbFT%2FrgtFUp7mpTCklFFlPz2OY0%2Fimg.png)
문제 인강을 보며 신규 프로젝트 생성하면서 무심코 Custom VM options을 수정한 뒤로 인텔리제이가 실행 되지 않았다. (-Xms1024m -Xmx2048m) *한시간 동안 괴롭혔던 에러 메시지 $ intellij // 인텔리제이 실행 alias Invalid initial heap size: -Xms1024m Error: Could not create the Java Virtual Machine. Error: A fatal exception has occurred. Program will exit. 기술블로그를 찾아보거나 ChatGPT에게 질문해보아도 인텔리제이 설치 경로에 있는 idea64.vmoptions의 Xms, Xmx 힙 사이즈 수정해도 실행되지 않았다 설치 경로 /home/사용자명/..

Jenkins v2.413 기준 설명 Slack 설정 Slack 가입 및 개인 채널 생성 (생략) - 무료 플랜 사용 - 배포 알림 채널로 #build-deploy 생성 Jenkins CI 앱 설치 앱에서 jenkins 검색하여 추가 아래 이미지에서는 생략되어 있지만 친절하게 Jenkins에 Slack Token 등록하는 방법 또한 가이드 설명해 준다 사용할 채널을 선택하고 Slack Token을 발급받고 가이드에 따라 Jenkins 설정에 해당 토큰을 등록 후 사용 Jenkins 설정 plugin 설치 - 플러그인 설치 권한 가진 계정으로 접속 - [Jenkins관리 > Plugins] 에서 slack notification 설치 Slack Token 등록 - [jenkins 관리 > System] 메..
![[Ubuntu] /bin/bash로 기본 shell 변경하기](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FcWlpeH%2FbtsnGZRCyC9%2F9403Y2bYPWjRmNbRy2ScD1%2Fimg.png)
chsh 명렁어 실행 $ su root $ chsh -s /bin/bash /etc/passwd 수정 $ vim /etc/passwd /bin/sh 를 /bin/bash 로 수정 후 저장하면 된다
![[Docker] Jenkins Build, Deploy, Execute Shell / 자동배포 환경 테스트 (4)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2Fb5MvBo%2FbtsnK90EdoI%2FbTg4zxmgO5sveJBJkDIBck%2Fimg.png)
전체 flow 해당 포스팅에서는 *.war 빌드 배포 후 hello world 화면 확인하는 과정만을 기록 Jenkins Execute Shell 작성 1. Execute Shell #!/bin/bash ./gradlew clean bootWar 2. Execute Shell #!/bin/bash BUILD_FILE=$(find . -name *.war) FILE_NAME=`basename $BUILD_FILE` HOST=ubuntu1 USER=ubuntu LOC=/home/ubuntu/project/wars SYMBOLIC_LINK=/home/ubuntu/project/dev.war RUN_CMD=/home/ubuntu/project/deploy.sh echo "> copy ${BUILD_FILE} t..
![[Docker] Container SSH key 접속, scp 명령어로 파일 전송 (3)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FEsYPJ%2FbtsnLbcPUa3%2FvPlnzYLJFgunLJ4vMlokKK%2Fimg.png)
* 절차 : Docker Network 신규 생성 > hostname 지정 > ssh key 통신 접속 수행 Docker Network 생성 $ docker network create --gateway 172.19.0.1 --subnet 172.19.0.0/16 home # 확인 $ docker network ls $ docker inspect home - home bridge 신규 생성 - docker의 경우 신규 컨테이너 생성시 default 네트워크에 B클래스 대역 IP로 할당하는 것으로 보임 Docker Container 실행 및 SSH Key 접속 - 사전에 만들어 놓은 ubuntu와 jenkins container 를 활용하여 - docker run의 경우 container를 다시 만들고, 실..
![[Docker] Container IP 확인 및 SSH 접속하기 (2)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FB4ZEU%2FbtsnFenYE9S%2FLJH21AqNHNvMTZvEOwwiyk%2Fimg.png)
Docker Container 별 IP Address 확인 1. host (local) 에서 docker command로 확인하기 방법1. docker inspect json 형태로 구성된 (low-level) docker container 정보에서 확인 $ docker inspect -f "{{.NetworkSettings.IPAddress}}" $ docker inspect | grep IPAddress 방법2. docker exec 실행 중인 docker container 에 command 실행 시킴 이때 ip 명령어의 경우 서버에 패키지 설치 되어 있지 않을 경우 동작하지 않음 (iproute2 패키지 설치) $ docker exec ifconfig eth0 $ docker exec ip addr..
![[Docker] Jenkins 설치 및 Github 연동 (1)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FbAqjKd%2FbtsmUu5AwFI%2FRx6bh748sthUhcWcV3IOW1%2Fimg.png)
Jenkins 설치 (By Docker) - 처음 lts와 2.176.2 설치했었는데, 버전 문제인지 플러그인 설치 실패 계속 되었음 - docker hub에서 2.413-jdk11버전으로 받으니 플러그인 정상 설치 확인 # docker image 검색 $ docker search jenkins # image 다운로드 $ docker pull jenkins/jenkins:2.413-jdk11 # image 확인 $ docker images # 설치 $ docker run --name jenkins -d -p 8080:8080 -p 50000:50000 -v /home/jenkins:/var/jenkins_home -u root jenkins/jenkins:2.413-jdk11 # container 터미널..
초기 개발 환경에서 h2 inmemory 데이터 베이스를 활용하여 테이블 생성 및 샘플 데이터 입력할 수 있도록 설정 수행 1. 의존성 추가 (build.gradle) dependencies { // spring boot implementation 'org.springframework.boot:spring-boot-starter-web' implementation 'org.springframework.boot:spring-boot-starter-data-jpa' // test testImplementation 'org.springframework.boot:spring-boot-starter-test' // lombok compileOnly 'org.projectlombok:lombok' annotatio..
![[Java] Primitive type (기본형 타입)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2Fdv1jzN%2FbtsoUMp1ijJ%2FQK8Of97dQgXdg7LlsxeP2K%2Fimg.png)
Primitive type - 총 8가지의 기본형 타입을 자바에서 제공함 - 기본값을 제공하기 때문에 Null이 존재하지 않음. 만약 기본형 타입에 Null을 넣고 싶은 경우 Wrapper class를 활용해야함 - 실제 값을 저장하는데, 이때 Stack(스택) 메모리에 저장됨 타입 할당 메모리 크기 데이터 표현 범위 논리형 boolean 1byte false, true 정수형 byte 8bit (1byte) -128 ~ 127 short 16bit (2byte) -32,768 ~ 32,767 int 32bit (4byte) -2,147,483,648 ~ 2,147,483,647 long 64bit (8byte) -9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,..

후기🧑💻 약 2년 전 단기간 코딩 테스트 준비를 하여 더 나은 곳으로 이직을 할 수 있었다. 실무에서 코딩 테스트와 같은 문제를 요구하지는 않지만, 문제 해결 과정에서 필요한 자료 구조 유형을 판단하여 사용하거나 알고리즘 기법을 응용해서 적용하거나 할 수 있었다. 이는 이전에는 할 수 없었던 경험이었다. 그러나 시간이 지남에 따라 잊게 되고, 할 줄 아는 거만 반복하는 모습에서 기본기가 부족한 게 아닌가 싶은 고민을 하고 있었고, 이러한 상황에서 기회가 되어 강의를 수강할 수 있었다. 한 단계 더 성장 강의 해설에 절차 지향적인 코드와 설명을 접하더라도 이해가 되지 않는 경우가 많았다. 그럴 때 마다 시야를 넓혀서 기술 블로그/유튜브 등을 통해 앞서 고민했던 사람의 흔적을 볼 수 있었고, 그 결과 새로..