当前位置:  技术问答>linux和unix

多进程与多线程的取舍

    来源: 互联网  发布时间:2015-07-13

    本文导语:  本人初学UNIX,看到很多代码里边用fork产生新进程去完成某项任务,但是我觉得这里用线程也可以,而且线程的开销比产生进程要小得多,也更轻巧,为什么线程在UNIX下就不怎么受欢迎呢? 另外,我在什么时候用多...

本人初学UNIX,看到很多代码里边用fork产生新进程去完成某项任务,但是我觉得这里用线程也可以,而且线程的开销比产生进程要小得多,也更轻巧,为什么线程在UNIX下就不怎么受欢迎呢?

另外,我在什么时候用多进程比较合适,什么时候用多线程比较好,欢迎赐教!!

|
多线程比多进程麻烦些,考虑的问题比较多,如读写互斥等。
多进程编程比较简单,
fork()的子进程拷贝父进程的内存映象,
资源利用率没多线程的高。
如用vfork()等函数就是为了避免这种资源浪费。

|
1.线程是个比较新的东东,上个世纪90年代才开始流行起来。在这之前的系统都是基于进程的,已经有大量很成熟的应用了,总不至于因为线程的流行,就一夜之间突然放弃了吧!

2.不是所有的操作系统对线程的支持都很好。Linux2.6以前的内核,线程并不比进程有什么优势,FreeBSD5.0以前的版本也是如此。

|
线程虽然提高了资源的利用率,但是开发的复杂度,bug的出现机率大大增加;多进程虽然是
浪费了些资源,而且在多个进程之间切换会给系统带来一定程度的开销,但是随着COW等技术的出现,这种浪费在大大的减少.
所以,如果你的程序对资源利用率不是那么苛刻,还是用多进程编程好了.

|
线程的优点在于堆的数据共享,缺点也是这个,访问需要互斥。另外,标准库对线程支持比较麻烦。

|
UNIX fork是一个应用成熟的机制,所以这方面讲解较多;线程的应用是较新的东东,而且在某些系统又不成熟,所以较少用了;UNIX的版本有些不支持线程比如SCO等。

|
主要是因为采用多进程或线程的程序一般都是服务器,多进程的优点是健壮性和稳定性好,多线程处理不好会因为一个线程的崩溃造成整个系统死机

|
楼上说的对,用线程共享了同一段进程空间,处理上会有一点麻烦
进程无所谓了

|
UP

    
 
 

您可能感兴趣的文章:

  • 主进程有两个线程,fork子进程后复制主进程两个线程的内存么?
  • 如何实现这样的API,可同时被不同的进程/线程使用,但是又不区分进程/线程?
  • 请问:进程创建的线程是怎样运行的啊,线程的处理函数运行完了,线程就退出了吗?
  • 如果父进程有多个线程,那么它的子进程也该拥有这些线程
  • 一个进程创建了两个线程,如何使得当任何一个线程(比如线程a)结束时,同时也结束线程b,也就是使两个线程一起死掉,怎么办呢?
  • 如何让子进程继承父进程的线程
  • 请问,在一个进程中创建多线程时如何能避免不同的线程获得同一个线程标识
  • 在一个进程的主线程中如何判断自己创建的线程是否存在?
  • Linux中最多同时可以开多少个进程,一个进程可以开多少个线程?
  • 请教:线程中调用一个阻塞的方法后,进程及其它线程会阻塞么?
  • 请问在单进程,多线程程序里,线程间使用IPC的信号量来同步,能行吗?
  • linux线程与进程的问题
  • 在程序中启动一个进程(不是线程),如何知道该进程已运行结束
  • 如何准确理解“程序”、“进程”、“线程”这三个概念
  • 进程和线程的区别
  • 请问:linux下的子进程与线程的区别
  • linux进程(线程)运行过程中如何获取本进程当前的内存使用状况,统计信息?
  • socket+多进程+多线程
  • sleep是进程域还是线程域的?
  • 线程上下文切换和进程上下文切换那个代价大?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • android 4.0 托管进程介绍及优先级和回收机制
  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3