我觉得多线程已经很全能了,而且线程间通信啊、同步啊都比较简单
各位有用多进程的吗?哪些地方用多进程比较好呢
进程间互相隔离,更安全 |
多线程是十字路口 多进程是立交桥。一个线程挂了进程就挂了
多进程如果能解决问题,就不要引入多线程。 |
1、看应用。 进程一般来说更稳定,很多服务器默认是使用进程或者只有进程模式的,如Apache/PostgreSQL。线程虽然轻快(尤其在win上),但潜在问题很多。如果你需要稳定,进程是更好的选择。如果要速度,线程可能更好。 2、看平台。 win平台上,你可以说线程支持很优秀,反过来也可以说进程性能太低。上面提到的apache/postgresql如果在win平台上仍然使用进程的话,性能是大大不如在*nix平台的。铁杆的Unix用户对线程不那么感冒。
线程的同步比进程之间的通信复杂多了好不好?
如果你的应用程序需要采取以下的操作,那么你尽可在编程的时候考虑多线程机制: 连续的操作,需要花费忍无可忍的过长时间才可能完成 并行计算 为了等待网络、文件系统、用户或其他I/O响应而耗费大量的执行时间 所以说,在动手之前,先保证自己的应用程序中是否出现了以上3种情形。 为什么需要多线程(解释何时考虑使用线程) 从用户的角度考虑,就是为了得到更好的系统服务;从程序自身的角度考虑,就是使目标任务能够尽可能快的完成,更有效的利用系统资源。综合考虑,一般以下场合需要使用多线程:如果你的应用程序需要采取以下的操作,那么你尽可在编程的时候考虑多线程机制: 连续的操作,需要花费忍无可忍的过长时间才可能完成 并行计算 为了等待网络、文件系统、用户或其他I/O响应而耗费大量的执行时间 所以说,在动手之前,先保证自己的应用程序中是否出现了以上3种情形。 为什么需要多线程(解释何时考虑使用线程) 从用户的角度考虑,就是为了得到更好的系统服务;从程序自身的角度考虑,就是使目标任务能够尽可能快的完成,更有效的利用系统资源。综合考虑,一般以下场合需要使用多线程: 1、 程序包含复杂的计算任务时 主要是利用多线程获取更多的CPU时间(资源)。 2、 处理速度较慢的外围设备 比如:打印时。再比如网络程序,涉及数据包的收发,时间因素不定。使用独立的线程处理这些任务,可使程序无需专门等待结果。 3、 程序设计自身的需要 WINDOWS系统是基于消息循环的抢占式多任务系统,为使消息循环系统不至于阻塞,程序需要多个线程的来共同完成某些任务。 每个正在系统上运行的程序都是一个进程。每个进程包含一到多个线程。进程也可能是整个程序或者是部分程序的动态执行。线程是一组指令的集合,或者是程序的特殊段,它可以在程序里独立执行。也可以把它理解为代码运行的上下文。所以线程基本上是轻量级的进程,它负责在单个程序里执行多任务。通常由操作系统负责多个线程的调度和执行。 什么是多线程? 多线程是为了使得多个线程并行的工作以完成多项任务,以提高系统的效率。线程是在同一时间需要完成多项任务的时候被实现的。 使用线程的好处有以下几点: ·使用线程可以把占据长时间的程序中的任务放到后台去处理 ·用户界面可以更加吸引人,这样比如用户点击了一个按钮去触发某些事件的处理,可以弹出一个进度条来显示处理的进度 ·程序的运行速度可能加快 ·在一些等待的任务实现上如用户输入、文件读写和网络收发数据等,线程就比较有用了。在这种情况下我们可以释放一些珍贵的资源如内存占用等等。 还有其他很多使用多线程的好处,这里就不一一说明了。 一些线程模型的背景我们可以重点讨论一下在Win32环境中常用的一些模型。 ·单线程模型 在这种线程模型中,一个进程中只能有一个线程,剩下的进程必须等待当前的线程执行完。这种模型的缺点在于系统完成一个很小的任务都必须占用很长的时间。 ·块线程模型(单线程多块模型STA) 这种模型里,一个程序里可能会包含多个执行的线程。在这里,每个线程被分为进程里一个单独的块。每个进程可以含有多个块,可以共享多个块中的数据。程序规定了每个块中线程的执行时间。所有的请求通过Windows消息队列进行串行化,这样保证了每个时刻只能访问一个块,因而只有一个单独的进程可以在某一个时刻得到执行。这种模型比单线程模型的好处在于,可以响应同一时刻的多个用户请求的任务而不只是单个用户请求。但它的性能还不是很好,因为它使用了串行化的线程模型,任务是一个接一个得到执行的。 ·多线程块模型(自由线程块模型) 多线程块模型(MTA)在每个进程里只有一个块而不是多个块。这单个块控制着多个线程而不是单个线程。这里不需要消息队列,因为所有的线程都是相同的块的一个部分,并且可以共享。这样的程序比单线程模型和STA的执行速度都要块,因为降低了系统的负载,因而可以优化来减少系统idle的时间。这些应用程序一般比较复杂,因为程序员必须提供线程同步以保证线程不会并发的请求相同的资源,因而导致竞争情况的发生。这里有必要提供一个锁机制。但是这样也许会导致系统死锁的发生 |