[Clean Code][TIL] 단위 테스트
이 포스트는 로버트 C.마틴의 Clean Code 속 9장(154p ~ 169p) 내용에 대한 정리입니다. “테스트 코드는 실제 코드만큼이나 프로젝트 건강에 중요하다.” (9장 168p) TDD 법칙 세 가지 실패하는 단위 테스트를 작성할 때까지 실제 코드를 작성하지 않는다. 컴파일은 실패하지 않으면서 실행이 실패하는 정도로만 ...
이 포스트는 로버트 C.마틴의 Clean Code 속 9장(154p ~ 169p) 내용에 대한 정리입니다. “테스트 코드는 실제 코드만큼이나 프로젝트 건강에 중요하다.” (9장 168p) TDD 법칙 세 가지 실패하는 단위 테스트를 작성할 때까지 실제 코드를 작성하지 않는다. 컴파일은 실패하지 않으면서 실행이 실패하는 정도로만 ...
통신을 위해 소켓을 만들고 서버에서 bind와 listen 을 실행하고 클라이언트는 connect 를 실행한 하면 서버와 클라이언트는 간단한 패킷을 주고 받을 준비가 됬다고 할 수 있습니다. 패킷(packet)이란 정보 기술에서 패킷 방식의 컴퓨터 네트워크가 전달하는 데이터의 형식화된 블록입니다. 즉, 컴퓨터가 네트워크에서 데이터를 주고 받을 때 ...
통신을 위해 소켓을 만들고 서버에서 bind와 listen 을 실행하고 클라이언트는 connect 를 실행한 하면 서버와 클라이언트는 간단한 패킷을 주고 받을 준비가 됬다고 할 수 있습니다. 패킷(packet)이란 정보 기술에서 패킷 방식의 컴퓨터 네트워크가 전달하는 데이터의 형식화된 블록입니다. 즉, 컴퓨터가 네트워크에서 데이터를 주고 받을 때 ...
이 포스트는 로버트 C.마틴의 Clean Code 속 7장(130p ~ 142p) 내용에 대한 정리입니다. “깨끗한 코드는 읽기도 좋아야 하지만 안정성도 높아야 한다.” (7장 142p) 오류를 막기 위한 예외 처리 try-catch 코드를 작성하다 보면 OutOfBounds, NullPointerException 등 여러 오류가 발생합...
문제 제약 확인 시간 제한이 0.5초 이므로 50’000’000 번 이내 연산으로 결과를 출력해야 합니다. 입력 크기가 \(10^6\) 이므로 만약 \(O(N^2)\) 인 경우 100’000’000’000 가 되므로 시간 복잡도가 \(O(N)\) 가 보장되는 알고리즘이 필요합니다. 알고리즘 선택하기 최소 횟수 라는 키워드로 최단 경로 ...
문제 제약 확인 시간 제한이 0.5초 이므로 50’000’000 번 이내 연산으로 결과를 출력해야 합니다. 입력 크기가 \(10^6\) 이므로 만약 \(O(N^2)\) 인 경우 100’000’000’000 가 되므로 시간 복잡도가 \(O(N)\) 가 보장되는 알고리즘이 필요합니다. 알고리즘 선택하기 최소 횟수 라는 키워드로 최단 경로 ...
Clean Code를 읽으면서 작성 했던 프로젝트를 수정하던 중 쓰레드가 전역 함수를 받고 함수 내부에서 전역 변수에 접근하는 것을 보고서 전역으로 사용할 필요가 없는 변수와 함수를 클래스에 담아 쓰레드에서 실행할 수 있도록 수정하고자 하였습니다. 쓰레드가 클래스를 담도록 쓰레드의 생성자를 확인하던 중 생성자가 실행할 전역 함수만 전달받는 것이 아...
이 포스트는 로버트 C.마틴의 Clean Code 속 6장(118p ~ 128p) 내용에 대한 정리입니다. “새로운 자료 타입을 추가하는 유연성이 필요하면 객체가 더 적합하다. 다른 경우로 새로운 동작을 추가하는 유연성이 필요하면 자료구조와 절차적인 코드가 더 적합하다.” (6장 128p) 자료의 추상화 자료를 표현할 때, 자료 구조를 ...
이 포스트는 로버트 C.마틴의 Clean Code 속 5장(96p ~ 116p) 내용에 대한 후기입니다. “좋은 소프트웨어 시스템은 읽기 쉬운 문서로 이뤄진다.” (5장 114p) 형식을 맞추는 목적 코드를 작성하면서 돌아가는 코드 뿐만 아니라 코드 작성 형식까지 고려해야할까요? 형식의 필요성을 확인하기 위해 내용이 같지만 형식이 다른 ...
이것이 취업을 위한 코딩 테스트다 with 파이썬 (나동빈 저) 를 참고해 작성한 포스트입니다. 가장 빨리 도달하는 방법 최단 경로 알고리즘은 이름 그대로 목적지까지 가장 짧은 경로를 찾는 알고리즘입니다. 최단 경로 유형의 문제로는 “한 지점에서 특정 지점까지의 최단 경로를 구해야 하는 경우”, “모든 지점에서 다른 모든 지점까지의 모두 최단...