学习并发(1)基本概念

前言

在工作中时常接触到并发环境,只是现有的框架已经在底层封装好了,可以直接调用。但总会有一些奇特的场景需要自己手动实现并发,所以了解原理是很重要的。本文用于记录学习并发过程中重要的点或思考。

本文只讨论基本概念,旨在用较为详细易懂的文字记录自己对于并发的一些理解。

什么是并发

并发(Concurrency)是指系统在同一时间段可同时处理多个任务,而同一时刻只有一个任务处于运行状态。

实际上对于单核CPU而言无法实现真正的同时运行多个任务。但是由于CPU运算速度极快,在一个短的时间单位内(比如0.001秒)执行一个任务,执行完马上切换到下一个任务。这样宏观看起来就像是在同时运行多个任务了。

与**并行(Parallel)**的区别:并行是指同一时刻可以同时运行多个任务。现代多核处理器都支持并行运算。并发强调系统支持多个任务同一时刻存在;并行强调系统支持多个任务同时运行。

CPU核心数

可以理解为多处理器,双核CPU从程序的角度来看就等于可共享资源的两个单核处理器。对于单核处理器而言,任一时刻只能处理一个任务;然而多核处理器可以在同一时刻同时处理多个任务。由于现在的CPU基本都支持所谓的超线程,使得一个物理核心可以逻辑上实现两个任务的同时运行(比如Intel的i5处理器通常都是4核8线程,6核12线程),所以程序角度来看一个核心,系统在同一时刻可以同时运行的任务数为:CPU超线程数 * CPU个数。

线程与进程

基本概念

进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础,同时也是线程的容器。

线程(Thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。

一个操作系统拥有多个进程,一个进程拥有至少一个线程。一个程序拥有一个或多个进程,通常应用为一个进程,但诸如Chrome、Firefox等应用也会拥有多个进程。一般而言进程之间无法共享

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值