以下是在C++中使用Redis客户端库cpp_redis实现一个一个弹出redis list的示例代码:
#include <cpp_redis/cpp_redis>
#include <iostream>
int main() {
cpp_redis::client client;
// 连接 Redis 服务器
client.connect("127.0.0.1", 6379, [](const std::string& host, std::size_t port, cpp_redis::connect_state status) {
if (status == cpp_redis::connect_state::dropped) {
std::cout << "连接已断开" << std::endl;
}
});
// 向 Redis 列表 mylist 中添加三个元素
client.lpush("mylist", {"one", "two", "three"}, [](cpp_redis::reply& reply) {
if (reply.is_error()) {
std::cerr << "添加元素失败: " << reply.as_string() << std::endl;
} else {
std::cout << "添加元素成功" << std::endl;
}
});
// 弹出并打印列表中所有元素
while (true) {
client.lpop("mylist", [](cpp_redis::reply& reply) {
if (reply.is_null()) { // 如果列表为空,则结束循环
return;
}
if (reply.is_error()) { // 如果发生错误,则输出错误信息
std::cerr << "弹出元素失败: " << reply.as_string() << std::endl;
} else { // 否则打印被弹出的元素值
std::cout << reply.as_string() << std::endl;
}
});
// 处理 Redis 客户端库的响应
client.sync_commit();
}
return 0;
}
在此示例中,我们首先连接到Redis服务器并向mylist列表中添加三个元素。然后,我们使用while循环和LPOP命令来逐个弹出并打印列表中的所有元素。当列表为空时,循环将终止。
请注意,在cpp_redis客户端库中,您需要使用client.sync_commit()方法来处理Redis客户端库的响应。这是因为该库是异步操作的,并且需要显式调用sync_commit()方法以确保响应已处理完毕。




