使用hiredis库可高效实现C++与Redis交互。首先安装libhiredis-dev或hiredis-devel,再通过redisConnect连接Redis服务器,调用redisCommand执行SET、GET等命令,操作字符串、列表等数据类型,并用freeReplyObject释放响应结果,最后redisFree断开连接。编译时需链接-hiredis。
在C++中连接和操作Redis数据库,最常用的方式是使用官方推荐的C客户端库 hiredis。由于Redis本身是用C语言编写的,hiredis轻量高效,被广泛用于C/C++项目中的NoSQL数据交互。
在开始前,需要先安装 hiredis 动态库和头文件。以 Ubuntu/Debian 系统为例:
sudo apt-get update sudo apt-get install libhiredis-dev
如果你使用的是 CentOS 或 Fedora:
sudo yum install hiredis-devel
也可以从 GitHub 源码编译安装:
git clone https://github.com/redis/hiredis.git cd hiredis make sudo make install sudo ldconfig // 刷新共享库缓存
使用 hiredis 连接 Redis 非常简单。以下是一个基本的同步连接示例,展示如何设置键值、获取值并处理响应。
#include#include int main() { // 1. 连接 Redis 服务器 redisContext *context = redisConnect("127.0.0.1", 6379); if (context = = nullptr || context->err) { if (context) { std::cerr << "连接错误: " << context->errstr << std::endl; } else { std::cerr << "无法分配 redis context" << std::endl; } return -1; } std::cout << "成功连接到 Redis 服务器!" << std::endl; // 2. 执行 SET 命令 redisReply *reply = (redisReply*)redisCommand(context, "SET mykey 'Hello from C++'"); if (reply == nullptr) { std::cerr << "执行命令失败: " << context->errstr << std::endl; redisFree(context); return -1; } std::cout << "SET 命令执行结果: " << reply->str << std::endl; freeReplyObject(reply); // 3. 执行 GET 命令 reply = (redisReply*)redisCommand(context, "GET mykey"); if (reply != nullptr && reply->type == REDIS_REPLY_STRING) { std::cout << "GET mykey 的值: " << reply->str << std::endl; } else { std::cout << "键不存在或返回类型错误" << std::endl; } freeReplyObject(reply); // 4. 断开连接 redisFree(context); return 0; }
编译时需要链接 hiredis 库:
g++ -o redis_demo redis_demo.cpp -lhiredis
确保 Redis 服务正在运行:
redis-server --daemonize yes
然后运行程序:
./redis_demo
输出应为:
成功连接到 Redis 服务器! SET 命令执行结果: OK GET mykey 的值: Hello from C++
Redis 支持多种数据结构,如列表、哈希、集合等。你可以通过发送相应的命令来操作它们。
例如,向列表添加元素并读取:
// 添加元素到列表
reply = (redisReply*)redisCommand(context, "LPUSH mylist 'item1'");
freeReplyObject(reply);
reply = (redisReply*)redisCommand(context, "LPUSH mylist 'item2'");
freeReplyObject(reply);
// 获取列表长度
reply = (redisReply*)redisCommand(context, "LLEN mylist");
if (reply->type == REDIS_REPLY_INTEGER) {
std::cout << "列表长度: " << reply->integer << std::endl;
}
freeReplyObject(reply);
// 获取所有元素
reply = (redisReply*)redisCommand(context, "LRANGE mylist 0 -1");
if (reply->type == REDIS_REPLY_ARRAY) {
for (size_t i = 0; i < reply->elements; ++i) {
std::cout << "元素 " << i << ": " << reply->element[i]->str << std::endl;
}
}
freeReplyObject(reply);
注意判断 reply->type 类型,避免空指针或类型不匹配导致崩溃。
hiredis 还提供异步 API(hiredis async),适用于高并发场景。它基于事件循环,可与 libevent、libev 等集成,实现非阻塞通信。
对于大多数中小型应用,同步接口已足够高效。
基本上就这些。掌握 hiredis 后,C++ 与 Redis 的交互变得直接而高效。
# redis
# centos
# git
# github
# c语言
# ubuntu
# ai
# c++
# ios
# stream
# red
# 数据类型
# 字符串
# 循环
# 指针
# 数据结构
# 接口
# 空指针
# 并发
# 事件
# 异步
# nosql
# 数据库
# debian
# 连接到
# 时需
# 的是
# 是一个
# 进阶
# 如果你
# 你可以
# 适用于
# 不存在
相关文章:
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
如何制作算命网站,怎么注册算命网站?
如何通过山东自助建站平台快速注册域名?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
网站制作需要会哪些技术,建立一个网站要花费多少?
高防服务器租用如何选择配置与防御等级?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
如何快速搭建虚拟主机网站?新手必看指南
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
如何在腾讯云服务器快速搭建个人网站?
如何通过.red域名打造高辨识度品牌网站?
如何通过FTP服务器快速搭建网站?
三星网站视频制作教程下载,三星w23网页如何全屏?
网站企业制作流程,用什么语言做企业网站比较好?
如何高效配置IIS服务器搭建网站?
企业微网站怎么做,公司网站和公众号有什么区别?
相册网站制作软件,图片上的网址怎么复制?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
招贴海报怎么做,什么是海报招贴?
教学论文网站制作软件有哪些,写论文用什么软件
?
javascript中的try catch异常捕获机制用法分析
广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?
焦点电影公司作品,电影焦点结局是什么?
宁波免费建站如何选择可靠模板与平台?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
建站之星后台管理系统如何操作?
建站与域名管理如何高效结合?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
高性能网站服务器配置指南:安全稳定与高效建站核心方案
建站主机是否属于云主机类型?
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
建站主机类型有哪些?如何正确选型
外贸公司网站制作,外贸网站建设一般有哪些步骤?
专业商城网站制作公司有哪些,pi商城官网是哪个?
如何快速打造个性化非模板自助建站?
如何在Windows服务器上快速搭建网站?
网站设计制作企业有哪些,抖音官网主页怎么设置?
视频网站app制作软件,有什么好的视频聊天网站或者软件?
如何在IIS服务器上快速部署高效网站?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
如何在IIS管理器中快速创建并配置网站?
完全自定义免费建站平台:主题模板在线生成一站式服务
如何通过万网虚拟主机快速搭建网站?
建站之星下载版如何获取与安装?
建站主机选购指南与交易推荐:核心配置解析
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
*请认真填写需求信息,我们会在24小时内与您取得联系。