본문 바로가기

Java & Kotlin

(15)
클래스로더는 .class 파일을 어떻게 실행시키나? 자바는 "한 번 작성하면 어디서나 실행된다"는 철학으로 유명합니다. 이 철학의 중심에는 JVM 클래스 로딩 시스템이 있습니다.이번 글에서는 JVM이 .class 파일을 어떻게 메모리에 올리고 실행하는지, 그 핵심 매커니즘을 상세히 설명합니다. 1. 클래스 로딩이란 무엇인가?자바 프로그램은 .java 소스 파일을 컴파일하면 .class 파일(바이트코드)이 생성됩니다.JVM은 이 .class 파일을 메모리에 로드하고 실행하는데, 이 과정을 클래스 로딩(Class Loading)이라고 부릅니다.굳이 java파일을 class 파일로 변환하는 이유는, JVM이 이를 읽을 수 없어서가 아니라 효율성, 이식성, 보안성을 위해서 JVM이 읽기 쉬운 파일로 변환한다고 보시면 됩니다. 자바 프로그램의 실행 흐름 개요자바 ..
NIO(New I/O)와 Webflux 비동기 프로그래밍 Java의 New Input/Output을 사용해보며 대규모 처리에서 중요한 개념이라고 생각되어 이를 소개합니다. 1. NIO는 어떤것이고 왜 사용하는가NIO가 등장하기 이전에 사용된던 방식은 Blocking I/O입니다.글에서는 편하게 과거 방식의 Blocking I/O 를 BIO 라고 부르겠습니다. BIO에서는 클라이언트당 하나의 스레드를 할당해야 하며, 클라이언트가 많아질 경우 OOM(Out Of Memory)이 발생하거나 과도한 context switching 등의 문제가 발생합니다. 예를 들어, 하나의 스레드를 생성하는 데 약 1MB의 메모리가 필요하다고 가정하면,10,000명의 클라이언트 요청을 동시에 처리할 경우 10GB의 메모리가 필요합니다. 이를 해결하기 위해 2002년 Sun Micro..
Java Stream API의 핵심 개념과 병렬 처리의 함정 Java 8에 도입된 Stream API는 반복문 위주의 명령형 코드를 선언형 스타일로 바꾸고,더 나아가 병렬 처리를 손쉽게 구현할 수 있도록 도와주는 강력한 도구입니다. 이 글에서는 기본적인 사용법은 다루지 않고,실무에서 주의해야 할 핵심 개념들과 병렬 처리 시 발생할 수 있는 문제들에 대해 정리해보려 합니다. 1. Java Stream API가 무엇인지?Stream API는 2014년 4월, Java 8과 함께 등장한 기능으로, 컬렉션 또는 배열 데이터를 데이터 흐름(stream) 형태로 처리할 수 있게 합니다. 기존에는 for/while 루프를 사용해 명시적으로 데이터를 처리했다면,Stream은 데이터 처리 과정을 선언적으로 구성할 수 있습니다. 이를 통해 가독성이 좋아지고, 병렬 처리도 간결하게 ..
Socket 통신 1. Socket 통신이란 무엇인가?Socket은 네트워크 프로그래밍에서 가장 기본적이고 중요한 개념 중 하나입니다. 다양한 네트워크 애플리케이션(채팅, 실시간 게임, 파일 전송 등)을 개발하려면 클라이언트-서버 간 통신이 필수적입니다. 이때 Socket은 데이터를 주고받는 양 끝단의 연결점을 의미합니다. 2. Socket 통신의 기본 개념2.1. Socket이란?Socket은 네트워크 상의 두 호스트 간 통신을 위한 인터페이스입니다.주로 TCP/IP 또는 UDP 프로토콜 위에서 데이터를 주고받을 때 사용됩니다. 2.2. TCP와 UDP의 차이구분TCPUDP프로토콜 타입연결형(Connection-oriented)비연결형(Connectionless)신뢰성데이터 무결성 및 순서 보장신뢰성 보장 안 함속도느림..
Java ThreadPoolExecutor 예외 처리와 Exception Handler ThreadPoolExecutor의 예외처리와 Exception을 어떤식으로 핸들링 해야 하는지, 그리고 JDK에서는 어떤 설정을 기본으로 가져가는지 알아보겠습니다. 알아보기에 앞서 ThreadPoolExecutor에 대한 사용법부터 간단하게 알아보겠습니다.1. 기본 사용 방법ThreadPoolExecutor executor = new ThreadPoolExecutor(30, 60, 60, TimeUnit.SECONDS , new LinkedBlockingQueue(1000), new ThreadPoolExecutor.AbortPolicy()); executor.execute(runnable);executor.submit(callable); 각 파라미터에 대한 설명1(core) : 코어 쓰레드는 3..
Java Thread로 직접 구현하는 커스텀 쓰레드 풀: 기본 원리부터 동작까지 오늘은 Java의 Thread 객체만을 이용해 직접 Executors 클래스의 쓰레드 풀을 구현하는 방법에 대해 소개하겠습니다. Java에서는 Executors 클래스를 사용해 쉽게 쓰레드 풀을 만들 수 있지만, 내부적으로 어떻게 작동하는지 이해하면 더 유연하고 자신만의 커스텀 쓰레드 풀을 설계할 수 있습니다. 이번 글에서는 Thread와 BlockingQueue를 이용해 최소한의 쓰레드 풀을 구현하고, 이를 통해 기본적인 원리를 설명해보겠습니다. 코드는 GitHub에서 확인하실 수 있습니다: https://github.com/youseonghyeon/threadpool 요구 사항구현하려는 Thread Pool의 주요 기능은 다음과 같습니다: 최소 쓰레드 개수 설정: 항상 일정한 최소 개수의 쓰레드가 살..
Kotlin으로 TTL 기반 Map 구현하기: Java 21 가상 쓰레드와 ConcurrentHashMap 최적화 Redis를 사용할 때 유용한 기능인 시간이 지나면 데이터가 지워지는 기능이 있습니다. 이것을 Kotlin에서 사용해보면 좋을 것 같아 구현해보겠습니다. Redis의 TTL(Time To Live) 기능은 데이터가 일정 시간이 지나면 자동으로 삭제되는 매우 유용한 기능입니다. 이 기능을 활용하면 일정 시간 동안만 유효한 데이터를 관리할 수 있어 리소스 효율성을 극대화할 수 있습니다. Redis 대신 Kotlin에서 직접 이러한 TTL 기능을 구현해보면, 기존 Map처럼 동작하면서도 시간 기반 데이터 관리가 필요한 상황에서 유용하게 사용할 수 있습니다. 요구사항기능은 기존 Map과 동일하게 동작해야 합니다.TTL 시간을 생성자로 주입합니다.시간이 지나면 key, Value가 제거됩니다. 구글이 제작한 라이..
Java Checked vs Unchecked Exception: 예외 처리의 원칙과 트랜잭션 롤백 Checked Exception과 Unchecked Exception에 대한 이해Java에서 예외 처리(Exception Handling)는 매우 중요한 요소입니다.저는 아키텍처 설계에서 가장 중요하다고 생각되는게 Exception 처리라고 생각합니다. 예외는 프로그램 실행 중에 발생할 수 있는 비정상적인 상황을 나타내며, 이 예외를 적절히 처리하지 않으면 프로그램이 예기치 않게 종료될 수 있습니다.Java에서는 예외를 두 가지 유형으로 나눌 수 있는데, 바로 Checked Exception과 Unchecked Exception입니다. 이번 글에서는 두 가지 예외의 차이점과 사용 사례, 그리고 언제 어떤 예외를 사용하는 것이 적절한지에 대해 알아보겠습니다. Checked Exception이란Checked..