전체 글
-
Thread ( + pthread)컴퓨터 구조 2021. 1. 23. 00:28
Process "메모리에 적재되어 실행중인 프로그램" 사용자의 프로그램이 OS에 의해 메모리 공간을 할당받아 실행 중인 것을 말한다. 프로세스는 프로그램에 사용되는 데이터와 메모리자원 그리고 thread로 구성된다. 하드디스크의 프로그램을 실행하면, 프로그램 실행을 위해 메모리 할당이 이루어진다. 할당된 메모리 공간에 바이너리 코드가 올라가며 프로세스가 실행된다. Thread 프로세스는 스레드라고 하는 실행 유닛으로 구성되어 있다. 모든 프로세스에서 한 개 이상의 스레드가 존재하고 스레드가 작업을 수행한다. 스레드는 서로 code, data, heap영역을 공유하고 stack영역을 별도로 사용한다. 따라서, 별도의 process를 실행시키는 것 보다 데이터 공유를 쉽게 할 수 있고 효율적이다. Pthre..
-
JUNGLE_5주차SW사관학교 Jungle 2021. 1. 20. 21:22
주차별 키워드 - B tree & B plus tree 더 고민해볼 키워드 - pointer pointer와 malloc에 대해 익숙해질 수 있었던 한 주 였다. SW사관학교 정글 WEEK04 시험 B Plus Tree [입력] 삽입 – key, data 삭제 – key [출력] → 채점 시 함수를 다 같이 만들 예정 내부 노드 – key만 출력 리프 노드 – key와 data 모두 출력 [기준] 노드에 존재할 수 있는 키의 최대 개수는 3개이다. 부모의 키 값과 같은 값은 왼쪽 서브 트리에 위치한다. 트리의 리프 노드에 존재하는 키들은 오름차순 정렬한다. 삭제하고자 하는 키는 무조건 트리 내에 존재한다. 삽입하고자 하는 키는 무조건 트리 내에 존재하지 않는다. Top-Down 방식(Introductio..
-
pointer & memory segment컴퓨터 구조 2021. 1. 18. 01:39
Pointer (feat. char) char* a = "hello";로 a가 "hello"의 시작점을 가리키게 하고, *a = 'H'를 통해 "hello"를 "Hello"로 바꾸려는 시도를 해보았다. 하지만, 컴파일 결과 우리가 원하던 "Hello"가 제대로 반환되지 않고, 오류가 발생했다. Code #include #include int main() { char* a = "hello"; *a = 'H'; printf("%c", *a); } 위의 코드에서 hello가 변경이 되지 않은 채 프로그램이 종료되는 것이 아니라 왜 오류가 발생하는지가 의문이었다. 여기저기 찾아보던 중 microchip-'How do i copy char b[] to the content of char* a variable?'c..
-
B-Tree - 삭제컴퓨터 구조 2021. 1. 18. 01:38
B-Tree - 삭제 B Tree 삽입에서 가득 찬 노드들을 미리 분할했던 것 처럼, 삭제시에도 최소 키의 개수를 가지는 노드들이 키를 더 많이 가질 수 있도록 미리 처리한다. k를 찾아 재귀적으로 내려가는 과정에서 방문하는 경로에 존재하는 키의 개수가 (t-1)인 경우 형제 노드에서 키를 가져오거나, 형제노드와 병합하는 과정을 거친다. 삭제 과정에서 발생할 수 있는 모든 경우의 수에 대해 알아보자. 1. 리프 노드 x를 방문했을 때, x 내에 k가 존재한다. 2. 리프 노드가 아닌 노드 x를 방문했을 때, x 내에 k가 존재한다. 3. 리프 노드가 아닌 노드 x를 방문했을 때, x 내에 k가 존재하지 않는다. 1. 리프 노드 x를 방문했을 때, x 내에 k가 존재한다. 리프 노드 x 내에 k가 존재한다..
-
1월 중순 되돌아보기Life 2021. 1. 15. 02:09
되돌아보기 list 더보기 10월 되돌아보기 11월 되돌아보기 12월 중순 되돌아보기 12월 말 되돌아보기 1월 중순 되돌아보기 2주가 정말 길었다. 1월 첫째 주에는 DP문제들을 공부하며, django프로젝트를 진행했다. Jump to django페이지를 참고해서 공부하며 만들었고, 현재 배포 직전이다.(급격히 바빠지는 바람에 밀뤄지는 중이다.) 1월 둘째 주 부터는 B-Tree를 구현해 보았다. 동적 할당을 해보는 것이 처음에는 조금 어색하긴 했지만, 1주일이 지난 현재는 꽤 익숙해 지고, 자유자재로 사용할 수 있게 된 것 같다. 2주 간의 목표 달성 Django code_review project 마무리( 배포는 하지 않았다.. ) python local variable과 global variabl..
-
B-Tree - 삽입컴퓨터 구조 2021. 1. 13. 21:29
이번 포스팅에서는 트리를 단순화하기 위해, 키와 관련된 부수적인 정보는 키와 같은 노드에 있다고 가정한다. Abdul Bari 교수님의 10.2 B Trees and B+ Trees. How they are useful in Databases click 위의 강의에서 설명하는 방식과 다른 방식의 삽입을 설명합니다. 해당 포스팅에서 설명하는 방식은 루트 노드에서 리프 노드까지 Top-Down으로 내려가며 재귀적으로 탐색하는 방식입니다. B-Tree - 기본 규칙 1. 모든 노드 x는 아래와 같은 속성이 있다. a. x.n은 노드 x에 현재 저장되어 있는 키의 개수다. b. x의 key들은 x.key(1) leaf; z->n = DEGREE - 1; for (int j = 0; j < DEGREE - 1; ..
-
Crafton Q&ASW사관학교 Jungle 2021. 1. 11. 19:09
Q&A Q. 크래프톤에 신입으로 들어가도 바로 라이브 서비스 중인 직접적으로 관여하기도 하나요? 크래프톤은 큰 회사입니다. 회사 내에서 하나의 프로젝트가 진행되는 것이 아니라 여러 프로젝트가 돌아가고 있습니다. 그래서 반드시 그렇다고 말씀드리기가 어렵네요. 직접 관여합니다. 하지만, 여러 안전장치들이 있습니다. 멘토와 사수가 함께 코드를 확인하며, 문제상황이 생기는 것을 사전에 방지합니다! Q. 자기 개발을 누구도 강요하지 않는 환경에서 정환님은 어떤 과정을 통해서 자기 개발을 해오셨나요? 세미나도 꾸준히 만들어 지고, 꾸준히 토론하는 문화, 분위기가 있었기 때문에 함께 이야기를 나누기 위해서는 저도 끊임없이 발전해야 했습니다. 자기개발을 강요 받은 셈입니다...ㅎ Q. 어떤 회사는 가상의 현실을 체험을..
-
B-Tree - intro컴퓨터 구조 2021. 1. 11. 01:16
B-Tree 1월 8일 부터 1월 13일까지, B - Tree와 B+ - Tree를 구현하는 프로젝트를 진행하고 있다. 오늘(1월 11일)을 시작으로 한 주 동안 B - Tree의 원리, 삽입 그리고 삭제가 어떻게 이루어지는지에 대해 알아볼 것이다. B - Tree 관련 포스팅들은 [Introductions to Algorithms (Third Edition), Tomas H. Corman]의 내용을 토대로 부족한 설명들과 예시를 덧 붙일 예정이다. 들어가기 전에 B - Tree를 공부하며, 인터넷의 여러 강의들 그리고 블로그들을 참고했다. 그런데, B - Tree를 구현하는 방법이 조금씩 달라서 이해하는데 혼란스러웠던 점이 있다. 특히, 대부분의 자료들에서 삽입에 대한 설명보다 삭제에 대한 설명이 부족..
-
단순 연결 리스트컴퓨터 구조 2021. 1. 10. 02:12
단순 연결 리스트 C언어의 pointer를 사용해 연결리스트를 구현해 보았다. 아래의 structure를 만들어 연결리스트의 node로 사용하였다. node는 item과 pointer로 구성했다. item은 해당 노드의 값을 저장하고, pointer는 다음에 이어질 node의 주소를 저장한다. typedef struct node { int item; //node의 값을 저장하는 변수 struct node* next; //node의 주소를 저장하는 포인터 } node; 단순 연결 리스트 중에서도 가장 간단한 형태로 구현했다. 값이 추가되지 않은 초기 상태에는 연결 리스트의 시작지점을 가리키는 'head'node가 존재한다. 현재 값이 추가되지 않았음으로, head의 pointer(head->next)는 N..
-
C - Pointer컴퓨터 구조 2021. 1. 8. 13:03
Pointer 아래의 코드는 a와 b를 swap하는 함수를 흉내낸 코드이다. 분명 문제가 없어 보이지만, 실제로 프로그램을 실행 시켜보면, a와 b의 값이 바뀌지 않았음을 알 수 있다. #include #include void swap(int* x, int* y); int main() { int a = 123; int b = 321; printf("%d %d\n", a, b); swap(&a, &b); printf("%d %d\n", a, b); return 0; } void swap(int* x, int* y) { int tmp = *x; *x = *y; *y = tmp; } //output 123 321 123 321 왜 바뀌지 않았을까?! 위의 그림과 같이 메모리의 code segment, data..