safe_cache

Crates.iosafe_cache
lib.rssafe_cache
version0.2.2
sourcesrc
created_at2023-11-18 03:39:50.768047
updated_at2023-12-20 14:00:21.909266
descriptionA key-value cache library in Rust featuring dynamic typing with support for multiple data types, automatic expiration, and thread-safe operations using Arc and RwLock.
homepage
repositoryhttps://github.com/Baiyuetribe/safe_cache
max_upload_size
id1040234
size10,076
佰阅 (Baiyuetribe)

documentation

README

SAFE_Cache

Features

  • k-v 键值缓存,v 值为泛型,支持任意类型
  • Mutex 并发安全
  • Rwlock 模式读写锁
  • 线程安全
  • 简单有效

Install

cargo add safe_cache

Usage

场景 1:定义缓存及清理时间

use safe_cache::{Cache, async_cleanup_task}; // with Mutex
// use safe_cache::{CacheRwLock, async_cleanup_task_rwlock}; or rwlock
use std::sync::Arc;

async fn main() {
    let cache = Arc::new(Cache::new());

    // 启动定时任务清理内存
    let cache_clone = Arc::clone(&cache);
    async_cleanup_task(cache_clone, 10).await; // 10秒清理一次


    // 示例使用
     // 示例使用
    cache.set("number".to_string(), 42, 20);
    cache.set("list".to_string(), vec![1, 2, 3], 60);
    cache.set("text".to_string(), "Hello, Rust!".to_string(), 0); // 0代表永不过期

    println!("Value for number: {:?}", cache.get::<u16>("number"));
    println!("Value for list: {:?}", cache.get::<Vec<i32>>("list"));
    println!("Value for text: {:?}", cache.get::<Vec<i32>>("text"));

    // 休眠等待定时任务执行
    thread::sleep(Duration::from_secs(30));

    println!("After clearing expired entries:");
    println!("Value for number: {:?}", cache.get::<i32>("number"));
    println!("Value for text: {:?}", cache.get::<String>("text"));
    cache.remove("text");
    println!("Value for text: {:?}", cache.get::<String>("text"));
}

场景 2:当做全局 config 来使用,不启用清理任务

use safe_cache::Cache;
use std::sync::Arc;

fn main() {
    let cache = Arc::new(Cache::new());

    // 示例使用
     // 示例使用
    cache.set("number".to_string(), 42, 0);
    cache.set("list".to_string(), vec![1, 2, 3], 0);
    cache.set("text".to_string(), "Hello, Rust!".to_string(), 0); // 0代表永不过期

    println!("Value for number: {:?}", cache.get::<i32>("number"));
    println!("Value for list: {:?}", cache.get::<Vec<i32>>("list"));
    println!("Value for text: {:?}", cache.get::<Vec<String>>("text"));
}

Overview

impl Cache<T> {
    fn set<T: 'static + Clone + Send>(&self, key: String, value: T, expire_seconds: u64);
    fn get<T: 'static + Clone>(&self, key: &str) -> Option<T>;
    fn remove(&self, key: &str);
}
impl CacheRwLock {
    fn get<T: 'static + Clone>(&self, key: &str) -> Option<T>;
    pub fn set<T: 'static + Clone + Send + Sync>(&self,key: String,value: T,expire_seconds: u64,);
    pub fn remove(&self, key: &str);
}
Commit count: 11

cargo fmt