Rumah > pembangunan bahagian belakang > Golang > Penjadualan kerja dan peruntukan berbilang tugas dalam bahasa Go

Penjadualan kerja dan peruntukan berbilang tugas dalam bahasa Go

WBOY
Lepaskan: 2023-06-02 14:51:06
asal
1055 orang telah melayarinya

Bahasa Go ialah bahasa pengaturcaraan yang cekap, ringkas dan serentak Sokongan konkurensi yang berkuasa dan urutan yang ringan ialah ciri utama bahasa Go. Bahasa Go juga menyediakan mekanisme yang sepadan untuk melaksanakan penjadualan masa dan peruntukan berbilang tugas Artikel ini akan memperkenalkan penjadualan kerja dan peruntukan berbilang tugas dalam bahasa Go.

1. Penjadualan Kerja

Penjadualan kerja dalam bahasa Go boleh dilaksanakan dengan bantuan pakej masa Fungsi NewTicker, NewTimer dan Sleep yang disediakan oleh pakej ini boleh membantu kami melengkapkan penjadualan kerja yang berbeza keperluan. Mengambil NewTicker sebagai contoh, prototaip fungsinya adalah seperti berikut:

func NewTicker(d Tempoh) *Ticker

Parameter d mewakili selang masa setiap ticker, dan Ticker mengembalikan saluran dalam yang boleh dibaca Dapatkan acara masa. Berikut ialah contoh mudah:

package main

import (
    "fmt"
    "time"
)

func main() {
    t := time.NewTicker(time.Millisecond * 500)
    defer t.Stop()
    for i := 0; i < 10; i++ {
        <-t.C
        fmt.Println("tick")
    }
}
Salin selepas log masuk

Dalam kod di atas, kami menggunakan NewTicker untuk mencipta penanda yang mencetuskan setiap 500 milisaat dan menggunakan gelung for untuk menerima mesej saluran dan mencetak "tanda".

Sudah tentu, kita juga boleh menggunakan NewTimer untuk mencipta jadual kerja sekali sahaja Prototaip fungsi adalah seperti berikut:

func NewTimer(d Duration) *Timer

Parameter d Mewakili tempoh menunggu, Pemasa mengembalikan saluran di mana peristiwa masa boleh dibaca. Berikut ialah contoh mudah:

package main

import (
    "fmt"
    "time"
)

func main() {
    fmt.Println("starting...")
    t := time.NewTimer(time.Second)
    <-t.C
    fmt.Println("done")
}
Salin selepas log masuk

Dalam kod di atas, kami menggunakan NewTimer untuk mencipta pemasa dengan tempoh 1 saat dan menunggu pemasa tamat dalam saluran. Coretan kod ini akan menunggu selama 1 saat dan kemudian mencetak "selesai".

2. Peruntukan berbilang tugas

Bahasa Go sememangnya menyokong pengaturcaraan serentak, jadi kami boleh melaksanakan peruntukan berbilang tugas dengan mudah. Berikut ialah contoh mudah:

package main

import (
    "fmt"
    "time"
)

func worker(id int, jobs <-chan int, results chan<- int) {
    for j := range jobs {
        fmt.Printf("worker %d processing job %d
", id, j)
        time.Sleep(time.Second)
        results <- j * 2
    }
}

func main() {
    jobs := make(chan int, 100)
    results := make(chan int, 100)

    for w := 1; w <= 3; w++ {
        go worker(w, jobs, results)
    }

    for j := 1; j <= 5; j++ {
        jobs <- j
    }
    close(jobs)

    for a := 1; a <= 5; a++ {
        <-results
    }
}
Salin selepas log masuk

Dalam kod di atas, kami melaksanakan pengalokasi tugas mudah, mencipta 3 coroutine pekerja dan menetapkan tugasan kepada saluran. Setiap coroutine pekerja membaca tugasan daripada saluran, melaksanakan tugasan dan mengembalikan keputusan kepada saluran hasil. Fungsi utama menunggu semua keputusan dikembalikan.

Ringkasan

Sokongan serentak yang cekap bagi bahasa Go memberikan kami penjadualan kerja yang mudah dan pelaksanaan peruntukan berbilang tugas. Melalui fungsi NewTicker, NewTimer dan Sleep bagi pakej masa, kami boleh melaksanakan penjadualan masa dengan mudah. Melalui coroutine dan saluran, kami boleh melaksanakan pengedaran berbilang tugas dengan mudah. Ciri-ciri ini membolehkan kami melaksanakan pengaturcaraan serentak dan pengagihan tugas dengan lebih pantas apabila menulis kod setiap hari, dan meningkatkan kecekapan dan prestasi kod berjalan.

Atas ialah kandungan terperinci Penjadualan kerja dan peruntukan berbilang tugas dalam bahasa Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan