Java-多进程与多线程

一、概念
多进程:在同一个时间里,同一个计算机系统中如果允许两个或两个以上的进程处于运行状态,便是多进程,也称多任务。现代的操作系统几乎都是多任务操作系统,能够同时管理多个进程的运行。

多线程:线程是一个轻量级的子进程,是最小的处理单元;多线程是一种执行模型,它允许多个线程存在于进程的上下文中,以便它们独立执行但共享其进程资源。

二、区别
数据共享、同步:
多进程:数据是分开的,共享复杂,需要用IPC;同步简单;
多线程:多线程共享进程数据,共享简单;同步复杂。
内存、CPU:
多进程:占用内存多,切换复杂,CPU利用率低;
多线程:占用内存少,切换简单,CPU利用率高 线程占优。
创建销毁、切换:
多进程:创建销毁、切换复杂,速度慢;
多线程:创建销毁、切换简单,速度快 线程占优。
编程调试:
多进程:编程简单,调试简单;
多线程:编程复杂,调试复杂。
可靠性:
多进程:进程间不会相互影响;
多线程:一个线程挂掉将导致整个进程挂掉。
分布式:
多进程:适应于多核、多机分布 ;如果一台机器不够,扩展到多台机器比较简单;
多线程:适应于多核分布。

文章仅作为个人学习整理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值