Hoo, I am

junior_datalist

  • 분류 전체보기 (344)
    • Backend (96)
      • ☕️ Java (32)
      • 🌿 Spring (35)
      • 🩵 Go (7)
      • 🔗 Kafka (3)
      • 🐍 Python (17)
    • Frontend (27)
      • React (9)
      • JS (18)
    • 🌐 Web (13)
    • ☁️ Cloud (10)
      • ⚓️ Kubernetes (0)
    • 💡Database (1)
    • 📔 TIL (98)
    • 📚 Book (6)
      • Core Javascript (2)
      • 데이터 중심 애플리케이션 설계 (3)
    • 🔱 Algorithm (53)
      • DP (7)
      • BFS DFS (3)
      • Greedy (7)
      • Back tracking (2)
      • Else (18)
    • 🤿 숨참고 Deep Dive (3)
    • 📝기록 (20)
      • 후기 (3)
07-11 19:46
  • 홈
  • 태그
  • 방명록
로그인
로그아웃 글쓰기 관리

junior_datalist

컨텐츠 검색

태그

로또의최고순위와최저순위 파이썬 npm맥윈도우 어드바이드 스프링부트3 자바스크립트 map 객체 글또 파티션할당전략 JavaAppletPlugin 기억보단기록을 Nullish Coalescing Operator 회고 모든개발자를위한http웹기본지식 gitreset 포인트컷 query parameter string 백준 2346 리눅스 디렉토리 삭제 데이터중심애플리케이션설계 null 병합 연산자 커밋되돌리기

최근글

댓글

공지사항

  • About me

아카이브

