Develop
2003.04.23 10:44
[c] fork() 시스템 콜 사용 방법.
Views 27639 Comment 0
Unix 에서 임의의 프로세스는 fork()를 이용해서
자신과 똑같은 기능을 수행하는 프로세스를 하나 복제 할 수 있다.
- fork()를 호출한 프로세스 : 부모프로세스
- 새로 생긴 프로세스 : 자식프로세스
자식 프로세스는 부모프로세스의 코드, 스택, 파일기술자, 소켓번호 등을 공유
단, 새로 생간 자식 프로세스의 id번호(PID)는
부모 프로세스의 PID와 구별되며 각종 변수들은 공유하지 않는다..
fork() 시스템 콜이 성공적으로 수행 됐을때..
- 하나의 프로세스가 두개의 프로세스로 된다.
(두 프로세스의 fork() 리턴문이 서로 다르다는 것을 이용하여 두 프로세스는 수행할 일을 구분한다.)
- 부모프로세스에게는 fork()의 리턴값으로 새로 만들어진 자식 PID가 리턴
- 자식 프로세스는 fork()의 리턴값이 0이 된다.
fork()이 실패한 경우는 -1이 리턴되고 자식 프로세스는 생성되지 않는다.
----------------------------------------------
부모 프로세스(PID=135) <┐
| │ fork() 리턴값 136
fork() ───────┘
│
자식 프로세스(PID=136) -> fork()리턴값 0
----------------------------------------------
int pid; pid = fork(); if(pid==0){ child_work(); // 자식 프로세스용 코드 }else{ parent_work(); // 부로 프로세스용 코드 }
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
793 | Develop |
[jsp][php] 간단한 강좌 자료..
![]() |
hooni | 2003.04.23 | 8142 |
792 | Develop |
[c] 학생명단 관리 프로그램 소스 ㅋㅋ
1 ![]() |
hooni | 2003.04.23 | 7804 |
791 | Develop |
[c] 근의 공식으로 2차방정식 풀기..
![]() |
hooni | 2003.04.23 | 7812 |
790 | Develop | [c] 이진트리(binary tree)의 운행.. | hooni | 2003.04.23 | 8296 |
789 | Develop |
[c] 이진트리(binary tree)의 특성
![]() |
hooni | 2003.04.23 | 9633 |
788 | Develop |
[자료구조] 트리(tree) 용어정리
![]() |
hooni | 2003.04.23 | 11103 |
787 | Develop |
[c] 농구팀 점수 산출 프로그램 소스
![]() |
hooni | 2003.04.23 | 7406 |
786 | Develop |
[c] 단어 입력/수정 프로그램 소스
![]() |
hooni | 2003.04.23 | 7055 |
785 | Develop |
[c] 정사각배열의 서브 배열의 최대 값 구하기
![]() |
hooni | 2003.04.23 | 7041 |
784 | Develop |
[c] 이진트리(binary tree) 샘플소스 (삽입, 삭제, 운행)
![]() |
hooni | 2003.04.23 | 7835 |
783 | Develop | [java] 컴포넌트 배치 ㅡ.,ㅡ; | hooni | 2003.04.23 | 7176 |
782 | Develop | [html] 메타태그 사용예.. 은지나 바라~ | hooni | 2003.04.23 | 7249 |