Maximize Your Potential

Developer Study

기술 면접 준비 가이드: 자주 묻는 질문 및 답변

maxworld 2024. 9. 22. 12:39
728x90

기술 면접 준비 가이드: 자주 묻는 질문 및 답변

기술 면접 준비 가이드: 자주 묻는 질문 및 답변

개발자라면 누구나 경험하는 중요한 순간, 바로 기술 면접입니다. 이 과정은 코딩 실력뿐 아니라 컴퓨터 공학 기초, 데이터베이스, 네트워크, 시스템 구조 등에 대한 깊이 있는 이해가 요구됩니다. 이번 포스팅에서는 기술 면접에서 자주 묻는 질문들과 그에 대한 답변을 정리해보았습니다. 이 글을 통해 면접 준비에 도움이 되길 바랍니다.

1. 데이터베이스(DB) 관련 질문

Q. 데이터베이스의 종류에는 어떤 것들이 있나요?

A. 데이터베이스는 정보를 저장하고 관리하는 시스템으로, 크게 관계형 데이터베이스(RDBMS)와 비관계형 데이터베이스(NoSQL)로 나눌 수 있습니다.

  • 관계형 데이터베이스(RDBMS): 데이터를 테이블 형태로 저장하고, 이를 관계(키)로 관리합니다. 예: MySQL, PostgreSQL.
  • 비관계형 데이터베이스(NoSQL): 테이블 형태가 아닌 다양한 데이터 모델을 사용합니다. 예: MongoDB, Cassandra.

Q. 캐싱이란 무엇인가요?

A. 캐싱(Cache)은 자주 사용하는 데이터를 임시로 저장해 두고 빠르게 접근할 수 있도록 하여, 데이터베이스 조회 시간과 시스템 응답 시간을 줄여 성능을 높이는 기술입니다. 예를 들어, 메모리에 데이터를 저장하여 빠른 속도로 읽어오는 것이 그 대표적인 사례입니다.

Q. 트랜잭션이란 무엇인가요?

A. 트랜잭션(Transaction)은 데이터베이스에서 하나의 작업 단위를 의미하며, 작업이 모두 성공하거나 모두 실패해야 하는 일련의 연산입니다. 트랜잭션은 ACID 속성을 만족해야 합니다:

  • 원자성(Atomicity): 트랜잭션은 모두 실행되거나 전혀 실행되지 않아야 한다.
  • 일관성(Consistency): 트랜잭션 수행 후 데이터베이스가 일관된 상태여야 한다.
  • 고립성(Isolation): 트랜잭션이 독립적으로 수행되어야 한다.
  • 지속성(Durability): 트랜잭션 완료 후 결과는 영구적으로 반영되어야 한다.

2. 컴퓨터 구조(CS) 관련 질문

Q. 프로세스와 스레드의 차이는 무엇인가요?

A. 프로세스(Process)는 운영체제에서 실행 중인 프로그램의 인스턴스입니다. 각 프로세스는 독립적인 메모리 공간을 가지고 있습니다. 반면, 스레드(Thread)는 프로세스 내에서 실행되는 작업의 단위이며, 같은 프로세스 내의 스레드끼리는 메모리를 공유합니다. 따라서 스레드 간의 통신이 빠르지만, 잘못된 동기화로 인해 경쟁 상태(Race Condition)가 발생할 수 있습니다.

Q. 힙 메모리와 스택 메모리의 차이는 무엇인가요?

A. 힙(Heap)과 스택(Stack)은 모두 메모리 할당 방식입니다.

  • 스택: 함수 호출 시 할당되며, 함수가 종료되면 자동으로 메모리가 해제됩니다. 빠른 메모리 접근이 가능하지만, 크기가 제한적입니다.
  • 힙: 프로그래머가 직접 메모리를 할당하고 해제해야 합니다. 동적 메모리 할당이 가능하지만, 속도는 스택보다 느립니다.

3. 자료구조와 알고리즘

Q. 자료구조에는 어떤 것들이 있나요?

