Java进程和线程

本文探讨了Java中进程和线程的出现原因、区别、优缺点以及并发与并行的概念。进程提供了内存中多程序运行的能力,而线程则解决了进程内部的并发问题。进程间地址空间和资源独立,线程共享。线程执行开销小,适合频繁切换,而进程资源管理能力强。并发是指命令快速轮换执行,而并行则涉及多处理器同时执行。
摘要由CSDN通过智能技术生成

1 进程和线程出现的原因

最初,计算机只能接受一些特定的指令,用户输入一个指令,计算机就做一个操作。效率低下,出现了 批处理操作,但是,原来都是只有一个程序在计算机里运行 — 即 内存中始终只有一个程序的运行数据
进程的出现,就是为了让 内存中可以装多个程序(进程),每个进程对应着一定的内存地址空间。并且 只能使用它自己的内存空间,各个进程间互不干扰。并且进程保存了程序每个时刻的运行状态,这样就为进程切换提供了可能。


进程的出现解决了操作系统的并发问题。但是不能解决 实时性。所以出现了线程。
进程让操作系统的并发性成为可能,而线程让进程的内部并发成为可能


2 进程和线程的区别

进程,又称为 轻量级线程

  • 1 地址空间:同一进程的线程共享本进程的地址空间,而进程之间则是独立的地址空间
  • 2 资源拥有:同一进程内的线程共享本进程的资源,但是进程之间的资源是独立的
  • 3 一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是 一个线程崩溃整个进程都死掉。所以多进程要比多线程健壮
  • 4 进程切换时,消耗的资源大,效率低。所以涉及到频繁的切换时,使用线程要好于进程。同样如果要求同时进行并且又要共享某些变量的并发操作,只能用线程不能用进程
  • 5 执行过程:每个独立的进程程有一个程序运行的入口、顺序执行序列和程序入口。但是 线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制
  • 6 线程是处理器调度的基本单位,但是进程不是
  • 7 两者均可并发执行
3 优缺点
  • 线程执行开销小,但是不利于资源的管理和保护。线程适合在SMP机器(双CPU系统)上运行
  • 进程执行开销大,但是能够很好的进行资源管理和保护。进程可以跨机器前移
4 并发与并行
  • 并发是指在同一时刻,只有一条命令是在处理器上执行的,但多个进程命令被快速轮换执行,使得在宏观上具有多个进程同时执行的效果
  • 并行是指同一时刻,多个命令在多个处理器上同时执行
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值