make(chan string)
messages <- "buffered"
fmt.Println(<-messages)
messages <- "channel"
fmt.Println(<-messages)
}
Кто-нибудь может объяснить почему последовательная отправка и приём данных из канала, требует наличия буфферизованного канала ?
она не требует, просто если ты в одной рутине это делать будешь, то ты залочишься при записи в него, если канал будет небуф
А, т.е. если канал небуферизированный, то можно делать только один раз отправку в этой горутине ?
Пока другая рутина не прочитает значение
если канал не буферизированый тогда запись в него заблокируется, если его никто не читает
Почитай лучше про разницу буф и небуф каналов, станет понятнее
А почему тогда вот этот код работает package main import "fmt" func main() { messages := make(chan string) go func(){ messages <- "buffered" }() go func(){ messages <- "channel" }() fmt.Println(<-messages) fmt.Println(<-messages) } А вот этот нет: package main import "fmt" func main() { messages := make(chan string) messages <- "buffered" messages <- "channel" go func(){ fmt.Println(<-messages) }() go func(){ fmt.Println(<-messages) }() }
Ну так лочишь отдельную рутину, а во втором случае ты лочишь основную горутину - main функцию
тут у тебя читалки запускаются до записи. а ниже сначала пишешь и блочишь. читалки вообще не запускаются.
https://www.google.com/amp/s/nuancesprog.ru/p/5381/%3Famp
Обсуждают сегодня