Back to questions
Senior
3
Задача: «Пинг-понг с таймаутом» Напишите функцию pingPong, которая: - Запускает две горутины: одна генерирует сообщения "ping", другая — "pong". - Горутины должны обмениваться сообщениями через общий канал строго по очереди. - Обмен продолжается 3 секунды, после чего программа должна завершиться (graceful shutdown). - Используйте контекст для отмены через таймаут. - Выводите каждое сообщение на экран вместе с временем (в миллисекундах от старта). Пример ожидаемого вывода: text 0ms: ping
Companies where asked
FREEDOM LIFESTYLE
Answer from AI
sobes.tech AI
go package main
import ( "context" "fmt" "time" )
func pingPong() { ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second) defer cancel()
ch := make(chan string)
start := time.Now()
// Функция для вывода с временем от старта
printMsg := func(msg string) {
elapsed := time.Since(start).Milliseconds()
fmt.Printf("%dms: %s\n", elapsed, msg)
}
// Горутина ping
go func() {
for {
select {
case <-ctx.Done():
return
case ch <- "ping":
}
}
}()
// Горутина pong
go func() {
for {
select {
case <-ctx.Done():
return
case msg := <-ch:
printMsg(msg)
if msg == "ping" {
ch <- "pong"
}
}
}
}()
// Главная горутина читает pong и выводит
for {
select {
case <-ctx.Done():
return
case msg := <-ch:
printMsg(msg)
}
}
}
func main() { pingPong() }
В этом решении две горутины обмениваются сообщениями через канал `ch`. Горутина `ping` отправляет "ping", горутина `pong` читает "ping", выводит и отправляет "pong" обратно. Главная горутина читает "pong" и выводит. Контекст с таймаутом 3 секунды обеспечивает graceful shutdown.