java线程第一节 进程 线程 程序与并发 并行

java线程第一节 进程 线程 程序与并发 并行

一.线程,进程,程序定义

  • 程序

    • 程序是以某些程序设计语言(机器语言、汇编语言、高级语言c、java等)编写的指令集。(静态)

    • 说白了就是一段静态代码

    • 在存放到磁盘之后就形成了一个可执行文件

  • 进程

    • 进程是正在运行的程序的实例(一段程序的执行过程)(动态,有周期

    • 通俗一点说,进程就是程序的一次执行

    • 是系统进行资源分配和调度的基本单位

    • 正在执行的程序,从Windows上来讲,其实就是含有内存和资源

    • 进程之间:

    • 每个进程之间是独立。操作系统在分配资源(例如:内存)时,是以进程为单位。+

    • 两个进程之间进行切换,通信(交换数据)等操作时,成本比较高。

    • 一个程序可以对应多个进程,但一个进程只能对应一个程序。

  • 线程

    • 线程被包含在进程之中,是进程中的实际运作单位

    • 线程可以理解为进程中的执行的一段程序片段

    • 进程进一步细化为线程,是进程内部的最小执行单元

    • 线程,有时被称为轻量级进程(Lightweight Process,LWP),是程序执行流的最小单元。一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成。另外,线程是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源。
      原文链接:https://blog.csdn.net/dypnlw/article/details/80606595

    • 同一个进程中的多个线程之间是可以共享部分内存(方法区、堆),每个线程的有些内存又是独立(虚拟机栈、本地方法栈、程序计数器)。

    • 因为线程之间可能使用共享内存,那么在数据交换成本上就比较低。而且线程之间的切换,对于CPU和操作系统来说,成本比较低。 所以我们通常用多线程来代替多进程的方式,实现多任务开发。

      原文链接:https://blog.csdn.net/weixin_46369022/article/details/119137725

二.线程,进程,程序联系

程序与进程的联系与区别:

  • 程序是一组指令的集合,是静态的,永久的 进程是执行的程序,是动态的,是有生命周期的;
  • 进程 = 程序+数据+PCB(进程控制块)

进程与线程的联系与区别:

  • 同一进程中的两段代码是不可能同时执行的,除非引入线程。
  • 线程是属于进程的,当进程退出时该进程所产生的线程都会被强制退出并清除。
  • 线程占用的资源要少于进程所占用的资源。
  • 一个进程可以有多个线程,一个线程只能属于一个进程,线程不能脱离进程而独立运行;
  • 每个进程至少有一个线程(主线程),在主线程中开始执行程序,Java程序入口main方法就是在主线程执行的;
  • 在主线程中可以创建并启动其他进程;
  • 一个进程内所有的线程共享该进程的内存资源;

三.并发与并行

并行

  • 并行:指两个或多个事件在同一时刻点发生。
  • 倘若计算机系统中有多个CPU,则这些可以并发执行的程序便可被分配到多个处理器上,实现多任务并行执行,即利用每个处理器来处理一个可并发执行的程序,这样,多个程序便可以同时执行,因为是微观的,所以大家在使用电脑的时候感觉就是多个程序是同时执行的。所以,大家买电脑的时候喜欢买“核”多的,其原因就是“多核处理器”电脑可以同时并行地处理多个程序,从而提高了电脑的运行效率。单核处理器的计算机肯定是不能并行的处理多个任务的,只能是多个任务在单个CPU上并发运行。
    原文链接:https://blog.csdn.net/yangying496875002/article/details/73480337

并发

  • 并发:指两个或多个事件在同一时间段内发生。

  • 在操作系统中,在多道程序环境下,并发性是指在一段时间内宏观上有多个程序在同时运行,但在单CPU系统中,每一时刻却仅能有一道程序执行(时间片),故微观上这些程序只能是分时地交替执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值