C++如何使用redis的实例详解

C++使用redis的实例详解 hiredis是redis数据库的C接口,目前只能在linux下使用,几个基本的函数就可以操作redis数据库了。 函数原型:r

C++使用redis的实例详解

hiredis是redis数据库的C接口,目前只能在linux下使用,几个基本的函数就可以操作redis数据库了。 

函数原型:redisContext *redisConnect(const char *ip, int port);

说明:该函数用来连接redis数据库,参数为数据库的ip地址和端口,一般redis数据库的端口为6379;

函数返回值:该函数返回一个结构体redisContext;

类似的提供了一个函数redisContext* redisConnectWithTimeout(const char *ip, int port, timeval tv),以带有超时的方式连接redis服务器,同时获取与redis连接的上下文对象。 

函数原型:void *redisCommand(redisContext *c, const char *format, ...);

说明:该函数执行命令,就如sql数据库中的SQL语句一样,只是执行的是redis数据库中的操作命令,第一个参数为连接数据库时返回的redisContext,剩下的参数为变参,就如C标准函数printf函数一样的变参。

函数返回值:返回值为void*,一般强制转换成为redisReply类型,以便做进一步处理。

 函数原型void freeReplyObject(void *reply);

说明:释放redisCommand执行后返回的redisReply所占用的内存;

 函数返回值:无。

函数原型:void redisFree(redisContext *c);

说明:释放redisConnect()所产生的连接。

函数返回值:无。 

下面用一个简单的例子说明:

#include <stdio.h> 
#include <stdlib.h> 
#include <stddef.h> 
#include <stdarg.h> 
#include <string.h> 
#include <assert.h> 
#include <hiredis/hiredis.h> 
 
void doTest() 
{ 
  //redis默认监听端口为6387 可以再配置文件中修改 
  redisContext* c = redisConnect("127.0.0.1", 6379); 
  if ( c->err) 
  { 
    redisFree(c); 
    printf("Connect to redisServer faile\n"); 
    return ; 
  } 
  printf("Connect to redisServer Success\n"); 
   
  const char* command1 = "set stest1 value1"; 
  redisReply* r = (redisReply*)redisCommand(c, command1); 
   
  if( NULL == r) 
  { 
    printf("Execut command1 failure\n"); 
    redisFree(c); 
    return; 
  } 
  if( !(r->type == REDIS_REPLY_STATUS && strcasecmp(r->str,"OK")==0)) 
  { 
    printf("Failed to execute command[%s]\n",command1); 
    freeReplyObject(r); 
    redisFree(c); 
    return; 
  }   
  freeReplyObject(r); 
  printf("Succeed to execute command[%s]\n", command1); 
   
  const char* command2 = "strlen stest1"; 
  r = (redisReply*)redisCommand(c, command2); 
  if ( r->type != REDIS_REPLY_INTEGER) 
  { 
    printf("Failed to execute command[%s]\n",command2); 
    freeReplyObject(r); 
    redisFree(c); 
    return; 
  } 
  int length = r->integer; 
  freeReplyObject(r); 
  printf("The length of 'stest1' is %d.\n", length); 
  printf("Succeed to execute command[%s]\n", command2); 
   
   
  const char* command3 = "get stest1"; 
  r = (redisReply*)redisCommand(c, command3); 
  if ( r->type != REDIS_REPLY_STRING) 
  { 
    printf("Failed to execute command[%s]\n",command3); 
    freeReplyObject(r); 
    redisFree(c); 
    return; 
  } 
  printf("The value of 'stest1' is %s\n", r->str); 
  freeReplyObject(r); 
  printf("Succeed to execute command[%s]\n", command3); 
   
  const char* command4 = "get stest2"; 
  r = (redisReply*)redisCommand(c, command4); 
  if ( r->type != REDIS_REPLY_NIL) 
  { 
    printf("Failed to execute command[%s]\n",command4); 
    freeReplyObject(r); 
    redisFree(c); 
    return; 
  } 
  freeReplyObject(r); 
  printf("Succeed to execute command[%s]\n", command4);   
   
   
  redisFree(c); 
   
} 
 
int main() 
{ 
  doTest(); 
  return 0; 
} 
 

执行结果为:

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

您可能有感兴趣的文章
Redis数据结构SortedSet的底层原理解析

redis主从哨兵模式如何实现一主二从

RediSearch加RedisJSON大于Elasticsearch的搜索存储引擎

Redis如何存储对象

Redis唯一ID生成器的如何实现