当前位置: 技术问答>linux和unix
unix/linux上用多线程还是多进程开发程序好?
来源: 互联网 发布时间:2016-06-12
本文导语: unix/linux上用多线程还是多进程开发程序好? 高手针对Linux、Unix分别给出建议。 | linux跟unix用起来很大区别吗?没感觉吧,应该说我们平时都是linux。 至于多线程还是多进程,自己看开销咯,想开销小...
unix/linux上用多线程还是多进程开发程序好?
高手针对Linux、Unix分别给出建议。
高手针对Linux、Unix分别给出建议。
|
linux跟unix用起来很大区别吗?没感觉吧,应该说我们平时都是linux。
至于多线程还是多进程,自己看开销咯,想开销小点就多线程,不过要注意线程函数的重入性。
自己看看多进程跟多线程的区别就知道了。像select就可以配合多线程,但是不能配合多进程。
|
Unix 不咋懂
Linux可以瞎掰活几句 (咱基本都是自己经验总结,不是简单给你链接)
多线程 多进程 在Linux内核都以 LWP 形式调度,所以从CPU角度几乎无差异。
从内存角度 进程开销当然比线程要大一些,线程毕竟只有自己的一个线程栈 然后共享进程地址空间。
从实际应用,就我个人的经验来看,几点值得注意的地方
1. 如果应用程序的某个模块,本身比较独立,与其他的耦合性小,建议用进程实现之
2. 如果应用程序可靠性要求高,一个模块的fail 不能影响其他模块的功能,也建议用多进程。(同样内核也有 微内核 和 单内核之争)
3. 如果应用程序多个模块间 通信量大(如果采用多进程的话),建议改用多线程。
4. 如果应用程序某个模块,自己只是几个函数的多个执行流的组合可以搞定,当然多线程。
5. 如果应用程序拆成多进程后,进程数可能达到数万。。。(比如典型的appache服务器),内存负载量太大了,还是建议多线程吧。(NIGIX)
一点个人意见,说错莫怪 :)
Linux可以瞎掰活几句 (咱基本都是自己经验总结,不是简单给你链接)
多线程 多进程 在Linux内核都以 LWP 形式调度,所以从CPU角度几乎无差异。
从内存角度 进程开销当然比线程要大一些,线程毕竟只有自己的一个线程栈 然后共享进程地址空间。
从实际应用,就我个人的经验来看,几点值得注意的地方
1. 如果应用程序的某个模块,本身比较独立,与其他的耦合性小,建议用进程实现之
2. 如果应用程序可靠性要求高,一个模块的fail 不能影响其他模块的功能,也建议用多进程。(同样内核也有 微内核 和 单内核之争)
3. 如果应用程序多个模块间 通信量大(如果采用多进程的话),建议改用多线程。
4. 如果应用程序某个模块,自己只是几个函数的多个执行流的组合可以搞定,当然多线程。
5. 如果应用程序拆成多进程后,进程数可能达到数万。。。(比如典型的appache服务器),内存负载量太大了,还是建议多线程吧。(NIGIX)
一点个人意见,说错莫怪 :)
|
多线程肯定开销要小很多呀!
|
unix上一般都用多进程
|
多进程是比较容易的,fork()函数就是做这个的。
|
这问题没啥意义阿
两种使用的环境不一样
两种使用的环境不一样
|
if(fork()==0){
左手弹楼下的小JJ
}else{
右手拍楼下的小PP;
}
左手弹楼下的小JJ
}else{
右手拍楼下的小PP;
}
|
根据你的系统而定,多进程+多线程是最好的选择