那年,一步一步学linux c ---“侠肝义胆”之进程

2019-07-12 23:37发布

转自:http://blog.csdn.net/muge0913/article/details/7315522

那年,一步一步学linux c ---“侠肝义胆”之进程

分类: 嵌入式linux c 编程 2391人阅读 评论(6) 收藏 举报 linuxc 转载请注明出处:http://blog.csdn.net/muge0913/article/details/7315522 如果我们把计算机上的操作系统及各种各样的软件看成一系列的有机生命,而不是指令集,那么这就是一个进程的世界,在进程的世界中同样有“道德”和“法制法规”,窥探进程世界,看它的侠肝义胆,风雨江湖路~~~~~ linux支持多个进程同时进行,也就是我们常说的现代操作系统中的多道程序设计,所谓同时是linux系统调度各个进程分别占用cpu的时间。由于每个时间片的时间很小和宏观时间相比,给人的感觉是多个进程在运行。 注:总结下就是在微观是串行,在宏观上是并行。 为了提高程序的运行效率,程序往往分成多个部分组成,这也就是说的并发程序设计。并发程序中各进程是相互独立的,在必要的时候会通过相应的机制进行通信。若进程间要共享资源,为了避免出现冲突,常通过相应通信机制使它们轮流使用共享资源。在进程进行通信时,会出现一个进程等另一个进程完,才能继续运行的情况,这也需要进程间通信以了解对方的运行情况。有时进程间会出现互斥现象,这是会用到锁机制。在并发程序设计中,进程的创建和结束是由用户决定的。这也就出现了父进程和子进程概念。 进程的创建: [cpp] view plaincopyprint?
  1. #include
  2. pid_t fork(void);
  3. pid_t vfork(void);
#include pid_t fork(void); pid_t vfork(void);
在这简述,fork创建的子进程是父进程的一个拷贝,但是和父进程使用不同的数据段和堆栈。vfork和fork基本相同但是vfork不会复制父进程的数据段,它们共享数据段。这是因为vfork常和exec函数使用去调用一个程序如ls命令,开启一个新的进程。vfork后父进程会等待子进程运行结束或调用了exit。fork后父进程和子进程的运行顺序是不确定的。 下面是体现它们性质的程序: [cpp] view plaincopyprint?
  1. #include
  2. #include
  3. #include
  4. #include
  5. main()
  6. {
  7. pid_tpid;
  8. char*pchar = "before fork";
  9. inttest_va = 1;
  10. if((pid= fork()) < 0 )
  11. {
  12. printf("forkerror!! ");
  13. exit(1);
  14. }
  15. elseif(pid == 0)
  16. {
  17. printf("childprocess ");
  18. pchar= "child pchr ";
  19. printf("%s ",pchar);
  20. test_va= 2;
  21. printf("%d ",test_va);
  22. _exit(2);
  23. }
  24. else
  25. {
  26. printf("parentprocess ");
  27. //sleep(1);
  28. printf("%s ",pchar);
  29. printf("%d ",test_va);
  30. }
  31. }
#include #include #include #include main() { pid_tpid; char*pchar = "before fork"; inttest_va = 1; if((pid= fork()) < 0 ) { printf("forkerror!! "); exit(1); } elseif(pid == 0) { printf("childprocess "); pchar= "child pchr "; printf("%s ",pchar); test_va= 2; printf("%d ",test_va); _exit(2); } else { printf("parentprocess "); //sleep(1); printf("%s ",pchar); printf("%d ",test_va); } }
把上面的fork改为vfork即可 fork: vfork: