이끌든지 따르든지 비키든지

분류 전체보기 67

[Git] 좋은 Commit Message

코드 작성에 Code Convention이 있듯이, 깃 커밋 메시지에도 Commit Message Convention과 규칙이 존재하는데, 이 내용을 정리해봤다. Commit Message Convention 커밋 메시지는 제목, 본문, 꼬리말로 구성하고, 각 항목에는 아래의 내용을 작성한다. (※ 중요 : 항목 간의 구분은 한 줄 공백으로!) 제목 : [Commit Type]: [Commit Message][#Issue Number] 내가 코드를 작성한 의도와 짧은 요약을 작성한다. 내 의도를 type으로 명시하고, 내용은 명령조로 작성한다. (마침표는 쓰지 않음! / 영문으로 작성하는 경우 50자 이내, 첫 글자는 대문자로) ■ Commit Type · feat : 기능 추가 · fix : 버그 수정..

Framework 2023.10.16

[정보처리기사] 디자인 패턴

디자인 패턴이란? 소프트웨어 디자인 과정에서 자주 발생하는 문제들을 해결하기 위해 맞춤화할 수 있는 미리 만들어진 청사진(템플릿) 디자인 패턴의 분류 생성 패턴들은 기존 코드의 재활용과 유연성을 증가시키는 객체 생성 메커니즘들을 제공 구조 패턴은 구조를 유연하고 효율적으로 유지하면서 객체와 클래스를 더 큰 구조로 조합하는 방법을 설명 행위 패턴은 객체 간의 효과적인 의사소통과 책임 할당을 처리 생성 패턴의 종류 싱글턴 패턴(Singleton Pattern) 특정 클래스에 객체 인스턴스가 하나만 만들어지도록 해주는 패턴 추상 팩토리 패턴(Abstract Factory Pattern) 구상 클래스에 의존하지 않고도 서로 연관되거나 의존적인 객체로 이루어진 제품군을 생산하는 인터페이스를 제공 팩토리 메소드 패..

[JavaScript] 모듈 (import / export)

모듈이란? 코드의 일부를 논리적으로 분리하고 구조화할 때, 각각 분리된 단위를 모듈(Module)이라 한다. 모듈화가 필요한 이유 코드의 재사용 : 비슷한 기능이나 관련된 기능들을 모듈로 분리하여 필요한 곳에서 재사용할 수 있다. 코드의 구조화 : 프로그램을 여러 개의 독립적인 모듈로 나누어 각 모듈이 특정 역할을 담당하도록 분리함으로써 코드의 구조를 개선하고 유지보수를 용이하게 한다. 네임스페이스 관리 : 모듈을 사용함으로써 전역 네임스페이스 충돌을 방지하고 각 모듈에서 정의한 변수, 함수, 객체 등을 별도의 네임스페이스로 유지할 수 있다. 코드의 숨김 : 필요한 기능을 외부에 노출시키지 않고 private하게 유지하여 정보 은닉과 캡슐화를 구현할 수 있다. 모듈 export 모듈을 내보내는 방법은 e..

[TypeScript] 타입 추론 & 타입 단언 & 타입 가드

타입 추론(Type Inference) 타입스크립트는 코드를 작성할 때 변수, 함수, 매개변수 및 반환값 등에 명시적으로 타입을 선언할 수 있다. 그러나 타입을 명시적으로 선언하지 않아도 컴파일러가 코드를 분석하고 타입을 추론할 수 있는데, 이를 타입 추론이라고 한다. function add(a: number, b: number) { return a + b; } const result = add(10, 20); // result가 number 타입일 것으로 추론한다. 예를 들어, 위 코드는 매개변수 a와 b가 number 타입임을 명시했으므로, 컴파일러는 이를 바탕으로 result가 number 타입일 것으로 추론한다. const user = { name: 'John Doe', age: 30, }; co..

[JAVA] Annotation

Java는 어노테이션(Annotation)이라는 프로그램의 코드에 메타데이터를 추가하는 특별한 형태의 주석을 제공한다. 이 단어의 사전적 의미도 말 그대로 '주석'이다. 자바에서 주석은 // 로 시작하는 거 아니었나요? 둘 다 주석이 맞다. 둘의 차이점은, // 로 시작하는 주석(Comment)은 개발자에게 코드 설명 등 정보를 제공하고, @ 로 시작하는 어노테이션(Annotation)은 프로그램, 컴파일러 등 에게 추가 정보를 제공한다. 주로 사용되는 표준 어노테이션 중 몇 가지를 살펴보자면, @Override 메서드 선언부에 작성해 해당 메서드가 오버라이드되었음을 알리는 어노테이션이다. 컴파일러는 @Override가 붙은 메서드의 오버라이드가 올바르게 이루어졌는지를 검사하고, 잘못된 부분(리턴 타입이..

[TypeScript] TypeScript란?

JavaScript는 동적 타입 언어로, 변수의 타입을 런타임(실행) 때에 결정한다. 이 덕분에 유연한 개발이 가능하지만, 실행 시까지 오류나 버그를 찾기 어렵고, 코드가 늘어날수록 팀원 간 협업도 어려워진다. TypeScript는 이러한 자바스크립트의 단점을 보완하기 위해, 코드 작성 때 객체에 타입을 명시할 수 있도록 하고, 컴파일 환경을 제공하여 코드를 작성하는 동안 문법 오류 등 에러를 확인하고 수정할 수 있다. TypeScript로 작성한 코드는 .ts 확장자를 가진 파일로 저장되고, 실행하면 타입스크립트 컴파일러(tsc)가 이를 자바스크립트 파일로 컴파일해 node.js나 브라우저에서 실행된다. .js 파일로 컴파일하면서 타입 검사와 문법 오류 등을 검사할 수 있고, Vanilla JS 환경에..

[프로그래머스] 광물 캐기 - JAVA

프로그래머스 코딩 테스트 연습 문제 - 광물 캐기 / JAVA 풀이 정리 https://school.programmers.co.kr/learn/courses/30/lessons/172927 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 알고리즘 광물을 5개 단위로 묶고, 묶음마다 대해 돌을 가장 효율적으로 캘 수 있는 곡괭이를 선택한다. 돌을 가장 많이 캘 수 있는 곡괭이부터 사용하여 광물을 캐고, 해당 곡괭이의 사용 횟수를 감소시킨다. 위 과정을 곡괭이 사용 횟수를 소진할 때까지 반복한다. (광물이 5개 단위인 이유 : 한 번 곡괭이를 사용하면 소진될 ..

[프로그래머스] 숫자 짝꿍 - JAVA

프로그래머스 코딩 테스트 연습 문제 - 숫자 짝꿍 / JAVA 풀이 정리 https://school.programmers.co.kr/learn/courses/30/lessons/131128 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 방법 for (char digit : X.toCharArray()) { countX[digit - '0']++; } for (char digit : Y.toCharArray()) { countY[digit - '0']++; } 입력된 문자열 X, Y를 순회하면서 등장하는 숫자의 횟수를 세어 배열에 저장한다. for (..

[프로그래머스] 도둑질 - JAVA

프로그래머스 코딩 테스트 연습 문제 - 도둑질 / JAVA 풀이 정리 https://school.programmers.co.kr/learn/courses/30/lessons/42897 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 방법 이 문제는 동적 계획법(Bottom-Up)을 사용해 풀이하는데, 최대한 많은 돈을 훔치며 도둑질하기라는 전체 문제를 도둑질을 첫 번째 집부터 시작하기 도둑질을 두번째 집부터 시작하기 두 가지의 부분 문제로 나누어 해결한다. 코드 풀이 ▶ 첫번째 집을 터는 경우 // 첫번째 집을 털 경우 dp1[0] = money[0]..

[알고리즘] 동적 계획법(Dynamic Programming)

동적 계획법(Dynamic Programming)이란? 큰 문제를 여러 개의 부분 문제로 나누어 이를 해결하고, 그 결과를 저장하여 다시 큰 문제를 해결할 때 사용하는 문제해결방법이다. ■ 분할 · 정복(Divide & Conquer) 알고리즘이랑 비슷한데? 큰 문제를 여러 부분 문제로 나눈다는 점에서 분할 정복 알고리즘과 유사하다. 하지만, 이 두 방법 간에 가장 큰 차이점은 부분 문제의 중복 여부이다. 분할 · 정복 알고리즘은 부분 문제들 간에 중복이 없고 각각의 부분 문제는 독립적이지만, 동적 계획법에서 부분 문제 간에 중복이 존재하고, 해결한 부분 문제의 정답을 저장(Memoization)해 두었다 재활용해 문제를 해결한다. 동적 계획법의 사용 조건 1. 중복된 부분 문제 (Overlapping ..