登录
首页 >  Golang >  Go教程

Golang 函数:goroutine 与协程的异同

时间:2024-10-25 21:26:58 210浏览 收藏

在Golang实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《Golang 函数:goroutine 与协程的异同》,聊聊,希望可以帮助到正在努力赚钱的你。

在 Go 中,Goroutine 和协程都作为并发原语存在,但它们之间存在以下关键差异:Goroutine 拥有自己的栈空间,可以独立并发执行;协程通过协作多任务实现并发,可以在多个栈帧之间切换执行。Goroutine 可以共享数据,但需要使用同步机制确保一致性;协程在同一地址空间内运行,可以轻松共享数据。

Golang 函数:goroutine 与协程的异同

Golang 函数:goroutine 与协程的异同

在 Golang 中,goroutine 和协程都是轻量级的并发原语,但它们之间存在一些关键差异。

goroutine

  • Goroutine 是一个独立的并发执行体,它拥有自己的栈空间。
  • Goroutine 可以被创建、调度和终止。
  • Goroutine 可以共享数据,但必须使用同步机制(如互斥锁或条件变量)来确保数据一致性。

协程

  • 协程是一个协作性多任务机制,它通过显式挂起和恢复执行来实现并发。
  • 在协程中,执行可以在多个栈帧之间切换,而无需创建或调度新线程。
  • 协程可以轻松共享数据,因为它们在同一个地址空间内运行。

实战案例

考虑以下 Goroutine 示例,它实现了一个简单的并发 Web 服务器:

package main

import (
    "fmt"
    "net/http"
)

func main() {
    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
        fmt.Fprintln(w, "Hello, World!")
    })

    go http.ListenAndServe(":8080", nil)

    fmt.Println("Server running on port 8080")
    select {} // 阻塞主 goroutine,等待服务器运行
}

在这个示例中,http.ListenAndServe 在一个 goroutine 中执行,允许服务器在后台运行,同时主 goroutine 等待输入。

以下是如何使用协程实现相同功能:

package main

import (
    "fmt"
    "net/http"
)

func main() {
    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
        fmt.Fprintln(w, "Hello, World!")
    })

    // 创建一个协程来运行服务器
    go func() {
        http.ListenAndServe(":8080", nil)
    }()

    fmt.Println("Server running on port 8080")
    select {} // 阻塞主 goroutine,等待服务器运行
}

在这个示例中,服务器运行在协程中,允许它与主 goroutine 并发执行。

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>