전체 썸네일형 리스트형 [Algorithm] 슬라이딩 윈도우(Sliding Window) 알고리즘 슬라이딩 윈도우 알고리즘 슬라이딩 윈도우 알고리즘은 윈도우 즉 일정한 범위를 가지고 있는 것을 유지하면서 이것을 이동(sliding) 하는 것이다. 예를들어 2가지 긴 문자열이 주어지고 알파벳 2개만을 포함하는 가장 긴 문자열을 찾아보는 문제가 있다, 이 문제를 슬라이딩 알고리즘을 이용하여 풀면 다음과 같이 파란색으로 칠해진 영역이 윈도우가 되고 이를 하나씩 밀게 되는 것이다. 그림의 Right 를 하나씩 움직이면 되는데 Right 가 C 를 가리키면 다음 포함하는 문자열이 3개가 되므로 윈도우가 더이상 확장 되지 않고 다음 윈도우로 움직인다. 이런식으로 움직이게 되는 것이다. 마찬가지로 D로 움직이면 CD 만 포함하게 되는것이다. Max lenght 를 값으로 가지면서 윈도우를 옮길 수 있는데 윈도우의.. [OOP] 책임과 역할의 차이 그리고 타입의 구현 방법 객체지향 관련글을 보다가 책임과 역할의 개념이 나왔다. 책임은 객체가 해야할 행위를 나타내고 역할을 그 책임이 모여 가지게 되는 것이 역할인 것이다. 조형호 작가님의 객체지향의 사실과 오해에서 보면 증언을 해야할 책임을 가진 증인 여기서 증언해야할 책임있고 그것을 하는 주체인 증인이 역할이 된다. 여기서 궁금한게 생겼다. 이상한 나라의 앨리스에서 재판이 열리고 여기서 트럼프 왕이 재판장인 역할을 맡는다. 트럼프가 있고 트럼트왕이있다. 그러면 트럼는 슈퍼타입(Super Type) 트럼프왕은 서브타입(Sub Type) 이다. 그리고 트럼프왕은 '재판장' 이라는 역할을 가지고 있다. 개념적으로 이해는 가지만 결국 이걸 구현하려다 보니 궁금해졌다. 그럼 어떻게 구현하지? 타입과 역할의 차이는 뭐지 역할이 타입이.. [OOP] 객체, 추상화, 캡슐화 객체 객체와 일반적인 값이 구분되는 것은 식별자때문이다. 객체를 고유하게 만들어주는 식별자 그게 바로 객체이다 식별자는 ID나 이름 같은 하나의 값일수도 ID와 이름이 합쳐진 또 다른 타입의 값일 수도있다. 추상화(Abstraction) 추상화는 특성을 일반화하고 세부사항을 제거하여 단순하게 만드는 과정이다. 모든 지형들을 표시하기 보다는 필요에 따라 필요한 특성들을 골라냄을 통해 복잡한 지형을 단순하게 길을 찾기 위한 용도만으로 사용할 수 있다. 이를 객체에 적용하여 하나의 새로운 타입으로 만들어 낼 수 있다. 토끼, 강아지, 고양이 이라는 객체가 있다고 하자 이 객체들을 '동물' 이라는 개념으로 추상화할 수 있다. 추상화의 과정 공통점을 찾아 일반화한다. 숨을 쉰다. 스스로 움직일 수 있다. 토끼가 .. [Cassandra] Cassandra Row Key 종류 Row Key 종류 Partition Key (Row Key) Node를 결정하는 Key 각 노드가 ring에 참여하면 hash 값의 범위를 부여받고 들어온 데이터의 hash 값을 계산하여 저장될 노드가 결정 된다. 이 때 계산되는 hash 값을 token 이라고 한다. Clustering Key (Sort Key) Node 에 저장된 각 Row 의 모든 Column 들을 정렬하는 Key Primary Key 각 Node 에서 각 Row를 Unique하게 결정해주는 Key 1개 이상의 Partition Key와 0개 이상의 Clustering Key로 구성된다. Primary Key는 Unique 해야한다. Composite Key 여러개의 컬럼으로 구성된 Key 끝! [JPA] @Convert 사용해서 Object를 Json 형식으로 저장하기 서론 요즘은 다양한 DB 에서 Json 타입을 지원하려고 하지만 하위버전이나 Json 타입을 지원하지 않는 DB 를 사용하고 있는 경우가 있을 것이다. 속성값 같은 건데 모두 column 으로 파는것보다는 Json 타입으로 저장하여 꺼내 쓰는 용도로 사용하면 유용한 경우가 있다. 이런 경우에 매번 가져올 때마다 convert 하지 않아도 Entity 내에서 객체 타입 그대로 사용할 수 있게 해주는 Java Persistence Api 가 있다. 예제 Product 라는 Entity 가 있고 ProductAttribute 를 Json 형식의 text 타입으로 DB Column 에 넣는다고 가정하자. Product Entity 코드 @Entity public class Product { ... @Conver.. [의존성과 아키텍처] 조영호작가님의 우아한 객체지향 강의 후기 및 정리 회사에 조영호작가님이 오셔서 우아한테크세미나에서 진행하신 의존성과 아키텍처 강의를 진행해주셨다. 오늘 쓸 내용은 그 강의에 대한 후기이자 정리이다. 정리 의존성 의존성이란 A와 B가 존재하고 B가 변경될 때 A도 변경되어야 하면 A가 B에 의존성을 가진다라고 할 수 있다. https://image.slidesharecdn.com/woowahanoo-190618171417/95/-3-1024.jpg?cb=1560916139 클래스 의존성의 종류 연관 관계 (Association) A가 B를 '영구적' 으로 의존하는 경우 대표적으로 객체참조가 이에 해당된다. 의존 관계 (Dependency) A가 B를 '일시적'으로 의존하는 경우 대표적으로 함수의 파라미터로 넘겨받는 경우나 리턴타입, 지역변수의 경우가 해당.. [JAVA Stream] stream(), peek()의 함정 Java8 에서 stream 에는 두가지의 반복문이 사용가능한데 peek() 과 forEach() 가 있다. 두가지의 차이점이라고하면 forEach 는 그자체만 사용가능하지만 peek() 은 그렇지 않다. 이유는 단순한데 forEach는 return 값이 void 라서 최종처리메소드로 쓰일 수 있지만 peek은 stream 을 return 해서 불가능하다. /*peek 구현체*/ @Override public final Stream peek(Consumer [Gradle] Dependency version 이 꼬였을 땐, Dependency Management gradle version :gradle-5.5-bin.zip ide : intellij idea 2019.1 잡소리서론 개발을 하다보면 전부 구현해서 쓸수 없으니까 여러가지 디펜던시를 설정해서 다양한 외부라이브러리들을 사용하게 된다. 하지만 그 라이브러리들 또한 다양한 외부 라이브러리들을 사용하게되고 한프로젝트 내에 다양한 모듈 그리고 다양한 라이브러리들을 사용하다보면 서로 버전이 안맞게 되고 guava 같이 하위버전 호환을 잘 안 해주지만 엄청나게 많은 라이브러리에서 사용하고 있는 애들이 간혹있다. compile 말고 implementation 를 사용하면 좀 더 버전을 깔끔하게 할 수 있지만 오억개의 라이브러리를 디펜던시하고있는 라이브러리를 사용할땐 여간 불편한게 아니다. 최근에 netty 관련 라.. 이전 1 2 3 4 5 6 7 다음