目录
Redis数据库里面的每个键值对( key-value pair)都是由 对象( object)组成的,其中:
数据库 键总是一个 字符串对象( string object );
而数据库键的值则可以是 字符串对象、列表对象(list object)、哈希对象( hash object)、集合对象(set object)、有序集合对象(sorted set object) 这五种对象中的
其中一种。
字符串对象
Redis没有直接使用C语言传统的字符串表示(以空字符结尾的字符数组,以下简称C字符串),而是自己构建了一种名为简单动态字符串( simple dynamic string,SDS)的抽象类型,并将SDS用作Redis的默认字符串表示。
SDS的定义
SSD与C字符串的区别
列表——链表对象
链表在Redis中的应用非常广泛,比如列表键的底层实现之一就是链表。当一个列表键包含了数量比较多的元素,又或者列表中包含的元素都是比较长的字符串时,Redis就会使用链表作为列表键的底层实现。
链表提供了高效的节点重排能力,以及顺序性的节点访问方式,并且可以通过增删节点来灵活地调落链表的长度。
除了链表键之外,发布与订阅、慢查询、监视器等功能也用到了链表,Redis服务器本身还使用链表来保存多个客户端的状态信息,以及使用链表来构建客户端输出缓冲区( output buffer ),本书后续的章节将陆续对这些链表应用进行介绍。