加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Redis为何这么快——数据存储角度

发布时间:2018-10-17 03:15:01 所属栏目:MySql教程 来源:JAVA高级程序员
导读:副标题#e# 【新产品上线啦】51CTO播客,随时随地,碎片化学习 本文内容思维导图如下: 一、简介和应用 Redis是一个由ANSI C语言编写,性能优秀、支持网络、可持久化的K-K内存数据库,并提供多种语言的API。它常用的类型主要是 String、List、Hash、Set、ZSe

hashtable哈希表可以实现O(1)复杂度的读写操作,因此效率很高。源码如下:

  1. typedef struct dict {  
  2.  // 类型特定函数  
  3.  dictType *type;  
  4.  // 私有数据  
  5.  void *privdata;  
  6.  // 哈希表  
  7.  dictht ht[2];  
  8.  // rehash 索引  
  9.  // 当 rehash 不在进行时,值为 -1  
  10.  int rehashidx; /* rehashing not in progress if rehashidx == -1 */  
  11.  // 目前正在运行的安全迭代器的数量  
  12.  int iterators; /* number of iterators currently running */  
  13.  } dict;  
  14.  typedef struct dictht {  
  15.  // 哈希表数组  
  16.  dictEntry **table;  
  17.  // 哈希表大小  
  18.  unsigned long size;  
  19.  // 哈希表大小掩码,用于计算索引值  
  20.  // 总是等于 size - 1  
  21.  unsigned long sizemask;  
  22.  // 该哈希表已有节点的数量  
  23.  unsigned long used;  
  24. } dictht;  
  25. typedef struct dictEntry {  
  26.  void *key;  
  27.  union {void *val;uint64_t u64;int64_t s64;} v;  
  28.  // 指向下个哈希表节点,形成链表  
  29.  struct dictEntry *next;  
  30.  } dictEntry;  
  31.  typedef struct dictType {  
  32.  // 计算哈希值的函数  
  33.  unsigned int (*hashFunction)(const void *key);  
  34.  // 复制键的函数  
  35.  void *(*keyDup)(void *privdata, const void *key);  
  36.  // 复制值的函数  
  37.  void *(*valDup)(void *privdata, const void *obj);  
  38.  // 对比键的函数  
  39.  int (*keyCompare)(void *privdata, const void *key1, const void *key2);  
  40.  // 销毁键的函数  
  41.  void (*keyDestructor)(void *privdata, void *key);  
  42.  // 销毁值的函数  
  43.  void (*valDestructor)(void *privdata, void *obj);  
  44. } dictType; 

上面源码可以简化成如下结构:

Redis为何这么快——数据存储角度

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读