进程和线程的区别,多进程和多线程的区别?

进程和线程的区别

进程和线程的区别,多进程和多线程的区别?


进程和线程的根本区别是进程是操作系统资源分配的基本单位,而线程是处理器任务调度和执行的基本单位 。另外区别还有资源开销、包含关系、内存分配、影响关系、执行过程等 。
资源开销:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小 。
包含关系:如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程 。
内存分配:同一进程的线程共享本进程的地址空间和资源,而进程之间的地址空间和资源是相互独立的 。
影响关系:一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都死掉 。所以多进程要比多线程健壮 。
执行过程:每个独立的进程有程序运行的入口、顺序执行序列和程序出口 。但是线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制,两者均可并发执行 。
进程和线程的根本区别是进程是操作系统资源分配的基本单位,而线程是处理器任务调度和执行的基本单位 。
多进程和多线程的区别?我不是专家 。每个进程都至少有一个线程 。一般,系统创建一个进程的开销是比较大的,需要分配内存,内核资源等等 。不同进程间无法直接共享彼此拥有的这些资源 。
而我们可以在同一进程内创建多个线程,这些线程相对来说‘轻量级’很多,它们可以共享所在进程的各种资源 。
首先,粗略的说,你可以认为线程是 个‘轻量级’进程 。用多线程模式,你可以很轻松的 实现 并行 。即,在多核 的设备上(如你有4核cpu),你可以开4个线程,以便这4个核 能同时 为你这个 进程 的工作服务 。
多进程没什么经验,以下是我的想法:多进程 相对多线程而言,里面每一个进程都更加独立,它们可以不再同一个机器上 。它们执行的代码也不同 。
比如你找到了两个开源项目来为你的 某个功能服务,如果时间紧迫,,你可以开两个进程运行这两个项目,然后把结果传给你自己的 进程 。
【进程和线程的区别,多进程和多线程的区别?】 进程间数据传输方式很多,简单的 可以写文件,用端口,,复杂的google下~~.而且,你也可以配置成分布式系统,这个机器跑一个集成,另一个机器跑另一个等等 。以上个人浅见 。坦白讲,我依然对进程和线程存有很多疑惑,我觉得如果想真正了解,先学操作系统原理

    推荐阅读