Handle-with-cache.c May 2026
static UserProfile* load_user_profile_from_disk(int user_id) { // Simulate expensive I/O printf("Loading user %d from disk...\n", user_id); sleep(1); // Pretend this is slow UserProfile *profile = malloc(sizeof(UserProfile)); profile->user_id = user_id; profile->name = malloc(32); profile->email = malloc(64); sprintf(profile->name, "User_%d", user_id); sprintf(profile->email, "user%d@example.com", user_id); return profile; } This is the heart of the module. The cache is transparent to the caller.
This article breaks down the key components, implementation strategies, and concurrency considerations for building a robust handle cache in C. Imagine a function get_user_profile(user_id) that reads a large JSON file from disk or queries a database. If your application needs this profile multiple times per second, disk I/O or network latency becomes a bottleneck. handle-with-cache.c
// Cache miss - load the resource pthread_mutex_unlock(&cache_lock); // Unlock during I/O UserProfile *profile = load_user_profile_from_disk(user_id); pthread_mutex_lock(&cache_lock); other data } UserProfile; // Cache entry wrapper
// handle-with-cache.c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <glib.h> // Using GLib's hash table for simplicity typedef struct { int user_id; char *name; char *email; // ... other data } UserProfile; other data } UserProfile
// Cache entry wrapper typedef struct { UserProfile *profile; time_t last_access; unsigned int ref_count; // Reference counting for safety } CacheEntry;
// Create new cache entry CacheEntry *new_entry = malloc(sizeof(CacheEntry)); new_entry->profile = profile; new_entry->last_access = time(NULL); new_entry->ref_count = 1;