A. 자료구조는 데이터를 효율적으로 저장하고 관리하기 위한 방법입니다. 주요 자료구조에는 다음이 있습니다:

  • 배열(Array): 연속된 메모리 공간에 데이터를 저장합니다.
  • 연결 리스트(Linked List): 노드들이 포인터로 연결된 구조입니다.
  • 스택(Stack): LIFO(Last In, First Out) 방식으로 작동합니다.
  • 큐(Queue): FIFO(First In, First Out) 방식으로 작동합니다.
  • 해시 테이블(Hash Table): 키-값 쌍을 저장하며, 빠른 검색을 위해 해시 함수를 사용합니다.
  • 이진 탐색 트리(Binary Search Tree): 노드를 왼쪽 자식과 오른쪽 자식으로 구분하여 데이터를 정렬된 형태로 저장합니다.

Q. 연결 리스트와 배열의 차이는 무엇인가요?

A. 배열은 메모리에 연속적으로 할당되며, 크기가 고정되어 있어 데이터 크기를 변경하기 어렵습니다. 반면, 연결 리스트는 비연속적인 메모리 할당을 통해 각 노드가 포인터로 연결되어 있습니다. 이 때문에 연결 리스트는 동적으로 크기를 조정할 수 있으며, 삽입과 삭제가 빠릅니다.

  • 배열: 인덱스를 통한 접근은 O(1) 시간 복잡도를 가지지만, 삽입/삭제는 O(n)의 시간이 소요될 수 있습니다.
  • 연결 리스트: 순차적으로 탐색해야 하므로 접근 시간은 O(n)이지만, 삽입/삭제는 O(1) 시간 복잡도를 가집니다.

Q. DFS와 BFS란 무엇인가요?

A. DFS(Depth-First Search)와 BFS(Breadth-First Search)는 그래프나 트리 구조에서 노드를 탐색하는 알고리즘입니다.

  • DFS: 깊이 우선 탐색으로, 가능한 깊게 탐색하다가 더 이상 갈 곳이 없으면 다시 돌아와 다른 경로를 탐색합니다. 주로 재귀를 사용하여 구현합니다.
  • BFS: 너비 우선 탐색으로, 현재 노드에 인접한 모든 노드를 우선 탐색한 후, 그다음 깊이의 노드를 탐색합니다. 주로 큐를 사용하여 구현합니다.

4. 웹 개발 관련 질문

Q. HTTP 메서드에는 어떤 것들이 있나요?

A. HTTP 메서드는 클라이언트가 서버에게 요청할 때 사용하는 방식입니다.

  • GET: 데이터를 요청할 때 사용합니다.
  • POST: 새로운 데이터를 서버에 전송할 때 사용합니다.
  • PUT: 데이터를 업데이트할 때 사용합니다.
  • DELETE: 데이터를 삭제할 때 사용합니다.

Q. 세션(Session)과 쿠키(Cookie)의 차이는 무엇인가요?

A. 쿠키는 클라이언트 측에 저장되는 작은 데이터로, 사용자의 상태를 유지합니다. 반면, 세션은 서버 측에서 관리되며, 클라이언트는 쿠키를 통해 세션 ID를 서버에 전달해 사용자 상태를 유지합니다.

5. 서버 및 기타

Q. CI/CD란 무엇인가요?

A. CI(Continuous Integration)는 개발 과정에서 코드 변경 사항을 주기적으로 통합하는 과정입니다. CD(Continuous Delivery/Deployment)는 통합된 코드를 자동으로 테스트하고 배포하는 과정입니다. 이를 통해 개발 속도를 높이고, 소프트웨어 품질을 향상시킬 수 있습니다.

Q. Docker를 사용해보셨나요?

A. Docker는 애플리케이션을 격리된 컨테이너에서 실행할 수 있도록 하는 가상화 도구입니다. 이를 통해 일관된 개발 환경을 제공하고, 리소스 사용을 최적화할 수 있습니다.