iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > GO >分析Go语言中CSP并发模型与Goroutine的基本使用
  • 951
分享到

分析Go语言中CSP并发模型与Goroutine的基本使用

2024-04-02 19:04:59 951人浏览 薄情痞子
摘要

目录一、并发实现模型1.1、多进程1.2、多线程1.3、协程二、共享内存与CSP三、Goroutine一、并发实现模型 1.1、多进程 在之前的文章当中我们曾经介绍过,进程是操作系统

一、并发实现模型

1.1、多进程

在之前的文章当中我们曾经介绍过,进程是操作系统资源分配的最小单元。所以多进程是在操作系统层面的并发模型,因为所有的进程都是有操作系统的内核管理的。所以每个进程之间是独立的,每一个进程都会有自己单独的内存空间以及上下文信息,一个进程挂了不会影响其他进程的运行。这个也是多进程最大的优点,但是它的缺点也很明显。

最大的缺点就是开销很大,创建、销毁进程的开销是最高的,远远高于创建、销毁线程。并且由于进程之间互相独立,导致进程之间通信也是一个比较棘手的问题,进程之间共享内存也非常不方便。因为这些弊端使得在大多数场景当中使用多进程都不是一个很好的做法。

1.2、多线程

多线程是目前最流行的并发场景的解决方案,由于线程更加轻量级,创建和销毁的成本都很低。并且线程之间通信以及共享内存非常方便,和多进程相比开销要小得多。

但是多线程也有缺点,一个缺点也是开销。虽然线程的开销要比进程小得多,但是如果创建和销毁频繁的话仍然是不小的负担。针对这个问题诞生了线程池这种设计。创建一大批线程放入线程池当中,需要用的时候拿出来使用,用完了再放回,回收和领用代替了创建和销毁两个操作,大大提升了性能。另外一个问题是资源的共享,由于线程之间资源共享更加频繁,所以在一些场景当中我们需要加上等设计,避免并发带来的数据紊乱。以及需要避免死锁等问题。

1.3、协程

也叫做轻量级线程,本质上仍然是线程。相比于多线程和多进程来说,协程要小众得多,相信很多同学可能都没有听说过。和多线程最大的区别在于,协程的调度不是基于操作系统的而是基于程序的。

也就是说协程更像是程序里的函数,但是在执行的过程当中可以随时挂起、随时继续。

我们举个例子,比如这里有两个函数:


def A():
    print '1'
    print '2'
    print '3'

def B():
    print 'x'
    print 'y'
    print 'z'

如果我们在一个线程内执行A和B这两个函数,要么先执行A再执行B要么先执行B再执行A。输出的结果是确定的,但如果我们用写成来执行A和B,有可能A函数执行了一半刚输出了一条语句的时候就转而去执行B,B输出了一条又再回到A继续执行。不管执行的过程当中发生了几次中断和继续,在操作系统当中执行的线程都没有发生变化。也就是说这是程序级的调度。

那么和多线程相比,我们创建、销毁线程的开销就完全没有了,整个过程变得非常灵活。但是缺点是由于是程序级别的调度,所以需要编程语言自身的支持,如果语言本身不支持,就很难使用了。目前原生就支持协程的语言并不多,显然golang就是其中一个。

二、共享内存与CSP

我们常见的多线程模型一般是通过共享内存实现的,但是共享内存就会有很多问题。比如资源抢占的问题、一致性问题等等。为了解决这些问题,我们需要引入多线程锁、原子操作等等限制来保证程序执行结果的正确性。

除了共享内存模型之外,还有一个经典模型就是CSP模型。CSP模型其实并不新,发表已经好几十年了。CSP的英文全称是Communicating Sequential Processes,翻译过来的意思是通信顺序进程。CSP描述了并发系统中的互动模式,是一种面向并发的语言的源头。

Golang只使用了CSP当中关于Process/Channel的部分。简单来说Process映射Goroutine,Channel映射Channel。Goroutine即Golang当中的协程,Goroutine之间没有任何耦合,可以完全并发执行。Channel用于给Goroutine传递消息,保持数据同步。虽然Goroutine之间没有耦合,但是它们与Channel依然存在耦合。

