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

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

发布时间:2018-10-12 15:59:20 所属栏目:编程 来源:JAVA高级程序员
导读:【新产物上线啦】51CTO播客,随时随地,碎片化进修 本文内容思想导图如下: 一、简介和应用 Redis是一个由ANSI C说话编写,机能优越、支持收集、可耐久化的K-K内存数据库,并提供多种说话的API。它常用的范例首要是 String、List、Hash、Set、ZSet 这5种 Re

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为何这么快——数据存储角度

(编辑:湖南网)

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

热点阅读