Sobes.tech
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)
}

Так сервер всегда быстро отвечает последним известным значением цены, обновляемым в фоне.