整个Goroutine和Channel的结构有些类似于生产消费者模式,多个线程之间通过队列共享数据,从而保持线程之间独立。这里不过多深入,我们大概有一个印象即可。

三、Goroutine

Goroutine即golang当中的协程,这也是golang这门语言的核心精髓所在。正是因为Goroutine,所以golang才叫做golang,所以人们才选择golang。

相比于Java、python等多线程的复杂的使用体验而言,golang当中的Goroutine的使用非常简单,简单到爆表。只需要一个关键字就够了,那就是go。所以你们应该明白为什么golang叫做Go语言不叫别的名字了吧?

比如我们有一个函数:


func Add(x, y int) int{
    z := x + y
    fmt.Println(z)
}

我们希望启动一个goroutine去执行它, 应该怎么办?很简单,只需要一行代码:


go Add(3, 4)

我们还可以用go关键字来使用goroutine来执行一个匿名函数:


go func(x, y int) {
    fmt.Println(x + y)
}(3, 4)

需要注意的是,当我们使用go关键字的时候,是不能获取返回值的。也就是说z := go Add(3, 4)是违法的。乍看起来似乎不合理,但是道理其实是很简单的。如果我们希望一个变量承接一个函数的返回值,说明这里的逻辑是串行的,那么我们使用goroutine的意义是什么?所以这里看似不合理,其实是设计者下了心思的。

以上就是分析Go语言中CSP并发模型与Goroutine的基本使用的详细内容,更多关于Go CSP并发模型 Goroutine的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: 分析Go语言中CSP并发模型与Goroutine的基本使用