전체 글(344)

  • 도커에서 Redis 사용할 때 시행착오 3가지

    목차 - 개요 : 사용한 명령어 - 1. `-v /path/on/host:/data` 옵션 누락 - 2. 포트 포워딩 옵션 누락 - 3. 키가 사라진 이유 (feat. 해킹?) - 결론 환경 ubuntu version: 18.04 docker version: 23.0.1 redis image version: latest 개요 도커에서 레디스를 사용할 때 겪은 에러 사항을 기록했습니다. 1. 레디스에 저장된 데이터가 유실되거나 2. 스프링부트 서버에서 레디스로 접속을 못했고 3. 저장한 키가 사라지고, "backup1" 이란 의문의 키가 나타남. 결론부터 말씀드리면, 도커에서 레디스를 실행할 때 명령어만 제대로 쳤으면 해결될 문제였습니다. 아래는 처음 레디스를 실행할 때 사용한 (잘못된) 명령어로, 어떤 ..

    2023.04.02
  • 2023-1분기 회고

    목차 1분기의 책 1분기의 스터디 1분기의 프로젝트 1분기의 키워드 1분기의 커피챗 1분기의 아쉬운 점 1분기의 습관 2분기는? 조금 일찍 작성해 보는 23년의 1분기 회고. 크리티컬 한 일이 있었지만 공개적인 곳에선 드러내기 힘들어 배제했다. 그럼에도 꽤 알찬 회고 글이 완성됐다. 심각하다고 느낀 일이 사실은 그리 큰일이 아닐 수도 있다. 1분기의 책 일반 서적 천개의 파랑 (천선란 作) 뼈의 기록 (천선란 作) 천문학자는 별을 보지 않는다. (심채경 作) 읽은 책 모두 좋았다. 위 3권의 책 말고 자기 계발서도 기웃거렸는데 끝내 완독은 못했다. 나는 자기 계발서와 맞지 않는 사람인가 봄,, "천 개의 파랑"은 진짜 최고 최고 최고. 요즘은 책 추천 부탁받으면 무조건 천 개의 파랑이다. 성장, 드라마,..

    2023.03.26
  • @Transactional 썼지만 Dirty Checking 이 안된 이유

    목차 0. Dirty Checking 이 동작하지 않은 내 코드 1. Dirty Checking 은 어떤 조건에서 실행되는가? 2. @Transactional 은 어떤 원리로 Dirty Checking 을 진행하는가? 3. 그럼 어떻게 수정해야하나? 4. 결론 Dirty Checking 과 @Transactional 의 원리를 잘 아시는 분이라면 이 글에서 얻어가시는게 많이 없을 수 있습니다. 이 글은 무지성으로 @Transactional 을 사용한 지난 날을 반성하고 더 공부하기 위해 작성했습니다. 0. Dirty Checking 이 동작하지 않은 내 코드 너무 부끄럽지만 처음엔 이렇게 코드를 짜놓고 왜 Dirty Checking 이 되지 않는지 의아했다. @Transactional 어노테이션이 있는 ..

    2023.03.12
  • Optional, ifPresentOrElse 로 간단한 리팩토링

    ifPresentOrElse 를 이용한 (초)간단 리팩토링 프로세스 1. userEmail 로 회원이 존재하는지 확인 2. Optional 타입의 findUser 반환 3. Optional 값이 비어있으면 userEmail 을 가지는 회원이 없다는 뜻이므로, newUser 엔티티를 저장 (repository.save()) . 4. Optional 값이 존재 시, findUser 의 토큰값 갱신 5. @Transactional 어노테이션으로 인해, 더티체킹 후 영속화 진행 기존.java @Transactional private void createUser(String userEmail, Token token) { Optional findUser = userRepository.findUserByEmail(u..

    2023.03.09
  • [딥 다이부] 이진트리, 이진탐색트리, B-Tree, B+Tree 개념과 꼬리질문

    Q. 트리란 무엇인가? A. 정의 : 부모 자식 관계로 이루어진 계층적 구조의 자료구조 Q. 이진 트리란 무엇인가? A. 자식노드가 최대 2개로 이루어진 트리 형태의 자료구조를 의미한다. Q. 이진 탐색 트리는 무엇인가? A. 마찬가지로 자식노드가 최대 2개로 이루어진 트리 자료구조. 트리의 모든 노드는 정렬된 상태를 유지하는데, 특정 노드의 왼쪽 서브트리는 해당 노드보다 작은 값을 가지며, 오른쪽 서브트리는 해당 노드보다 모두 큰 값을 가진다. Q. 이진 트리와 이진 탐색 트리의 차이는 무엇인가? A. 정렬 상태라 할 수 있다. 이진 탐색 트리는 정렬된 이진 트리로 볼 수 있는데, 노드의 왼쪽 하위 트리에는 해당 노드보다 작은 키가 있는 노드, 오른쪽 하위 트리에는 큰 키가 있는 노드만 포함된다. Q...

    2023.03.08
  • 책 좋은코드 나쁜코드 후기

    좋은 코드, 나쁜 코드(이하 좋코나코)를 읽었다. 작년에 제이펍 출판사 인스타그램 이벤트로 책을 받게 됐는데, 이제야 집어 들었다. 짧은 후기 좋코나코의 특징은 풍부한 예시 코드 덕분에 이해가 수월하다. 예시 코드는 수도 코드로 작성됐지만, 자바와 비슷한 스타일이라 더 읽기 편했다. 개선해야 할 코드를 우선 보여주고, 어떤 문제가 있는지 도식과 화살표를 이용해 설명하고 어떤 식으로 변경하면 좋은지 설명을 곁들여 개선된 코드를 제시한다. 개선된 코드로 도달하는 이유를 이론에 입각해 설명하기 때문에 그 과정에서 배울 수 있는 이론적인 내용도 유용하다. 추상화 계층을 만드는 이유, checked exception과 unchecked exception, 의존성 주입 등 자주 헷갈렸던 개념을 다루는데, 덕분에 읽..

    2023.03.05
  • 백준 1662 압축 파이썬

    1662번: 압축 압축되지 않은 문자열 S가 주어졌을 때, 이 문자열중 어떤 부분 문자열은 K(Q)와 같이 압축 할 수 있다. K는 한자리 정수이고, Q는 0자리 이상의 문자열이다. 이 Q라는 문자열이 K번 반복된다는 뜻이 www.acmicpc.net 내가 짠 코드 (메모리 초과) string = list(input()) input_stack = [] output_stack = [] for s in string: if s == ")": iter_num = -1 while 1: input_top = input_stack.pop() if input_top != "(": output_stack.append(input_top) else: iter_num = input_stack.pop() break input_..

    2023.03.01
  • 백준 2002 추월 파이썬

    2002번: 추월 입력은 총 2N+1개의 줄로 이루어져 있다. 첫 줄에는 차의 대수 N(1 ≤ N ≤ 1,000)이 주어진다. 둘째 줄부터 N개의 줄에는 대근이가 적은 차량 번호 목록이 주어지고, N+2째 줄부터 N개의 줄에는 영식이 www.acmicpc.net 쏘 이지한 문제지만 풀이 방법이 마음에 들지 않아서 다른 분들 코드랑 비교해봤다. 내가 푼 코드 deque 을 사용했다. 문제에서 원하는 것은 추월한 차의 수를 구하는 것. 즉 first in first out 을 위배한 경우를 카운트 하는 것이다. q1 이란 deque() 에 터널에 들어간 순서대로 원소를 담는다. 그리고 차례대로 터널을 빠져나오는 원소(out) 가 q1 의 첫번째와 일치하지 않다면, 해당 원소는 추월한 것으로 간주할 수 있다...

    2023.03.01
  • 백준 14225 부분수열의 합 파이썬

    14225번: 부분수열의 합 수열 S가 주어졌을 때, 수열 S의 부분 수열의 합으로 나올 수 없는 가장 작은 자연수를 구하는 프로그램을 작성하시오. 예를 들어, S = [5, 1, 2]인 경우에 1, 2, 3(=1+2), 5, 6(=1+5), 7(=2+5), 8(=1+2+5)을 만들 www.acmicpc.net 처음 푼 코드 from itertools import combinations N = int(input()) arr = list(map(int, input().split())) max_value = sum(arr) num_set = set() for n in range(1, N+1): for c in combinations(arr, n): num_set.add(sum(c)) i = 1 while T..

    2023.02.25
1 ··· 3 4 5 6 7 8 9 ··· 39
Github LinkedIn
© Huge Hoo

티스토리툴바