关于并发的非常基础的基础概念知识——线程进程,并发并行,同步异步

一、进程和线程对比认识

进程是系统进行资源分配的基本单位线程是被系统独立调度和执行的基本单位

进程可以看作是程序的一个实例,线程是属于进程的,一个进程可以包含多个线程。

与进程不同的是同类的多个线程共享进程的方法区资源,但每个线程有自己的程序计数器虚拟机栈本地方法栈,所以系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。

进程的特征:并发性,异步性,动态性,独立性,结构性

线程的作用:使多道程序更好的并发执行,提高资源利用率和系统吞吐量,增强操作系统的并发性能。

进程基本上是相互独立的,而线程存在于进程内,是进程的一个子集。

进程拥有共享的资源,比如内存空间,可以让其内部的线程集合共享使用。

进程间通信较为复杂,进程间的通信 IPC(Inter-process communication)

线程通信相对简单,因为它们共享进程内的内存。

  • 多个线程可以访问同一个共享变量Java 中的通信机制:volatile、等待/通知机制、join方式、InheritableThreadLocal、MappedByteBuffer

线程的上下文切换要比进程的上下文切换成本低。

相关文章

二、 并发和并行

解释一:并发是两件或多件事情在同一时间内交替发生;并行是两件或多件事情在同一时间内同时发生。

解释二:并发在同一时刻,有多个指令在单个 CPU 上交替执行 ;并行是在同一时刻,有多个指令在多个 CPU 上同时执行。

解释三:并发是不同代码块交替执行;并行是不同代码块同时执行。

并发中的交替的时间非常短,具体和CPU调度有关。

三、 同步和异步

同步是需要等待结果的返回才能继续执行;异步是不需要等待结果的返回就能执行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值