码迷,mamicode.com
首页 > 其他好文 > 详细

OS | Process

时间:2014-06-24 11:44:25      阅读:264      评论:0      收藏:0      [点我收藏+]

标签:style   class   blog   code   color   使用   

linux多进程

1. fork()创建进程,创建一份父进程的拷贝;在父进程中返回的是子进程id,在子进程中返回的是0;失败时返回-1;

2. fork()经常和exec()结合,exec() 覆盖了原进程的空间,转而执行其他程序;

3. 杀掉父进程,不会同时杀掉子进程;

孤儿进程:一个父进程退出,而它的一个或多个子进程还在运行,那么那些子进程将成为孤儿进程。孤儿进程将被init进程(进程号为1)所收养,并由init进程对它们完成状态收集工作。

僵尸进程:一个进程使用fork创建子进程,如果子进程退出,而父进程并没有调用wait或waitpid获取子进程的状态信息,那么子进程的进程描述符仍然保存在系统中。这个子进程称之为僵尸进程。系统所能使用的进程号是有限的,如果大量的产生僵死进程,将因为没有可用的进程号而导致系统不能产生新的进程。孤儿进程并不会有什么危害。

当我们寻求如何消灭系统中大量的僵死进程时,答案就是把产生大 量僵死进程的那个元凶枪毙掉(也就是通过kill发送SIGTERM或者SIGKILL信号啦)。枪毙了元凶进程之后,它产生的僵死进程就变成了孤儿进程,这些孤儿进程会被init进程接管,init进程会wait()这些孤儿进程,释放它们占用的系统进程表中的资源,这样,这些已经僵死的孤儿进程 就能瞑目而去了。

4. wait() 等待子进程;可以获取子进程的返回状态;

5. system()就是用fork()+exec()+wait()实现;

6. execlp(),每一个是可执行文件的路径,第二个参数开始就是arg0,arg1,...,所以arg0必须就是可执行文件名,最后一个arg必须是NULL; 

 1 int main() {
 2     int pid = fork();
 3     if (pid < 0) {
 4         fprintf(stderr, "fork failed");
 5         return -1;
 6     } else if (pid == 0) {
 7         cout << "child process" << endl;
 8         execlp("/bin/touch", "touch", "/root/lab/os/1", NULL);    
 9     } else {
10         cout << "pid of child:" << pid << endl;
11         int status;
12         wait(&status);
13         cout << "status of child:" << status << endl;
14     }
15     return 0;
16 }

 共享内存通信

1. shm_open打开或者创建共享内存object,名字必须以/开头;一开始大小为0;需要通过ftruncate()设置大小;

2. 用mmap将shared memory object映射到内存;映射为MAP_SHARED,这样在其他进程中可见;即使进程退出了,在没有调用shm_unlink之前,其他进程还是可以访问这一块区域的。

 1 #include <sys/mman.h>
 2 #include <sys/stat.h>        
 3 #include <fcntl.h>          
 4 #include <stdio.h>
 5 #include <unistd.h>
 6 #include <sys/types.h>
 7 
 8 int main() {
 9     int shmID = shm_open("/test", O_CREAT | O_RDWR, 0666);
10     if (shmID < 0) {
11         fprintf(stderr, "shm create failed\n");
12         return -1;
13     }
14     ftruncate(shmID, 2014);
15     char* p = (char*)mmap(NULL, 2014, PROT_WRITE, MAP_SHARED, shmID, 0);
16     for (int i = 0; i < 2000; i++) {
17         p[i] = 0 + i % 10;
18     }
19     munmap(p, 2014);
20     return 0;
21 }
 1 #include <stdio.h>
 2 #include <sys/mman.h>
 3 #include <sys/stat.h>       
 4 #include <fcntl.h>         
 5 
 6 int main() {
 7     int shmID = shm_open("/test", O_RDONLY, 0666);
 8     if (shmID < 0) {
 9         fprintf(stderr, "shm open fail\n");
10         return -1;
11     }
12     char* p = (char*)mmap(NULL, 2014, PROT_READ, MAP_SHARED, shmID, 0);
13     if (p == NULL) {
14         return -1;
15     }
16     for (int i = 0; i < 100; i++) {
17         printf("%c ", p[i]);
18     }
19     printf("\n");
20 
21     shm_unlink("/test");
22     munmap(p, 2014);
23     return 0;
24 }

 

OS | Process,布布扣,bubuko.com

OS | Process

标签:style   class   blog   code   color   使用   

原文地址:http://www.cnblogs.com/linyx/p/3805165.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!