首页 > 代码库 > OS | Process
OS | Process
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 }