线程--进程与线程

25 篇文章 0 订阅

线程和进程

  • 进程和线程:

进程:资源进行分配的单位,进程是操作系统中正在执行的不同应用程序的一个实例,操作系统把不同的进程分离开来。eg:IO ,内存

线程:进行资源调度的单位,执行程序代码片段 ,线程是操作系统分配处理器时间的基本单元。例:操作数据的执行流

  • 线程和进程的关系:
  1. 根本区别:

(1)进程:资源进行分配的最小单位。

(2)线程:程序执行的最小单位。(处理器调度)

  1. 内存分配:

(1)进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径;

(2)线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,同一个进程的线程共享本进程的地址空间。一个线程死掉就等于整个进程死掉。多个线程共享内存,从而极大地提高了程序的运行效率;

  1. 隶属关系:

    一个进程可以包含多个线程,一个线程只隶属于一个进程,进程对线程一对多的关系;

  2. 资源拥有:

(1)进程与进程是相互独立隔离的,若一个进程崩溃,是不会影响其他进程的正常执行;

(2)线程是隶属于进程,线程在进程间可以共享空间,一个线程的崩溃可能会影响其他线程正常执行,

  1. 系统开销:

(1)多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。

(2)但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。线程的划分尺度小于进程,使得多线程程序的并发性高。

  1. 执行过程:

每个独立的进程有一个程序运行的入口、顺序执行序列和程序的出口。但是进程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

  1. 从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。
  • 使用多线程的好处:

提高CPU 的使用效率

在多线程程序中,多个线程被并发的执行以提高程序的效率,CPU不会因为某个线程需要等待资源而进入空闲状态。多个线程共享堆内存(heap memory),因此创建多个线程去执行一些任务会比创建多个进程更好。

  • 使用线程的缺点:

多线程处理可解决用户响应性能和多任务的问题,但同时引入了资源共享和同步等问题。例如:过多的线程将占用大量的资源和处理器调度时间,从而影响了运行性能;为了避免对共享的资源的访问冲突,必须对共享资源进行同步或控制处理,因而有可能导致死锁;使用多线程控制代码执行非常复杂,并可能产生许多错误。

Java中线程与进程
  • java内存模型:

线程共享:方法区、堆区

线程私有:虚拟机栈、本地方法栈、程序计数器

  • java中启动main方法是进程还是线程?

java中main方法启动的是一个进程也是一个主线程

main方法里面的其他线程均为子线程。

一个java程序启动后它就是一个进程,进程相当于一个空盒(分配了内存空间、JVM虚拟机实例), 它只提供资源装载的空间,具体的调度并不是由进程来完成的,而是由线程来完成的。

一个java程序从main开始之后,进程启动,为整个程序提供各种资源,而此时将启动一个线程,
这个线程就是主线程,它将调度资源,进行具体的操作。

Thread、Runnable的开启的线程是主线程下的子线程,是父子关系,此时该java程序即为多线程的,这些线程共同进行资源的调度和执行。

  • Java线程与操作系统之间的关系?

Java中创建的进程和线程最终会映射到本地操作系统的进程、线程模型上。
java =》 jvm =》 Linux

:    进程       线程
:java Runtime.exec   thread
:linux fork/vfork   pthread_create
  (c++ 实现)

windows的进程线程模型 != Linux进程线程模型;

Linux进程线程模型 : 进程 = 线程;

windows的进程线程模型和Linux的进程线程模型不一致。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值