nginx 字符串结构体
1、ngx_str_t {
u_char *data;
size_t len;
}
redis的字符串结构体
struct sdshdr {
unsigned int len;
unsigned int free;
char buf[];
};
可以看出,redis的字符串比nginx字符串多了一个free字段,用来表示当前字符串已经分配的空间还剩余多少字节,如果有append这样的操作,如果append的字符长度小于free,那么可以直接追加到已分配的字符后边。
而且如果对这两个结构体求sizeof,在32位的平台上,sizeof(ngx_str_t) = 8 , sizeof(sdshdr) = 8
需要特别说明的是,redis的结构体中buf不占空间,只是一个符号。这也是redis这种内存数据库为了节省一点空间。
nginx的字符串更符合常理,使用起来更方便,而且解析http请求头中的各个字段时只需要把len赋值,并且把data指向请求的某个位置即可。这样获取一个字符串可以算是最省时间和空间的操作了,这也是nginx性能更好的一个理由。
本文对比了Nginx的ngx_str_t结构体与Redis的sdshdr结构体,详细介绍了两种结构体的特点及应用场景。Redis字符串结构体额外包含了一个free字段,用于记录已分配但未使用的空间,这有助于提高字符串扩展效率。而在32位平台上,两种结构体的大小相同。

被折叠的 条评论
为什么被折叠?



