多线程-进程与线程详解

目录:

什么是进程
什么是线程
线程的好处
进程与线程的关系
进程与线程的区别
java中的main方法是进程还是线程
java内存模型(JMM ( java Memory Model ))
多线程编程的好处
java线程与操作系统之间的关系
进程间通信:共享内存原理
虚拟地址空间
用户空间和内核空间
进程间的通信方式

什么是进程:

进程是操作系统资源分配的单位。如:I/O资源,内存资源等;

什么是线程:

线程是资源调度的单位,真正执行的指令。如操作数据的执行流; 线程是进程中执行运算的最小单位,是进程中一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点在运行中必不可少的资源,但它可以与同属一个进程的其它线程共享进程所拥有的全部资源。一个线程可以创建和撤销另一个线程,同一进程中的多个线程可以并发执行;

线程的好处:

  • 易于调度。
  • 提高并发性,通过线程可方便有效地实现并发性,进程可创建多个线程来执行同一程序地不同部分。
  • 开销少。创建线程比创建进程要快,所需开销很少。
  • 利用充分发挥多处理器地功能。通过创建多线程的进程,每个线程在一个处理器上运行,从而实现应用程序的并发运行,使每个处理器都得到充分运行。

进程与线程的关系:

  • 一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
  • 资源分配给进程,同一进程的所有线程共享该线程的所有资源。
  • 处理级分配给线程,即真正的处理机上运行的是线程。
  • 线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。线程是指进程内的一个执行单元,也是进程内的可调度实体。
  • 进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径,线程有自己的堆栈和局部变量,但是线程之间没有独立的地址空间,线程在进程中共享空间,因此一个线程死掉可能会影响其它线程,也可能会导致整个进程死掉,所以多进程的程序要比多线程的程序健壮,但是在进程切换时,耗费资源较大,效率要差一些,但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程

进程与线程的区别:

  • 调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位。
  • 并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可以并发执行。线程的划分尺度小于进程,使得多线程程序的并发性高。
  • 拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但是可以访问隶属于进程的资源。
  • 系统开销:在创建或撤销进程时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创建或撤销线程时的开销。
  • 线程在执行过程中与进程还是有去别的,每个独立的线程有一个程序运行的入口,顺序执行序列和
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值