SOLID 원칙
·
CS
SRP 단일 책임 원칙한 클래스는 하나의 책임만 가져야 한다.중요한 판단 기준은 변경. 변경이 있을 때 파급효과가 적어야 한다.객체의 생성과 사용을 분리클래스 하나에 너무 많은 것을 집어 넣지 말자. 문제가 발생했을 때 유지보수가 편리하게.. (한 변경에서 다른 책임의 변경으로의 연쇄작용은 최악) OCP 개방 폐쇄 원칙 ✦소프트웨어 요소는 확장에는 열려있어야 하며, 변경에는 닫혀있어야 한다.확장에 열려있다? 새로운 변경사항이 발생했을 때 유연하게 코드를 추가, 수정변경에 닫혀있다? 객체를 직접 수정하지 않고도 변경사항을 적용다형성을 활용자동차, 공연 배우 예시를 생각역할과 구현을 분리문제점구현 객체를 변경하려면 클라이언트 코드를 변경해야 한다.따라서, 객체 생성과 연관 관계를 맺어주는 별도의 조립, 설정..
LRU 알고리즘을 LinkedHashMap을 이용해 구현하기
·
CS
서론지난 게시글(LRU 알고리즘 파헤치기)로 LRU 알고리즘에 대해 OS와 HW 관점에서 알아봤습니다. 이번에는 Java를 이용해 이것을 구현하려면 어떻게 해야 할지 알아보고자 합니다. Java의 `LinkedHashMap`을 이용하면 편리하게 구현할 수 있습니다. LinkedHashMap?Hash table and linked list implementation of the Map interface, with predictable iteration order. This implementation differs from HashMap in that it maintains a doubly-linked list running through all of its entries. This linked list d..
LRU 알고리즘 파헤치기
·
CS
LRU페이지 교체 알고리즘 중에 하나로, Least Recently Used의 약자입니다. 즉, 가장 최근에 사용되지 않았던 것을 찾는 알고리즘입니다. 사실 페이지 교체를 위한 Optimal solution(가장 오랫동안 사용되지 않을 것을 선택하는 것)은 이론적인 방법이기 때문에 그것을 위한 근사 방법 중 하나입니다. 페이지 교체와 관련된 내용은 추후에 다뤄보고 여기서는 LRU에 대해서만 이야기하고자 합니다. LRU를 JAVA를 이용해 구현한 내용은 이 게시글을 참조하세요.   Implementing LRULRU 알고리즘을 구현하기 위해서는 다음과 같은 방식이 있습니다. Counter가장 단순하게 떠올릴 수 있는 방법 중 하나로, `clock register`를 이용하는 방식입니다. (모든 메모리 참조..
HTTPS, SSL를 쉽게 알아보자 (천천히 읽으면 누구나 이해가능한,)
·
CS
🔐 HTTPS 그게 뭔데?S는 secure의 약자왜 HTTPS를 사용함?서버에 보내는 정보를 제 3자가 볼 수 없게 (비밀번호 같은거 서버로 보낼 때 가로채면 아찔)사이트가 진품인지, 즉 신뢰할 수 있는 사이트인지 검증 (기관으로 부터 검증된 사이트만 HTTPS 사용이 허가됨)암호화 방식대칭키 방식: 하나의 키를 가지고 암호화, 복호화문제점: 결국 한 번은 한 쪽에서 다른 쪽으로 대칭키를 전송해야하는데.. 대칭키를 해킹 당하면 말짱 도루묵비대칭키(공개키) 방식: 공개키로 암호화, 비공개키로 복호화 가능.비대칭키(공개키)대칭키의 문제점 때문에 비대칭키 방식을 사용하는 건 알겠어.그러면 비공개키가 클라이언트에 있어야 하는데, 네이버가 우리에게 준 공개키가 정품인지 확인..
Elastic Stack: Elasticsearch, Kibana, Beats, Logstash
·
CS
Elasticsearch 엘라스틱서치는 모든 요청과 응답을 REST API 형태로 제공한다. 키바나 콘솔 사용법 Management -> Dev Tools 손쉽게 엘라스틱서치와 REST API로 통신할 수 있음 인덱스 : 도큐먼트를 저장하는 논리적 구분자 특정 도큐먼트 개수에 도달하거나 특정 용량을 넘어서면 인덱스를 분리 ex) 날짜/시간 단위로 인덱스를 분리하면 특정 날짜의 데이터를 쉽게 처리 도큐먼트 : 실제 데이터를 저장하는 단위 클러스터 내부 구조 하나의 프로젝트에서 하나의 클러스터를 생성 클러스터 내부는 여러 개의 인덱스를 생성 인덱스 내부에는 JSON 형태로 된 다수의 도큐먼트가 존재 다수의 도큐먼트는 복수의 필드를 가짐 실행 확인 8.0.1 버전부터 자동 보안 설정이 되어 있어서 다음과 같이..
influxDB란
·
CS
개요 시계열 데이터 현재 우리가 살아가는 환경에서는 시계열 데이터가 폭발적으로 존재한다. 여기서 말하는 시계열 데이터란, 다음의 특징을 가진다. 시간별로 구성된 값들의 집합 시간과 하나 이상의 속성으로 구성 Line diagram으로 시각화할 수 있다. 시계열 데이터를 분석하기 위해 많은 기업들이 노력을 한다. 1s는 물론 1ns 또는 그 이하의 아주 짧은 시간 동안 생성되는 수많은 데이터를 분석하여 경향, 주기 등의 특성을 파악할 수 있다. 시계열 데이터베이스 시간 처리에 최적화 된 데이터베이스 SQL 기반 시계열 질의 지원 빠른 데이터 입력 → 트랜잭션 지원 및 데이터 변경 불가 롤업 기능 지원 시계열 데이터베이스의 종류 InfluxDB Kdb+ Graphite 등이 존재하고, influxDB가 현재..
테스트 주도 개발(TDD) 실전 스킬 웨비나 (라이엇 게임즈)
·
CS
Why Software Test사례 1. 737 맥스 보잉사기체의 속도가 떨어지면 강제로 아래로 맞춰주는 소프트웨어가 있었다. 하지만, 센서가 오동작했을 때의 대비책을 만들어지지 않아 소프트웨어가 강제로 아래로 내리는 바람에 충돌하는 사고가 있었다. 예외적인 부분에 대해 모든 것을 테스트했어야 하는데, 이를 고려하지 않고 갔기에 발생한 사건이다. 잘못된 소프트웨어 하나가 인명 피해까지 발생시킨다. Cost to fix a defect 테스트에 대한 중요도는 나날이 증가했고, 이제는 거의 필수적이다. 얼마나 빨리 이것에 공감하고 여러분의 코드에 얼마나 큰 영향을 미치는지 이해하게 된다면, 여러분들의 가치는 달라지게 된다. 신입 사원 인터뷰에도 중요한 문제로 불린다. What is Sof..
Machine Learning Basic
·
CS
Machine Learning 일종의 소프트웨어이다. Limitations of explicit programming. (e.g. spam filter, automatic driving) 개발자가 일일이 어떻게 하는지 정하지 않고, 프로그램 자체가 스스로 학습해서 동작하는 방식 supervised/unsupervised learning 학습을 위해서 데이터가 미리 주어져야 한다. 학습하는 방법에 따라 supervised/unsupervised learning로 나뉜다. supervised learning: learning with labeled examples (= training set) unsupervised learning: un-labeled data (e.g. google news groupin..
squareyun
'CS' 카테고리의 글 목록