[Network] IP Class
2022. 12. 9. 15:53
컴퓨터 과학/네트워크
네트워크 클래스의 등장 배경 우리는 이제껏 IPv4 체계의 IP 주소를 사용해 왔기 때문에 이미 인프라가 IPv4 환경으로 구축되어 있습니다. 따라서 이미 구성된 인프라를 최대한 활용하기 위해서 IPv4 체계의 IP 주소를 사용하는 네트워크의 규모에 따라 관리하기 쉽도록 클래스라는 이름으로 나누기 시작했습니다. 이는 네트워크 클래스의 등장으로 이어졌습니다. 네트워크 클래스란? 네트워크 클래스는 IPv4 네트워크를 규모에 맞게 잘 사용하기 위해 등장한 개념입니다. IP 주소에서 어떻게 네트워크 주소와 호스트 주소를 구분할 수 있을까? -> 클래스를 이용해 네트워크 주소와 호스트 주소를 구분할 수 있다. 예시) 203.240.100.1 203.240.100.1 IP 가 C 클래스이기 때문에 204.240.1..
[Network] IP 주소
2022. 12. 9. 14:57
컴퓨터 과학/네트워크
IP 주소란? IP 주소 : 네트워크 환경에서 컴퓨터 간 데이터를 주고받기 위해 각 컴퓨터에 부여된 네트워크 상 주소 각기 떨어져 있는 컴퓨터들이 데이터를 주고받기 위해서는 각 컴퓨터들의 주소가 존재해야 합니다. 그 주소가 바로 IP 주소입니다. IP 주소는 네트워크 주소 + 호스트 주소로 구분됩니다. 네트워크 주소는 인터넷 상에서 네트워크를 구분하는 역할을 하고, 호스트 주소는 특정 네트워크 안에 존재하는 기기들을 구분하는 역할을 합니다. IP와 IP 주소의 차이 우리는 흔히들 IP 주소와 IP 를 동일한 개념으로 사용하는 경우가 많은데요. 사실 차이가 있으니 이에 주의해서 사용해야 합니다. IP : 프로토콜 IP 주소 : 인터넷 상에서 데이터를 주고받을 때 사용되는 각 컴퓨터들의 주소 IP 주소 부여..
큐(Queue)
2022. 11. 11. 13:08
컴퓨터 과학/자료구조
큐(Queue) - FIFO(First In First Out) 으로 데이터를 저장하는 구조입니다. - 먼저 들어온 데이터가 먼저 나갑니다. - 주요 동작 : enqueue, dequeue, peekFront - enqueue(데이터) : 큐에 데이터 추가 - dequeue( ) : 큐의 가장 앞에 있는 데이터 제거 후 반환 - peekFront : 큐의 가장 앞에 있는 데이터 반환 JavaScript 로 Queue 구현(feat.Linked List) dequeue 메서드 구현 시 array 가 제공하는 shift() 메서드를 사용하면 간단하게 구현 가능하겠지만, shift() 메서드는 시간 복잡도가 O(n) 이므로 Queue 구현에 적합하지 않습니다. 시간 복잡도를 O(1)으로 하기 위해 연결 리스트..
스택(Stack)
2022. 11. 11. 12:42
컴퓨터 과학/자료구조
스택(Stack) - LIFO(Last In First Out) 으로 데이터를 저장하는 구조입니다. - 나중에 들어온 데이터가 먼저 나갑니다. - 주요 동작으로는 push, pop, peek 등이 있습니다. - push(데이터) : 스택에 데이터 추가 - pop() : 스택으로부터 최상단에 있는 데이터 제거 - peek() : 스택 최상단에 있는 데이터 값 반환 JavaScript 로 스택 구현(feat. Array) class Stack { constructor() { // item들을 받을 배열 생성 this.stack = []; } isEmpty() { return this.stack.length == 0; } push(item) { this.stack.push(item); } pop() { ret..
ADT 와 Data Structure 의 차이
2022. 11. 11. 11:52
컴퓨터 과학/자료구조
ADT - Abstract Data Type 의 약자로 추상화된 데이터 타입이라는 의미를 가지고 있습니다. - 가령 이 데이터 타입은 어떤 속성과 어떤 메서드를 가지고 있는지, 그리고 이 메서드는 무엇을 하는 건지 정의만 합니다. - 실제로 이 데이터 타입이 내부적으로 어떤 자료 구조로 구현되어 있고 어떻게 동작하는지에 대해서는 논의하지 않습니다. - 정의, 구현을 분리하면 사용자는 굳이 어떻게 구현되어 있는지 알 필요 없이 데이터 타입을 사용하는데 아무런 문제가 없습니다. - 그저 사용자는 ADT에서 정의된 기능을 사용하기만 하면 되고 구현은 개발자가 알아서 하면 됩니다. - 설사 데이터 타입의 구현 방법이 바뀌더라도 정의만 그대로라면 기존 사용자는 아무런 변경 없이 동일하게 데이터 타입을 사용할 수 ..
자료구조의 구분
2022. 11. 8. 13:39
컴퓨터 과학/자료구조
자료구조는 크게 선형 자료 구조와 비선형 자료 구조로 구분할 수 있습니다. 선형 자료 구조 선형 자료 구조는 요소가 일렬로 나열되어 있는 자료 구조입니다. 선형 자료 구조로는 연결 리스트, 배열, 벡터, 스택, 큐 등이 있습니다. 비선형 자료 구조 비선형 자료 구조는 일렬로 나열하지 않고 자료 순서나 관계가 복잡한 자료 구조입니다. 비선형 자료 구조로는 그래프, 트리, 힙, 우선순위 큐, 맵, 셋, 해시 테이블 등이 있습니다. 앞으로 하나씩 공부하며 포스팅할 계획입니다. 참조 면접을 위한 CS 전공지식 노트 chapter 5 자료구조
트랜잭션의 연산 중 COMMIT의 개념을 간략히 설명해주세요.
2022. 8. 6. 15:57
컴퓨터 과학/데이터베이스
COMMIT이란? 트랜잭션의 연산 중의 하나이다. 저장되지 않은 모든 데이터를 데이터베이스에 저장하고 현재의 트랜잭션을 종료하는 명령이다. COMMIT 명령이 실행되기 이전 작업 과정에서 오류가 생긴다면, ROLLBACK 명령을 통해 원상태로 되돌릴 수 있다. 정리 COMMIT은 트랜잭션의 연산 중의 하나이며, 저장되지 않은 모든 데이터를 데이터베이스에 저장하고 현재의 트랜잭션을 종료하는 명령이다. COMMIT 명령 실행 후 데이터를 이전 상태로 되돌릴 수 없다.