목록School (28)
Keep going

스레드 이슈 fork(), exec() 스레드 여러 개 있을 때 어떤 한 스레드가 fork를 하면 새 process 에는 fork 한 스레드 1개만 들어가야 되냐, 모든 스레드가 다 복사되어야 하냐? (쓰레드 1개면 문제 x → 똑같은 시점으로 복사) Signal handling p1, p2 있을 때 p1 p2에게 어떤 사건 일어났다고 알려주기 위해 시그널을 보낸다. (시그널을 일반적으로 정수) (시그널이 발생했다는 걸 알려주고 시그널 몇번이다) 에 따라서 어떤 일이 일어났다 알려주는 것을 signal system p2 스레드 여러 개 있다면 어느 누구한테 signal이 가야 되는지 signal 누가 처리할지에 대한 문제 발생 Thread cancellation (스레드 중단) p1 프로세스가 여러 개 ..
스레드 라이브러리 구현 두 가지 방법 user mode에서 스레드 라이브러리 구현하는 방법 운영체제 내부에서 구현하는 방법 (kernel 모드에서 돌아감) 스레드 라이브러리 종류 POSIX windows java Implicit pthreads 유저 레벨, 커널 레벨 둘다 제공 a posix api - 스레드 지원하려면 다음과 같음 메서드들 제공해야 한다고 명시, 어떻게 구현할 건지 지정하는 것은 아님 unix systems에서 사용 java JVM이 OS가 제공하는 스레드 기능 구현 Runnable 인터페이스 내부에 run 메서드 → 스레드 생성 Implicit Threading 직접 만드는 것이 아니라 Runtime, Compiler가 만들어주고 암묵적으로 스레드 만들어서 실행하라고 명시하는 것 스레..

Motivation (왜 multithreaded programming 하는가?) 하나의 프로세스가 여러 개 실행흐름을 가지는 것. 프로그램안의 실행흐름을 스레드라고 한다. 요즘 응용 프로그래밍들은 하나의 프로세스가 여러개 실행흐름 가지는 multithreaded programming 경우 많다. 장점 한 스레드는 update display, 다른 스레드는 데이터 가져오기, 스펠링 체크하는 것처럼 다양한 일을 하는 스레드들로 하나의 응용 프로그램이 구성될 수 있다. (multithread 예) 코드를 간단하게 할 수 있다. 각자 하는 일을 하나의 스레드로 만들어서 처리하게 함으로써 전체 프로그램이 하나에 몰려있지 않게 함 여러 thread가 돌아감으로써 효율성 개선할 수 있다. 또한 운영체제 자체도 여러..
Interprocess Communication 프로세스간의 독립적 통신할 필요 없다. 프로세스간의 협력 협력하는 process는 데이터를 서로 주고 받고 공유한다. interprocess communication 필요 cooperating process 여러 프로세스 간 데이터 공유 위함 속도 빠르게 하기 위해 분담 s/w 구현할 때 A기능은 p1이 B기능은 p2가 잘라서 모듈 나누기 IPC의 2가지 모델 shared memory message passing (메시지 전달) Producer - Consumer Problem 생산자가 물건을 창고에 넣어둠, 소비자는 물건을 창고에서 빼서 갖다 씀 컴퓨터 내부나 응용 program에서도 많이 볼 수 있음 ex) process가 스플에 printer 할 작업..

프로세스 연산 프로세스 생성 프로세스 종료 프로세스 정보 가져오거나 프로세스에 대한 정보를 값으로 지정하거나...... 프로세스 생성 프로세스가 다른 프로세스 만든다. 프로세스들은 부모 - 자식 관계인 tree 구조다. 시스템 내부에서 각 프로세스는 고유한 번호 (pid) 부여 받는다. → 운영체제는 pid로 구별한다. 한 프로세스가 다른 프로세스를 만들 때 고려할 상황(resource) p1이 어떤 자원사용하고 있는데 p2를 만들려면 p1이 쓰고 있는 자원 어떻게 될까? p1이 사용하고 있는 모든 자원을 p2와 공유해서 같이 사용 p1이 사용하고 있는 자원에 일부만 가지고 p2가 사용 p1는 자기 것 사용하고 p2는 자원 따로 할당 받아서 사용 실행 p1이 p2 만들었을 때 p1 중지되고 p2 실행 둘..

Process Scheduling ready 되어 있는 process가 여러개 있다면 어떤 프로세스에게 cpu를 줄 것인가 process scheduler : ready queue에 있는 여러가지 process 중에서 어떤 process가 다음 cpu 실행을 받을 것인가 결정함 시스템안에서 여러가지 큐 job queue - DISC에서 main memory 나올 때까지 기다리는 큐 ready queue - cpu를 받기 위해 준비된 애들이 연결 되어 있는 애들 device queues - 장치에 있는 큐 프로세스가 어떤 큐에 있는가를 기준으로 process를 나눠 볼 수있다. process 처음 생겨나면 ready queue, cpu 받으면 실행 I/O 요청 → I/O queue 할당된 시간이 지나면 r..

프로세스 개념 (Process concept) cpu가 프로그램 실행. 실행 중인 프로그램을 여러가지 이름으로 운영체제에서 불렀다. Batch System - jobs 여러개의 job을 deque에 집어 넣고 작업을 하나하나 읽어들여서 실행. 이 작업 끝나면 다음 작업 읽어 들여서 실행 Time-shared Systems - tasks 컴퓨터에 직접 사용자 online terminal로 연결해서 사용자들이 바로 사용할 수 있는 시스템으로 바뀜 이런 경우에 사용자가 실행하는 프로그램이 돌아가고 있을 때 실행중인 컴퓨터 프로그램을 task라고 부름 job, task 모두 포함하는게 process (실행 중인 program) program이 실행중이다 → cpu가 프로그램 각 명령어를 레지스터에 갖고와서 계속..
디버깅 프로그램 에러 제거 운영체제 자체 실행기록이나 사용자 프로그램 실행 기록을 로그파일로 남겨서 나중에 분석을 통해서 에러 찾기 ex) 사용자 프로그램 실행되다가 오류에 의해서 중단되면 사용자 프로그램이 실행되던 메모리 내용을 파일에다가 덮어 쓰게 되는데 core dump file 이라고 한다. 메인 메모리는 core memory라고 부른다. core dump를 이용해 디버그가 어디서, 프로그램이 어디서 중단이 됬는지와 중단이 됐을 때 각 변수의 값이 어떻게 됐는지 하는 것을 찾아볼 수 있게 된다. 사용자 프로그램 실패 → 오류 발생, 운영체제 실패 → crash 실패할 때 crash dump라는 파일 만듬. (운영체제가 실패해서 만들어진) 운영체제가 돌아갈 때 메모리 내용을 갖다 쓴 파일을 cras..