首页 > 编程语言 >Go并发编程入门

Go并发编程入门

时间:2024-07-30 14:17:39浏览次数:8  
标签:编程 Channels 并发 say Go world hello

本文由 ChatMoney团队出品

Go 并发编程:Goroutines 与 Channels

并发编程是 Go 语言的一个重要特点,它高效地利用现代硬件的多核和并行性来提升应用性能。本文将简介 Go 并发编程的基本概念,包括 Goroutines 和 Channels。

Goroutines

Goroutines 是 Go 并发编程的基本单位,它们是轻量级线程,由 Go 运行时管理。创建一个 goroutine 非常简单,只需在函数调用前添加 go 关键字即可

例如:

package main

import (
    "fmt"
    "time"
)

func say(s string) {
    for i := 0; i < 5; i++ {
        time.Sleep(100 * time.Millisecond)
        fmt.Println(s)
    }
}

func main() {
    go say("world")
    say("hello")
}

输出:
world
hello
hello
world
world
hello
hello
world
world
hello

在这个例子中,say("world") 在一个 goroutine 中并发执行,而 say("hello") 在主 goroutine 中执行。

Channels

Channels 是 Go 提供的一种在 goroutines 之间通信的方式。使用 make 函数创建一个 channel:

ch := make(chan int)

可以通过 <- 操作符发送和接收数据:

ch <- 42  // 发送数据到 channel
value := <- ch  // 从 channel 接收数据

结合使用 Goroutines 和 Channels,可以创建高效的并发程序。

package main

import "fmt"

func sum(s []int, c chan int) {
    sum := 0
    for _, v := range s {
       sum += v
    }
    c <- sum // 把 sum 发送到 channel c
    close(c) // 关闭通道,表示不再发送数据
}

func main() {
    s := []int{7, 2, 8, -9, 4, 0}

    c1 := make(chan int)
    c2 := make(chan int)
    
    go sum(s[:len(s)/2], c1)
    go sum(s[len(s)/2:], c2)
    
    x := <-c1 // 从 c1 中接收
    y := <-c2 // 从 c2 中接收
    
    fmt.Println(x, y, x+y)
}

输出
17 -5 12

在这个程序中,我们使用两个 goroutine 计算数组的部分和,然后通过 channel 返回结果。

最后

掌握这些基础知识,有助于你在实际开发中更有效地利用 Go 的并发特性,提升程序的性能和响应速度。

关于我们

本文由ChatMoney团队出品,ChatMoney专注于AI应用落地与变现,我们提供全套、持续更新的AI源码系统与可执行的变现方案,致力于帮助更多人利用AI来变现,欢迎进入ChatMoney获取更多AI变现方案!

标签:编程,Channels,并发,say,Go,world,hello
From: https://www.cnblogs.com/chatrun/p/18332251

相关文章

  • 如何在 Django 中加载特定应用程序的模板?
    所以我正在高级学习Django,我已经知道如何包含manage.py所在的BASE_DIR中的模板。但是我想知道如何在Django中的特定应用程序中查找模板。例如,我有一个名为“mysite”的项目和一个名为polls的应用程序。现在,我在settings.pyDIRS=中添加了模板[os.path.join(BA......
  • 计算机毕业设计django+vue《Python数据分析》的教学系统【开题+论文+程序】
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景在当今数字化时代,数据分析已成为各行各业不可或缺的技能之一,而Python作为数据分析领域的首选语言,其重要性日益凸显。然而,传统的教学模式在......
  • 深入解析 Go 语言 GMP 模型:并发编程的核心机制
    前言本章是Go并发编程的起始篇章,在未来几篇文章中我们会围绕Go并发编程进行理论和实战的学习,欢迎关注我哦!本章主要以介绍GMP模型为主,偏向于面试和八股,目的是让小伙伴们注重于知识本身,面向面试,面向八股,面向加薪。Go语言自诞生以来,就以其简洁、高效的并发模型著称。而这其中的核......
  • go-zero 微服务框架如何将日志输出到文件
    在go-zero中,默认日志是输出到控制台的,项目运行起来后,往往都是输出到日志,今天看看go-zero框架的API功能的日志配置。目前网上关于go-zero的配置相对少,找了一圈,没找到更多的资料或者案例,而且官方给的doc又是一笔带过,不多说,下面看看吧。我们直接给出对应的配置:userapi.......
  • Django 1.9 教程 __str__ () 不起作用
    我正在尝试使用Win10操作系统和Python3.5的Django1.9教程,Django版本是1.9。我已成功在“问题”和“选择”中创建并存储值。之后,当我按照教程__str__()django教程2更改了polls/model.py时。我收到此错误:我的polls\models.py是:>>>frompolls.mod......
  • mongodb数据库范围分片数据分布不均匀
    【说明】当前使用mongodb分片,三个分片mongos>sh.status()---ShardingStatus---shardingversion:{"_id":1,"minCompatibleVersion":5,"currentVersion":6,"clusterId":ObjectId(&quo......
  • 并发与并行:理解现代计算的核心概念
    在现代计算中,“并发”和“并行”是两个经常出现的术语,尽管它们听起来相似,但实际上有着不同的含义和应用场景。并发是一种编程和计算的设计理念,允许多个任务在同一时间段内进行。这并不意味着这些任务在同一时刻同时执行,是指它们在时间上交替进行,使多个任务看起来像是在同时进......
  • 基于Python Django的旅游景点数据分析与推荐系统
    基于PythonDjango的旅游景点数据分析与推荐系统。源码+数据库+文档(LW)。开发技术:Pythondjangomysql。项目内容:系统包括多个功能模块,涵盖了用户管理、旅游景点管理、管理员管理、系统管理等方面,以及一些其他辅助功能和信息展示模块。用户管理模块允许管理员管理系统中的用......
  • django基于Python的校园个人闲置物品换购平台
    django基于Python的校园个人闲置物品换购平台。源码+数据库+文档(lw+ppt)。开发技术:Pythondjangomysql。项目内容:系统主要包括主页、个人中心、用户管理、景点信息管理、系统管理等功能。    ......
  • 干货-并发编程提高——线程的中断(六)
    执行IO命令的线程不管是本地IO还是网络IO在JVM中线程其状态都是Runable。相对于操作系统,OS会将当前线程挂起,然后由调度队列另起一个线程来执行。此时硬盘正在与CPU并发工作。当IO完成时,CPU会收到来自硬盘的中断信号。类似于回调的操作,告诉你,已经处理完了,等着收尸吧。此时之前......