반응형

전체 글 85

[코틀린 인 액션] 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

입사, 23개월, 퇴사 그리고 이직

성장의 여정 2022년 4월 11일, NHN에서 백엔드 개발자로서 새로운 여정을 시작했었다. 처음 맡게 된 소셜 카지노 게임 도메인은 모던한 기술을 다룰 기회를 제공했으며, 다양한 프로젝트를 독립적으로 설계하고 개발하는 성장의 기회를 가질 수 있었다. 허원철 파트장님의 지속적인 노력 덕분에 바쁜 일정 중에도 우리 파트는 뛰어난 개발 문화를 유지할 수 있었다. 특히 코드 리뷰, 테스트 코드 작성, 시스템 설계 등에 대한 나의 가치관을 다른 팀원들과 일치시키기 위한 노력을 하면서 더욱 성장할 수 있었다. 개발자로서의 성장은 회사 일에만 국한되지 않았다. 2023년 4월에 시작한 10명 규모의 백엔드 개발자 독서 모임은 현재 60명의 다양한 직무를 가진 개발자들이 활동하는 커뮤니티로 성장했다. 또한, 오픈소스..

회고록 2024.03.05

Revise the documentation to correct misleading information regarding the ItemWriteListener

Issue Documentation on ItemWriteListener is misleading. · Issue #4400 · spring-projects/spring-batch The reference doc for ItemWriteListener says: The afterWrite method is called after the item has been successfully written However, digging into the Javadoc for ItemWriteListener, it seems otherwis... github.com PR Revise the documentation to correct misleading information regarding the ItemWrite..

오픈소스 2023.11.18

[데이터 중심 애플리케이션 설계] 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
반응형