- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我理解,如果您的程序具有可以并行执行的大段,那么在实例不受单个资源约束时生成新线程将是有益的。这方面的示例是 Web 服务器发出页面请求。
从线程间通信成本低得多和上下文切换快得多的方面来看,线程是有益的。
从一个进程不能“混淆”另一个进程的内容的角度来看,进程为您提供了更高的安全性,而如果一个线程崩溃,则很可能所有线程都会在该进程内崩溃。
我的问题是,关于您何时想要使用进程(例如通过 C 中的 fork()),有哪些示例?
我可以想到,如果您有一个程序想要启动另一个程序,那么将它封装在一个新进程中是有意义的,但我觉得我缺少启动一个新进程的一些更大的理由。
具体来说,什么时候让一个程序产生一个新进程与线程有意义?
最佳答案
使用进程的主要原因是进程可能会崩溃或发疯,而操作系统会限制这对其他进程的影响。因此,例如 Firefox 最近开始在单独的进程中运行插件,IIRC Chrome 在不同的进程中运行不同的页面,并且网络服务器长期以来一直在单独的进程中处理单个请求。
操作系统应用限制有几种不同的方式:
使用流程的另一个潜在原因是它可以更轻松地推理您的代码。在多线程代码中,您依赖所有类的不变量来推断对特定对象的访问是序列化的:如果您的代码不是多线程的,那么您知道它是[*]。使用多线程代码也可以做到这一点,当然,只要确保您知道哪个线程“拥有”每个对象,并且永远不要从不是其所有者的线程访问对象。流程边界强制执行这一点,而不仅仅是为其设计。同样,不确定这是动机,但例如 World Community Grid 客户端可以使用多个核心。在该模式下,它运行多个进程,每个进程执行完全不同的任务,因此它具有额外内核的性能优势,不需要任何单独的任务可并行化,也不需要任何任务的代码是线程安全的。
[*] 好吧,只要它不是在共享内存中创建的。您还需要避免意外的递归调用等,但这通常是一个比同步多线程代码更简单的问题。
关于c - 产生新进程 v 线程的动机,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5839519/
为了了解 Redux 的动机,我阅读了官方链接 https://redux.js.org/introduction/motivation还有这个 stackoverflow 问题 Explain Re
您好,这个 firebase 函数曾经可以工作,但知道它现在工作时间更长了,我收到此错误消息 Function returned undefined, expected Promise or valu
我是一名优秀的程序员,十分优秀!