Back to questions
Principal
3
func getCarPrice() int64 { time.Sleep(1 * time.Second) return rand.Int63n(1000) } func main() { http.HandleFunc("/car/instant", func(resp http.ResponseWriter, req *http.Request) { fmt.Fprintf(resp, "%d", 0) }) http.ListenAndServe(":8080", nil) }
Companies where asked
Позитив Технолоджис
Answer from AI
sobes.tech AI
В данном коде HTTP-сервер всегда возвращает 0 по запросу "/car/instant", хотя функция getCarPrice() генерирует случайную цену с задержкой в 1 секунду.
Проблема в том, что обработчик не вызывает getCarPrice(), а сразу отвечает 0, возможно, чтобы не блокировать поток.
Если нужно вернуть актуальную цену машины, но при этом не блокировать обработчик, можно использовать асинхронный подход, например, кешировать цену в отдельной горутине и отдавать последнее значение мгновенно.
Пример с кешированием цены в фоне:
package main
import (
"fmt"
"math/rand"
"net/http"
"sync/atomic"
"time"
)
var carPrice int64
func updateCarPrice() {
for {
time.Sleep(1 * time.Second)
price := rand.Int63n(1000)
atomic.StoreInt64(&carPrice, price)
}
}
func main() {
go updateCarPrice()
http.HandleFunc("/car/instant", func(resp http.ResponseWriter, req *http.Request) {
price := atomic.LoadInt64(&carPrice)
fmt.Fprintf(resp, "%d", price)
})
http.ListenAndServe(":8080", nil)
}
Так сервер всегда быстро отвечает последним известным значением цены, обновляемым в фоне.