Rumah >pembangunan bahagian belakang >Golang >Panduan Pemula: Bagaimana untuk melaksanakan caching dalam golang?

Panduan Pemula: Bagaimana untuk melaksanakan caching dalam golang?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBasal
2023-06-20 10:05:531785semak imbas

Dalam bahasa pengaturcaraan moden, caching ialah alat yang digunakan secara meluas untuk meningkatkan prestasi aplikasi dan mengurangkan masa tindak balas. Golang ialah bahasa pengaturcaraan yang pantas dan berprestasi tinggi Ia secara semula jadi menyokong teknologi caching, kerana caching juga mempunyai kesan penting pada prestasi aplikasi Golang.

Dalam artikel ini, kami akan mempelajari cara melaksanakan caching dalam Golang dan cara menggunakan caching untuk meningkatkan prestasi aplikasi anda.

  1. Apakah itu cache?

Caching ialah teknologi yang menyimpan hasil pengiraan atau pertanyaan pangkalan data untuk kegunaan masa hadapan. Pada kali seterusnya keputusan yang sama diminta, cache segera mengembalikan hasil yang diambil sebelum ini tanpa perlu mengira semula atau menanyakan data. Dalam sesetengah kes, caching boleh meningkatkan prestasi aplikasi dengan ketara dan mengurangkan masa tindak balas.

  1. Caching dalam Golang

Di Golang, kami boleh menggunakan struktur data peta untuk melaksanakan caching. Struktur data Peta menyediakan mekanisme penyimpanan pasangan nilai kunci, di mana setiap kunci dikaitkan dengan nilai. Kita boleh menggunakan peta untuk menyimpan hasil pengiraan atau hasil pertanyaan, bersama-sama dengan kuncinya. Apabila kunci yang sama diminta pada masa akan datang, kita boleh mendapatkan nilai yang berkaitan daripada peta tanpa perlu mengira atau menanyakan keputusannya lagi.

Berikut ialah contoh penggunaan peta untuk melaksanakan caching:

package main

import (
    "fmt"
    "time"
)

// Cache stores previously computed results.
var Cache = map[string]interface{}{}

func ExampleCache() {
    // Check if the key is in the cache.
    value, ok := Cache["mykey"]
    if ok {
        fmt.Println("From Cache:", value)
        return
    }

    // Compute the result if it's not in the cache.
    time.Sleep(2 * time.Second)
    result := "Hello, World!"

    // Store the result in the cache.
    Cache["mykey"] = result

    fmt.Println("Computed Result:", result)
}

func main() {
    ExampleCache()
    ExampleCache()
}

Dalam kod di atas, kami telah mencipta pembolehubah peta bernama "Cache" yang menyimpan pasangan nilai kunci. Apabila kunci yang sama diminta pada masa akan datang, kami boleh mendapatkan semula nilai dengan mudah daripada peta "Cache".

Dalam contoh kami, kami mensimulasikan pengiraan hasil dengan menggunakan pernyataan masa.Sleep. Jika nilai ditemui dan dikembalikan, "Dari Cache:" dan nilai yang sepadan akan dicetak, jika tidak, "Hasil Kiraan:" dan hasil pengiraan akan dicetak.

  1. Menggunakan caching dengan tamat masa

Dalam dunia nyata, caching mungkin menjadi basi atau tidak diperlukan lagi dalam sesetengah situasi. Sebagai contoh, nilai mungkin telah diubah suai atas sebab tertentu, atau menjadi usang atau tidak diperlukan lagi.

Dalam kes ini, kita boleh menggunakan cache dengan fungsi tamat masa, yang akan mengosongkan cache secara automatik selepas tempoh masa tertentu. Jenis caching ini membantu kami memastikan bahawa kami menggunakan data terkini dan tidak menggunakan data lapuk.

Berikut ialah contoh melaksanakan cache dengan fungsi tamat masa dalam Golang:

package main

import (
    "fmt"
    "sync"
    "time"
)

// ExpirationMap stores keys and expirations.
type ExpirationMap struct {
    sync.RWMutex
    data map[string]time.Time
}

// Expired returns true if key has expired.
func (m *ExpirationMap) Expired(key string) bool {
    m.RLock()
    defer m.RUnlock()

    // Get the key's expiration time.
    expiration, ok := m.data[key]
    if !ok {
        return true
    }

    // Check if the key has expired.
    return time.Until(expiration) < 0
}

// Set sets the key's expiration time.
func (m *ExpirationMap) Set(key string, duration time.Duration) {
    m.Lock()
    defer m.Unlock()

    // Set the key's expiration time.
    m.data[key] = time.Now().Add(duration)
}

// Delete removes the key from the map.
func (m *ExpirationMap) Delete(key string) {
    m.Lock()
    defer m.Unlock()

    // Delete the key from the map.
    delete(m.data, key)
}

// Cache stores previously computed results.
var Cache = map[string]interface{}{}

// Expiration stores expiration times for cache keys.
var Expiration = ExpirationMap{data: make(map[string]time.Time)}

func ExampleCacheWithExpiration() {
    // Check if the key is in the cache.
    value, ok := Cache["mykey"]
    if ok && !Expiration.Expired("mykey") {
        fmt.Println("From Cache:", value)
        return
    }

    // Compute the result if it's not in the cache.
    time.Sleep(2 * time.Second)
    result := "Hello, World!"

    // Store the result in the cache.
    Cache["mykey"] = result
    Expiration.Set("mykey", 5*time.Second)

    fmt.Println("Computed Result:", result)
}

func main() {
    ExampleCacheWithExpiration()
    ExampleCacheWithExpiration()

    // Wait for the expiration time to elapse.
    time.Sleep(6 * time.Second)

    ExampleCacheWithExpiration()
}

Dalam kod di atas, kami menggunakan struktur yang dipanggil "ExpirationMap", yang menyimpan kunci dan masa tamat tempoh. Kami menggunakan peta "Tamat Tempoh" untuk merekodkan masa tamat tempoh setiap kunci dalam cache. Jika kunci tamat tempoh, maka kita perlu mengira semula hasilnya.

Dalam contoh kami, apabila kami memanggil fungsi "ExampleCacheWithExpiration" pada kali pertama dan kedua, nilai kunci "mykey" akan dikira dan disimpan dalam cache kami dan masa tamat tempoh akan ditetapkan ialah 5 detik. Pada panggilan kedua ke fungsi tersebut, kita akan mendapat nilai kunci "mykey" daripada cache kerana kunci itu belum tamat tempoh lagi.

Pada panggilan ketiga ke fungsi kami akan menunggu lebih daripada 5 saat untuk kekunci "mykey" tamat tempoh. Apabila kunci tamat tempoh, kami memaksa pengiraan semula keputusan supaya kami boleh menggunakan data terkini.

  1. Ringkasan

Kaedah melaksanakan caching di Golang adalah sangat mudah. Kita boleh menggunakan struktur data peta untuk menyimpan pasangan nilai kunci dan keputusannya. Kami juga boleh menggunakan caching dengan tamat masa untuk memastikan kami menggunakan data terkini dan tidak menggunakan data lapuk.

Walaupun caching boleh meningkatkan prestasi aplikasi dengan ketara, kami juga perlu memberi perhatian kepada penggunaan cache. Apabila menggunakan cache, kita perlu memastikan ketekalan cache dan melaraskan saiz cache mengikut keperluan. Faedah sebenar daripada caching hanya boleh didapati jika ia digunakan dengan betul.

Atas ialah kandungan terperinci Panduan Pemula: Bagaimana untuk melaksanakan caching dalam golang?. 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