php中文网

Golang 函数:goroutine 与协程的异同

php中文网

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

Golang 函数:goroutine 与协程的异同

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

goroutine

立即学习“go语言免费学习笔记(深入)”;

  • 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 函数:goroutine 与协程的异同的详细内容,更多请关注php中文网其它相关文章!