本文链接: https://www.lsjlt.com/news/128261.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 分析Go语言中CSP并发模型与Goroutine的基本使用
    目录一、并发实现模型1.1、多进程1.2、多线程1.3、协程二、共享内存与CSP三、Goroutine一、并发实现模型 1.1、多进程 在之前的文章当中我们曾经介绍过,进程是操作系统...
    99+
    2024-04-02
  • Go语言CSP并发模型goroutine及channel底层实现原理
    目录Go的CSP并发模型(goroutine + channel)1、goroutinegoroutine的优点:2、channel无缓存channel有缓存channel3、Go并...
    99+
    2024-04-02
  • Go并发中goroutine模型与调度策略的示例分析
    这篇文章给大家分享的是有关Go并发中goroutine模型与调度策略的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。单进程操作系统早期的单进程操作系统,可以理解为只有一个时间轴,CPU顺序执行每一个进程/...
    99+
    2023-06-25
  • Go语言中并发goroutine底层原理的示例分析
    小编给大家分享一下Go语言中并发goroutine底层原理的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、基本概念①并发、并行区分1.概念并发:同一时间段内一个对象执行多个任务,充分利用时间并行:同一时刻,多个...
    99+
    2023-06-29
  • 深入理解Go语言的并发编程:Go的并发模型解析
    Go语言作为一门流行的编程语言,以其出色的并发编程能力而闻名。并发编程是在同一时间内执行多个独立的任务,通过充分利用多核处理器的性能以提高程序的性能和效率。在Go语言中,并发编程是一种...
    99+
    2024-03-04
    go语言 标准库
  • Goroutine与Coroutine的对比分析:如何选择最佳并发模型?
    Goroutine与Coroutine的对比分析:如何选择最佳并发模型? 随着计算机技术的不断发展,多任务处理和并发编程成为了软件开发中的一个重要议题。在并发编程中,Goroutine...
    99+
    2024-03-12
    并发模型 go语言
  • Go语言中的并发模型:如何与Shell和Bash对比?
    在计算机科学领域,"并发"一词是指在同一时间内执行多个独立的任务。在现代编程语言中,支持并发的语言越来越普遍。其中,Go语言因其强大的并发模型而备受推崇。本文将讨论Go语言的并发模型,并将其与Shell和Bash进行对比。 一、Shell...
    99+
    2023-09-30
    并发 shell bash
  • Go语言中interface语法与使用实例分析
    这篇“Go语言中interface语法与使用实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Go语言中interfac...
    99+
    2023-07-02
  • 分析与优化:如何调试和优化Go语言中的goroutine程序?
    分析与优化:如何调试和优化Go语言中的goroutine程序? 在Go语言中,goroutine是一种轻量级的线程,可以实现并发执行。使用goroutine可以让程序更高效地利用多核处...
    99+
    2024-03-12
    调试 优化 go语言
  • Go语言中的基本map使用方法
    Go语言是一种开源的编程语言,具有高效性和简洁性,其中的数据结构之一就是map。在Go语言中,map是一种“键值对”的数据结构,可以用来存储一系列无序的键值对。本文将详细介绍Go语言中...
    99+
    2024-04-02
  • Go语言在大型项目开发中的适用性分析
    Go语言在大型项目开发中的适用性分析 随着互联网的快速发展,大型项目的开发变得日益复杂和多样化。开发人员在选择适合项目的编程语言时,需要考虑到语言的性能、可维护性、并发处理能力等因素。...
    99+
    2024-03-11
    go语言 大型项目 适用性
  • Go语言中chan通道的基本概念与使用方法
    Go语言中chan通道的基本概念与使用方法 Go语言作为一门并发编程语言,chan通道(channel)是其提供的一种重要的并发原语,用于在不同的goroutine之间进行通信和同步,...
    99+
    2024-03-12
    go语言 使用方法 通道
  • Go语言中SQL的基本概念及用法解析
    Go语言中SQL的基本概念及用法解析 SQL(Structured Query Language)是一种专门用来管理和操作关系数据库的语言。在Go语言中,我们通常使用SQL来执行数据库...
    99+
    2024-04-02
  • Go语言中的基础数据类型使用实例
    目录前言基础数据类型整型有符号整型无符号整型特殊整型浮点型复数布尔值字符串字符串的转义符多行字符串常用的操作字符串的手段byte和rune类型修改字符串类型转换小结前言 任何语言都...
    99+
    2023-05-14
    Go 基础数据类型 Go 数据类型
  • Go语言中的基础数据类型如何使用
    这篇文章主要介绍了Go语言中的基础数据类型如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Go语言中的基础数据类型如何使用文章都会有所收获,下面我们一起来看看吧。基础数据类型整型在Go中整型数据类型主要分...
    99+
    2023-07-05
  • Go语言中IOC的优势与应用场景分析
    在Go语言中IOC的优势与应用场景分析 随着Go语言的快速发展,越来越多的开发者开始使用Go语言来构建各种规模的应用程序。在Go语言中,控制反转(Inversion of Contro...
    99+
    2024-04-02
  • 自然语言处理在开发技术中的应用——从语言模型到情感分析
    随着人工智能技术的不断发展,自然语言处理(Natural Language Processing, NLP)在各行各业中的应用越来越广泛。从智能客服到机器翻译,从情感分析到文本分类,NLP技术正在改变我们的生活和工作方式。本文将从语言模型...
    99+
    2023-10-16
    编程算法 自然语言处理 开发技术
  • Go语言中的for循环使用实例分析
    这篇文章主要介绍“Go语言中的for循环使用实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Go语言中的for循环使用实例分析”文章能帮助大家解决问题。问题案例一:取地址符在 Go 语言中,我...
    99+
    2023-07-04
  • 使用Go语言开发高性能的数据分析应用
    随着大数据时代的到来,数据分析变得越来越重要。无论是企业管理决策,市场营销,还是科学研究,数据分析的应用都扮演着关键的角色。为了提高数据分析的效率和性能,许多开发者开始关注使用Go语言开发高性能的数据分析应用。Go语言是由Google开发的...
    99+
    2023-11-20
    数据分析 Go语言 高性能
  • 如何使用Go语言并发编程处理Shell脚本中的大数据?
    随着数据量的不断增大,传统的Shell脚本处理方式已经不能满足现代数据处理的需求。而Go语言则是一种高效的并发编程语言,可以很好地处理大数据量的问题。本文将介绍如何使用Go语言并发编程处理Shell脚本中的大数据。 一、Go语言的并发编程...
    99+
    2023-06-27
    并发 shell 大数据
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作