Rumah >pembangunan bahagian belakang >Golang >Bagaimanakah `runtime.Gosched()` Memberi Impak pada Pelaksanaan Program Go Sebelum dan Selepas Go 1.5?

Bagaimanakah `runtime.Gosched()` Memberi Impak pada Pelaksanaan Program Go Sebelum dan Selepas Go 1.5?

Susan Sarandon
Susan Sarandonasal
2024-12-30 14:37:16758semak imbas

How Does `runtime.Gosched()` Impact Go Program Execution Before and After Go 1.5?

Cara Gosched Mempengaruhi Pelaksanaan Program Go

Masalah

Dalam versi Go sebelum 1.5, sekeping kod yang melibatkan masa jalan.Gosched() diperhatikan untuk menjejaskan keluaran a program:

func say(s string) {
    for i := 0; i < 5; i++ {
        runtime.Gosched()
        fmt.Println(s)
    }
}

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

Output dengan runtime.Gosched():

hello
world
hello
world
hello
world
hello
world
hello

Output tanpa runtime.Gosched():

hello
hello
hello
hello
hello

Penjelasan

Dalam versi Go sebelum 1.5, runtime.Gosched() secara eksplisit menghasilkan kawalan kepada goroutine lain apabila dipanggil. Semasa program Go dijalankan pada urutan OS tunggal secara lalai, runtime.Gosched() membenarkan penjadual menukar pelaksanaan antara gorouti.

Apabila GOMAXPROCS dinyahset atau ditetapkan kepada 1, multitasking koperasi Go memerlukan goroutin untuk menghasilkan kawalan secara eksplisit . Oleh itu, dalam contoh kod di atas, output "dunia" hanya muncul apabila masa jalan.Gosched() dipanggil, kerana ia membenarkan penjadual bertukar kepada goroutine yang menjalankan pernyataan cetakan "dunia".

GOMAXPROCS dan Cooperative Multitasking

Dalam Go 1.5 dan lebih baru, masa jalan.GOMAXPROCS ditetapkan kepada bilangan teras perkakasan secara lalai, yang bermaksud bahawa Go boleh mencipta berbilang urutan OS untuk menjalankan goroutine.

Dengan GOMAXPROCS ditetapkan kepada nilai yang lebih besar daripada 1, goroutine boleh dijalankan secara selari. Walau bagaimanapun, tidak seperti dalam sistem multitasking preemptive, goroutin mesti masih memberikan kawalan secara eksplisit untuk membolehkan gorout lain dilaksanakan. Ini kerana Go menggunakan multitasking koperasi, di mana gorouti secara sukarela menyerahkan kawalan kepada penjadual.

Implikasi untuk Keselarian

Dengan GOMAXPROCS ditetapkan kepada nilai yang lebih besar daripada 1, hasil daripada goroutin bersilang boleh menjadi tidak tentu , kerana penjadual boleh menukar pelaksanaan antara mereka pada bila-bila masa. Ini boleh membawa kepada corak keluaran yang tidak dapat diramalkan, seperti yang dilihat dalam contoh di atas apabila GOMAXPROCS ditetapkan kepada 2.

Atas ialah kandungan terperinci Bagaimanakah `runtime.Gosched()` Memberi Impak pada Pelaksanaan Program Go Sebelum dan Selepas Go 1.5?. 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