(12-1)并发编程:并发编程基础

并发指在同一时间内可以执行多个任务,这样可以提高处理效率。并发编程的含义比较广泛,包含多线程编程、多进程编程及分布式程序等。并发是Go语言的最大优势之一,Go语言使用轻量级线程(称为goroutine)和通道(channel)来实现并发,这使得它能够更好地处理并发任务和网络编程等场景。在本章的内容中,将详细讲解Go语言并发编程的知识,通过具体实例讲解各个知识点的用法。

12.1  并发编程基础

在学习Go语言并发编程的知识之前,我们首先来了解和并发编程相关的概念。

12.1.1 进程

我们都知道计算机的核心是CPU,它承担了所有的计算任务,而操作系统是计算机的管理者,它负责任务的调度、资源的分配和管理、统领整个计算机硬件。应用程序是具有某种功能的程序,程序是运行于操作系统之上的。

进程是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程,是操作系统进行资源分配和调度的一个独立单位,是应用程序运行的载体。进程是一种抽象的概念,从来没有统一的标准定义,它一般由程序、数据集合和进程控制块三部分组成。程序用于描述进程要完成的功能,是控制进程执行的指令集;数据集合是程序在执行时所需要的数据和工作区;程序控制块包含进程的描述信息和控制信息是进程存在的唯一标志。

在操作系统中,进程是独立存在的,它拥有自己独立的资源,多个进程可以在同一个处理器上并发执行且互不影响。每一个进程都包括创建、运行、消亡3个阶段。我们日常使用的计算机都在同时多个程序,打开Windows任务管理器,在进程选项卡中就可以查看进程,如图12-1所示。通过图12-1可以看到,Microsoft Edge、Microsoft Word以及此时电脑正在运行的其他程序,将软件正常关闭或者右键结束进程,都可以使这个进程消亡。

图12-1 计算机进程

一般地,进程具有如下特征:

  1. 动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生,动态消亡的;
  2. 并发性:任何进程都可以同其他进行一起并发执行;
  3. 独立性:进程是系统进行资源分配和调度的一个独立单位;
  4. 结构性:进程由程序,数据和进程控制块三部分组成。

注意:实际上,计算机并行运行的所有进程并不是同时执行,因为计算机中所有的程序都是由CPU执行的,而CPU只有有限多个核心,一个CPU核心只能同时执行一个进程,但是操作系统会给各个同时打开的程序分配占用时间,在这段时间里可以执行Microsoft Edge,当这段时间段过了则切换到Microsoft Word,之后在切换到其他程序。由于CPU的执行速度很快,人们根本发觉不到它是在切换执行,所以会有一种计算机同时执行多个程序的感觉。当然,后面讲到的多线程同样如此。

12.1.2  线程

在早期的操作系统中并没有线程的概念,进程是拥有资源和独立运行的最小单位,也是程序执行的最小单位。任务调度采用的是时间片轮转的抢占式调度方式,而进程是任务调度的最小单位,每个进程有各自独立的一块内存,使得各个进程之间内存地址相互隔离。后来,随着计算机技术的发展,对CPU的要求越来越高,进程之间的切换开销较大,已经无法满足越来越复杂的程序的要求了。于是就发明了线程,线程是程序执行中一个单一的顺序控制流程,是程序执行流的最小单元,是处理器调度和分派的基本单位。一个进程可以有一个或多个线程,各个线程之间共享程序的内存空间(也就是所在进程的内存空间)。一个标准的线程由线程ID、当前指令指针PC、寄存器和堆栈组成。而进程由内存空间(程序、数据、进程空间、打开的文件)和一个或多个线程组成。打开Windows任务管理器,点击性能选项卡,可以查看当前系统的线程数,如图12-2所示。通过图12-2可以看出,当前系统的总进程数为163、总线程数为2790,总线程数要比总进程数多很多,原因正是一个进程里面可以有多个线程在同时执行。在Java开发中,多条线程在同一时间段内交替执行称为并发,而多条线程同时执行称为并行。

图12-2 当前系统的进程与线程

12.1.3  并发、并行和协程

多线程程序在单核心的 CPU上运行,称为并发;多线程程序在多核心的CPU上运行,称为并行。并发与并行并不相同,并发主要由切换时间片来实现“同时”运行,并行则是直接利用多核实现多线程的运行。在Go语言程序中可以设置使用的核心数,以发挥多核计算机的能力。

协程独立的栈空间,共享堆空间,由用户自己控制调度,本质上有点类似于用户级线程,这些用户级线程的调度也是自己实现的。

12.1.4  Go语言并发编程的核心概念

Go语言的并发编程是其最具特色和优势的特性之一,以下是几个和Go语言并发编程相关的核心概念。

(1)goroutine

Goroutine是由Go语言运行时管理的轻量级线程,可以在单个程序中同时并发执行许多任务。与传统的线程相比,goroutine更加高效、易于使用和易于管理。

(2)通道

通道(channel)是用于在goroutine之间通信和同步的机制,它们提供了一种安全、可靠和高效的方法来共享数据,避免竞态条件和死锁问题。

(3)select语句

select语句是一种用于处理通道的选择器,可以使我们更好地控制goroutine之间的通信和同步。select语句允许我们同时等待多个通道的操作,并根据它们的状态进行不同的处理。

总之,Go语言并发编程是非常重要和强大的特性,通过goroutine、通道和select语句,开发者可以轻松地创建高效的并发程序,并为多个任务提供安全、可靠和高效的通信和同步机制。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农三叔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值