Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Analisis teknologi teras bahasa Go

Analisis teknologi teras bahasa Go

WBOY
WBOYasal
2024-04-03 17:15:011047semak imbas

Pengaturcaraan serentak dalam Go dilaksanakan menggunakan goroutine (benang ringan) dan saluran (paip komunikasi). Goroutine dicipta melalui kata kunci pergi, yang sangat ringan dan boleh mencipta sejumlah besar goroutin tanpa menjejaskan prestasi. Saluran digunakan untuk komunikasi antara goroutine dan merupakan paip bertaip. Contoh ini menunjukkan aplikasi perangkak serentak, menggunakan goroutine untuk merangkak URL secara selari untuk meningkatkan kecekapan.

Analisis teknologi teras bahasa Go

Analisis Teknologi Teras Go: Pengaturcaraan Serentak

Model konkurensi dalam Go adalah berdasarkan konsep goroutine (benang ringan) dan saluran (paip komunikasi). Dengan memanfaatkan sepenuhnya ciri ini, pembangun boleh membina aplikasi berprestasi tinggi yang sangat serentak.

Goroutine

Goroutine ialah urutan ringan dalam Go, dibuat dengan kata kunci go. Ia dijalankan pada penjadual coroutine, dan tidak seperti benang tradisional, goroutine sangat ringan dan beribu-ribu boleh dibuat tanpa kesan prestasi yang ketara. Kod berikut menunjukkan cara mencipta dan menggunakan goroutines:

package main

import (
    "fmt"
    "runtime"
)

func main() {
    fmt.Printf("Number of goroutines: %d\n", runtime.NumGoroutine()) // 当前正在运行的 goroutine 数量

    // 创建一个 goroutine
    go func() {
        fmt.Println("Hello from a goroutine!")
    }()

    fmt.Printf("Number of goroutines: %d\n", runtime.NumGoroutine()) // 当前正在运行的 goroutine 数量
}

Saluran

Saluran ialah paip yang digunakan untuk komunikasi antara gorouti. Mereka ditaip, yang bermaksud mereka hanya boleh menghantar nilai jenis tertentu. Kod berikut menunjukkan cara membuat dan menggunakan saluran:

package main

import (
    "fmt"
)

func main() {
    // 创建一个 int 类型的 channel
    c := make(chan int)

    // 向 channel 发送值
    go func() {
        c <- 42
    }()

    // 从 channel 接收值
    v := <-c
    fmt.Println(v) // 输出:42
}

Kes praktikal: Perangkak serentak

Berikut ialah contoh mudah menggunakan goroutine dan saluran untuk membina perangkak serentak:

package main

import (
    "fmt"
    "net/http"
    "sync"
)

var wg sync.WaitGroup

func main() {
    // 要爬取的 URL 列表
    urls := []string{
        "https://example.com",
        "https://example2.com",
        "https://example3.com",
    }

    // 创建 channel 来接收每个 URL 的响应
    results := make(chan string)

    // 为每个 URL 创建一个 goroutine
    for _, url := range urls {
        wg.Add(1)
        go func(url string) {
            resp, err := http.Get(url)
            if err != nil {
                fmt.Printf("Error fetching %s: %v\n", url, err)
            } else if resp.StatusCode == 200 {
                results <- url
            }
            wg.Done()
        }(url)
    }

    // 从 channel 中获取响应
    go func() {
        for url := range results {
            fmt.Println(url)
        }
    }()

    // 等待所有 goroutine 完成
    wg.Wait()
}

Dengan menggunakan, goroutine dan saluran perangkak ini boleh merangkak serentak Ambil berbilang URL, sekali gus meningkatkan kecekapan.

Atas ialah kandungan terperinci Analisis teknologi teras bahasa Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn