news 2026/4/18 11:01:31

C++ 中解锁 Redis

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++ 中解锁 Redis

一、核心前提:选择 Redis C++ 客户端库

C++ 本身没有内置 Redis 客户端,主流选择是hiredis(官方推荐的 C 语言客户端,轻量、稳定,C++ 可直接调用),也是最基础、最常用的库。

1. 环境安装(以 Linux 为例)

bash

运行

# 1. 安装hiredis库 sudo apt update sudo apt install libhiredis-dev # 2. 验证安装(查看库文件) ls /usr/lib/x86_64-linux-gnu/libhiredis*

注:Windows 环境可下载 hiredis 源码编译,或使用 vcpkg 安装:vcpkg install hiredis

2. 编译指令

编写 C++ 代码后,编译时需链接 hiredis 库:

bash

运行

g++ your_code.cpp -o redis_demo -lhiredis

二、C++ 操作 Redis 核心实战代码

以下是完整的 C++ 操作 Redis 示例,包含连接、字符串操作、哈希操作、列表操作、断开连接等核心场景:

cpp

运行

#include <iostream> #include <string> #include <hiredis/hiredis.h> using namespace std; // 封装Redis连接函数 redisContext* connectRedis(const string& ip, int port, const string& password = "") { // 1. 建立连接(超时时间10秒) struct timeval timeout = {10, 0}; redisContext* ctx = redisConnectWithTimeout(ip.c_str(), port, timeout); // 2. 检查连接错误 if (ctx == nullptr || ctx->err) { if (ctx) { cerr << "连接Redis失败:" << ctx->errstr << endl; redisFree(ctx); } else { cerr << "Redis连接对象创建失败!" << endl; } return nullptr; } cout << "Redis连接成功!" << endl; // 3. 有密码则认证 if (!password.empty()) { redisReply* reply = (redisReply*)redisCommand(ctx, "AUTH %s", password.c_str()); if (reply == nullptr || reply->type == REDIS_REPLY_ERROR) { cerr << "Redis认证失败:" << (reply ? reply->str : "无返回") << endl; freeReplyObject(reply); redisFree(ctx); return nullptr; } freeReplyObject(reply); cout << "Redis认证成功!" << endl; } return ctx; } // 封装Redis命令执行函数 redisReply* executeRedisCommand(redisContext* ctx, const char* format, ...) { if (ctx == nullptr) { cerr << "Redis连接为空,无法执行命令!" << endl; return nullptr; } va_list args; va_start(args, format); redisReply* reply = (redisReply*)redisvCommand(ctx, format, args); va_end(args); // 检查命令执行错误 if (reply == nullptr) { cerr << "命令执行失败:连接已断开" << endl; return nullptr; } if (reply->type == REDIS_REPLY_ERROR) { cerr << "Redis命令错误:" << reply->str << endl; } return reply; } int main() { // 1. 连接Redis(替换为你的Redis地址、端口、密码) string redis_ip = "127.0.0.1"; int redis_port = 6379; string redis_pwd = ""; // 无密码则留空 redisContext* ctx = connectRedis(redis_ip, redis_port, redis_pwd); if (ctx == nullptr) { return -1; } // 2. 核心操作1:字符串(String)- SET/GET cout << "\n===== 字符串操作 =====" << endl; redisReply* reply = executeRedisCommand(ctx, "SET user:name Tom"); if (reply && reply->type == REDIS_REPLY_STATUS && strcmp(reply->str, "OK") == 0) { cout << "SET成功" << endl; } freeReplyObject(reply); reply = executeRedisCommand(ctx, "GET user:name"); if (reply && reply->type == REDIS_REPLY_STRING) { cout << "GET user:name = " << reply->str << endl; } freeReplyObject(reply); // 3. 核心操作2:哈希(Hash)- HSET/HGETALL cout << "\n===== 哈希操作 =====" << endl; reply = executeRedisCommand(ctx, "HSET user:1 name Jerry age 20 gender male"); if (reply && reply->type == REDIS_REPLY_INTEGER) { cout << "HSET成功,新增字段数:" << reply->integer << endl; } freeReplyObject(reply); reply = executeRedisCommand(ctx, "HGETALL user:1"); if (reply && reply->type == REDIS_REPLY_ARRAY) { cout << "HGETALL user:1 = "; for (size_t i = 0; i < reply->elements; i += 2) { cout << reply->element[i]->str << ":" << reply->element[i+1]->str << " "; } cout << endl; } freeReplyObject(reply); // 4. 核心操作3:列表(List)- LPUSH/LRANGE cout << "\n===== 列表操作 =====" << endl; reply = executeRedisCommand(ctx, "LPUSH fruits apple banana orange"); if (reply && reply->type == REDIS_REPLY_INTEGER) { cout << "LPUSH成功,列表长度:" << reply->integer << endl; } freeReplyObject(reply); reply = executeRedisCommand(ctx, "LRANGE fruits 0 -1"); if (reply && reply->type == REDIS_REPLY_ARRAY) { cout << "LRANGE fruits = "; for (size_t i = 0; i < reply->elements; i++) { cout << reply->element[i]->str << " "; } cout << endl; } freeReplyObject(reply); // 5. 断开连接 redisFree(ctx); cout << "\nRedis连接已断开" << endl; return 0; }

三、核心代码解释

  1. 连接 Redis
    • redisConnectWithTimeout:带超时的连接函数,避免无限等待;
    • AUTH命令:Redis 有密码时必须执行认证,否则后续命令会报错。
  2. 命令执行
    • redisCommand/redisvCommand:执行 Redis 命令,支持格式化参数(类似printf);
    • redisReply:存储命令返回结果,需通过type判断返回类型(字符串、数组、整数、状态等)。
  3. 资源释放
    • freeReplyObject:必须释放每个redisReply,避免内存泄漏;
    • redisFree:断开连接时释放上下文对象。

四、常见问题与注意事项

  1. 返回值类型对应

    Redis 命令返回类型redisReply->type示例
    成功状态(OK)REDIS_REPLY_STATUSSET、DEL 命令
    字符串 / 数字REDIS_REPLY_STRINGGET、HGET 命令
    整数REDIS_REPLY_INTEGERLPUSH、LLEN 命令
    数组REDIS_REPLY_ARRAYHGETALL、LRANGE 命令
    错误REDIS_REPLY_ERROR语法错误、认证失败
  2. 异常处理

    • 连接断开后,redisContext->err会被置位,需重新连接;
    • 生产环境建议封装重连逻辑,避免单次连接失败导致程序退出。
  3. 进阶选择:若嫌 hiredis(C 风格)不够 “C++ 化”,可选择封装后的 C++ 库:

    • redis-plus-plus:基于 hiredis 的现代 C++ 封装,支持 RAII、异步操作;
    • cpp_redis:轻量级异步 Redis 客户端,支持发布订阅、集群。

总结

  1. C++ 操作 Redis 的核心是使用hiredis 库,编译时需链接-lhiredis
  2. 核心流程:建立连接 → 执行命令(处理返回值) → 释放资源 → 断开连接;
  3. 需重点关注redisReply的类型判断和资源释放,避免内存泄漏和逻辑错误。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 10:52:04

Windows Server SMB 共享文件 回收站

1. 项目简介 ShareRecycleBin 是一个专为 Windows Server (特别是 SMB 共享环境) 设计的增量回收站服务。它通过硬链接 (Hard Link) 技术实现对文件的“即时备份”&#xff0c;并能在文件被删除时将其移动到指定的回收站目录&#xff0c;同时保留原始的目录结构和权限锁定。 …

作者头像 李华
网站建设 2026/4/18 8:29:43

绿城郑州爱心公益网站毕业论文+PPT(附源代码+演示视频)

文章目录绿城郑州爱心公益网站一、项目简介&#xff08;源代码在文末&#xff09;1.运行视频2.&#x1f680; 项目技术栈3.✅ 环境要求说明4.包含的文件列表&#xff08;含论文&#xff09;数据库结构与测试用例系统功能结构前端运行截图后端运行截图项目部署源码下载绿城郑州爱…

作者头像 李华
网站建设 2026/4/18 10:49:25

网络服务器入门指南:搭建与管理

网络服务器入门指南&#xff1a;搭建与管理选择服务器硬件或云服务根据需求选择物理服务器或云服务提供商。物理服务器需要购买硬件设备&#xff0c;适合对数据控制要求高的场景。云服务如AWS、阿里云等提供弹性扩展能力&#xff0c;适合初创企业或个人开发者。评估硬件配置时关…

作者头像 李华
网站建设 2026/4/18 5:37:02

【好写作AI】AI来了,学术伦理就崩了?我们用行动说不!

好写作AI官方网址&#xff1a;https://www.haoxiezuo.cn/一、深夜的良心拷问&#xff1a;用了AI的论文&#xff0c;还算“我”的吗&#xff1f; 当你好不容易用好写作AI搞定摘要、理清逻辑、降重到8%后&#xff0c;准备点击提交的瞬间&#xff0c;那个幽灵般的问题总会出现&…

作者头像 李华
网站建设 2026/4/18 10:27:15

经典的PHP+MySQL开发组合的微信投票活动源码系统

温馨提示&#xff1a;文末有资源获取方式你是否在寻找一个能快速启动、模式清晰、且能产生多重收益的互联网项目&#xff1f;微信投票活动巨大的市场需求和清晰的盈利模式&#xff0c;一直吸引着众多创业者。现在&#xff0c;一个功能更加强大的新版投票源码系统应运而生&#…

作者头像 李华