반응형

독서 21

[코틀린 인 액션] 6장. 코틀린 타입 시스템

찾아본 내용 1. 코틀린에서 확장함수 사용 시 객체가 null이어도 메서드 호출을 할 수 있는 이유는? 자바에서의 static 메서드와 같이 동작해서 그런가? (p. 265) 코틀린의 확장 함수는 실제로 자바의 static 메서드로 컴파일됩니다. 즉, 확장 함수는 호출되는 대상 객체를 첫 번째 매개변수로 받는 자바의 정적 메서드와 유사하게 동작합니다. 이러한 구현 방식 덕분에, 확장 함수는 클래스의 일부가 아니기 때문에, 객체가 null일지라도 함수를 호출할 수 있습니다. fun String?.isNullOrBlank(): Boolean { return this == null || this.isBlank() } public class StringExtensions { public static boolea..

독서 2024.04.21

[코틀린 인 액션] 5장. 람다로 프로그래밍

찾아본 내용 1. 주요 용어 무명 클래스 (Anonymous Class) 무명 클래스는 이름이 없는 클래스로, 주로 일회성으로 사용되는 객체를 생성할 때 사용됩니다. 이 클래스는 주로 이벤트 리스너나 작은 인터페이스 구현에 사용되며, Java와 유사한 방식으로 코틀린에서도 사용됩니다. val thread = Thread(object : Runnable { override fun run() { println("Thread running") } }) thread.start() 이 예에서 Runnable 인터페이스를 구현하는 무명 클래스를 만들어 Thread 생성자에 전달했습니다. 람다 (Lambda) 람다는 간결한 방식으로 함수를 표현하는 방법입니다. 람다 표현식을 사용하면 별도의 클래스를 정의하지 않고도 ..

독서 2024.04.14

[코틀린 인 액션] 4장. 클래스, 객체, 인터페이스

찾아본 내용 1. 중첩 클래스는 기본적으로는 내부 클래스가 아니다. 즉, 코틀린 중첩 클래스에는 외부 클래스에 대한 참조가 없다. (p. 142) 중첩 클래스 (Nested Class) 중첩 클래스는 기본적으로 static 클래스와 유사하게 동작합니다. 이는 중첩 클래스가 외부 클래스의 인스턴스 없이도 생성될 수 있다는 것을 의미합니다. 중첩 클래스는 외부 클래스의 인스턴스에 대한 참조를 자동으로 가지고 있지 않습니다. 즉, 외부 클래스의 속성이나 메소드에 직접 접근할 수 없습니다. 코틀린에서 중첩 클래스는 특별한 키워드 없이 클래스 내부에 다른 클래스를 선언함으로써 생성됩니다. 내부 클래스 (Inner Class) 내부 클래스는 inner 키워드를 사용하여 선언됩니다. 이 키워드는 클래스가 외부 클래스..

독서 2024.04.07

[코틀린 인 액션] 3장. 함수 정의와 호출

찾아본 내용 1. 코틀린의 로컬 함수와 확장 함수 (p.139) 코틀린에서는 코드의 가독성과 재사용성을 높이기 위해 로컬 함수와 확장 함수를 사용할 수 있다. 각각의 사용 시나리오는 아래와 같다. 로컬 함수 사용 시나리오 특정 함수 내에서만 사용되는 도우미(helper) 함수를 정의할 때 사용한다. 외부에서는 접근할 필요가 없는 함수의 경우, 로컬 함수로 정의하여 캡슐화를 강화할 수 있다. 장점 외부의 접근으로부터 함수를 숨길 수 있어, 더 좋은 캡슐화를 제공한다. 로컬 범위 내에서만 사용되므로, 코드의 가독성을 높이고, 유지보수를 용이하게 한다. 확장 함수 사용 시나리오 기존 클래스에 새로운 함수를 추가할 때 사용한다. 이 때, 클래스의 코드를 수정할 필요가 없다. 기존 라이브러리에 대한 확장이나, A..

독서 2024.03.30

[코틀린 인 액션] 2장. 코틀린 기초

찾아본 내용 1. 대입문은 자바에서는 식(expression)이었으나 코틀린에서는 문(statement)가 됐다. 그로 인해 자바와 달리 대입식과 비교식을 잘못 바꿔 써서 버그가 생기는 경우가 많았다. (p.63) Expression(식) vs. Statement(문)의 차이 Expression(식)과 Statement(문)은 프로그래밍 언어에서 기본적인 구성 요소입니다. 이 둘의 가장 큰 차이는 값의 반환 여부와 할당의 가능성에 있습니다. Expression(식): 값을 생성하고, 변수에 할당될 수 있는 코드 조각입니다. 예를 들어, 2 + 3, myVariable, myFunction() 등은 모두 값으로 평가되어 결과를 반환하는 식입니다. 식은 다른 식의 일부로 사용될 수 있습니다. Statemen..

독서 2024.03.24

[데이터 중심 애플리케이션 설계] 6장

핵심 내용 1. 주요 파티셔닝 기법 키 범위 파티셔닝 : 키가 정렬돼 있고 개별 파티션은 어떤 최솟값과 최댓값 사이에 속하는 모든 키를 담당한다. 키가 정렬돼 있어 범위 질의가 효율적이지만, 애플리케이션에서 정렬 순서가 서로 가까운 키에 자주 접근하면 핫스팟이 생길 위험이 있다. 이 방법에서는 보통 한 파티션이 너무 커지면 키 범위를 두 개로 쪼개 동적으로 재균형화를 실행한다. 해시 파티셔닝 : 각 키에 해시 함수를 적용하고 개별 파티션은 특정 범위의 해시값을 담당한다. 이 방법을 쓰면 키 순서가 보장되지 않아 범위 질의가 비효율적이지만 부하를 더욱 균일하게 분산할 수 있다. 해시 파티셔닝을 사용할 때는 보통 고정된 개수의 파티션을 미리 만들어 각 노드에 몇 개씩의 파티션을 할당하며 노드가 추가되거나 제..

독서 2023.11.17

[데이터 중심 애플리케이션 설계] 5장

핵심 내용 1. 복제의 용도 고가용성 연결이 끊긴 작업 : 네트워크 중단이 있어도 애플리케이션이 계속 동작 지연 시간 확장성 2. 복제에 대한 주요 접근 방식 단일 리더 복제 : 클라이언트는 모든 쓰기를 단일 노드로 전송하고 리더는 데이터 변경 이벤트 스트림을 다른 복제 서버로 전송한다. 읽기는 모든 복제 서버가 수행할 수 있지만 팔로워의 읽기는 오래된 값일 수 있다 다중 리더 복제 : 클라이언트는 각 쓰기를 여러 리더 노드 중 쓰기를 받아들일 수 있는 노드로 전송한다. 리더는 데이터 변경 이벤트 스트림을 다른 리더와 모든 팔로워 노드로 전송한다 리더 없는 복제 : 클라이언트는 각 쓰기를 여러 노드로 전송한다. 클라이언트는 오래된 데이터를 감지하고 이를 바로잡기 위해 병렬로 여러 노드에서 읽는다 3. 복..

독서 2023.11.17

[데이터 중심 애플리케이션 설계] 4장

핵심 내용 1. 순회식 업그레이드는 정지 시간 없이 새로운 버전의 서비스를 출시 가능하게 하고 배포를 덜 위험하게 만든다. 2. 순회식 업그레이드 중이거나 여러 가지 다른 이유로 다양한 노드에서 다른 버전의 여러 애플리케이션 코드가 수행된다. 따라서 시스템을 흐르는 모든 데이터는 하위 호환성과 상위 호환성을 제공하는 방식으로 부호화해야 한다. 3. 다양한 데이터 부호화 형식으로는 JSON, XML, CSV 같은 텍스트 형식과 스리프트, 프로토콜 버퍼, 아브로 같은 이진 스키마 기반 형식이 존재한다. 배운 내용 1. 프로토콜 버퍼와 같은 구조화된 데이터 직렬화 방식에서 필드에 새로운 태그 번호를 부여하는 방식으로 스키마에 새로운 필드를 추가할 수 있다. 새로 추가되는 필드는 상위 호환성을 유지하려면 opt..

독서 2023.11.15

[데이터 중심 애플리케이션 설계] 3장

핵심 내용 로그 구조화 관점에서 파일에 추가와 오래된 파일의 삭제만 허용하고 한 번 쓰여진 파일은 절대 갱신하지 않는다. 비트캐스크, SS테이블, LSM 트리, 레벨 DB, 카산드라, HBase, 루씬 등이 이 그룹에 속한다. 임의 접근 쓰기를 체계적으로 디스크에 순차 쓰기로 바꾼다 하드드라이브와 SSD의 성능 특성에 맞춰 쓰기 처리량을 높이는 것이 가능하다 제자리 갱신 관점에서 덮어쓰기 할 수 있는 고정 크기 페이지의 셋으로 디스크를 다룬다. 이 관점에서 가장 큰 예가 B 트리다. B 트리는 모든 주요 관계형 데이터베이스와 많은 비정형 데이터베이스에서도 사용한다. 배운 내용 1. 정렬되어 있으면 적어도 두가지 값 사이에 있다는 것만으로도 이진 탐색이 가능해진다. 인덱스가 범위를 나타내는 페이지로 구성되..

독서 2023.11.13

[스터디 메모] 2 ~ 5장

enrichPerformance 메서드에서 shallow copy한 Performance 객체에 동적으로 play라는 필드를 추가해버리는데 자바에서는 어떻게 구현하셨는지 궁금합니다 (p.56) PerformanceVo 별도로 정의 Performance 클래스에 추가 데이터베이스 리팩토링 or 마이그레이션 시 얼마나 작은 단계로 나눠서 릴리스 하시는지 궁금합니다 (p.99) flyway 사용 DBA 검수 이후 주로 오전에 배포합니다. 락이 걸리거나 큰 작업의 경우에는 새벽에 배포합니다. DBA에게 요청합니다. 2주에 한번씩 주기적으로 한번에 배포합니다. 모든 상황에서 기능 추가와 리팩토링을 독립적으로 분리하여 커밋하기에는 너무 피곤해질 것 같은데.. 그럼 기능 추가를 진행하며 마음에 들지않는 코드여도 일단..

반응형