博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
04.openssl编程——哈希表
阅读量:2243 次
发布时间:2019-05-09

本文共 2779 字,大约阅读时间需要 9 分钟。

4.1   
哈希表
在一般的数据结构如线性表和树中,记录在结构中的相对位置与记录的关键字之间不存在确定的关系,在结构中查找记录时需要进行一系列的关键字比较。这一类查找方法建立在比较的基础上,查找的效率与比较次数密切相关。理想的情况是能直接找到需要的记录,因此必须在记录的存储位置和他的关键字之间建立的对应关系,使每个关键字哈希表存在冲突现象:不同的关键字可能得到同一哈希地址。在建造哈希表时不仅要设定一个好的哈希函数,而且要设定一种处理冲突的方法。
4.2 哈希表数据结构
其原代码crypto/lhash目录下。
openssl中的哈希表数据结构在lhash.h中定义如下:
struct lhash_node_st {
void *data;
struct lhash _node_st *next;
unsigned long hash;
}
struct lhash_st {
OPENSSL_LH_NODE **b; 指针数组用于存放所有的数据,数组中的每一个值为数据链表的头指针
OPENSSL_LH_COMPFUNC comp;存放数据比较函数地址
OPENSSL_LH_HASHFUNC hash;存放计算哈希值函数的地址
unsigned int num_nodes;为链表个数
unsgined int num_alloc_nodes;分配空间的大小
unsigned int p;
unsigned int pmax;
unsigned long up_load;
unsigned long down_load;
unsigned long num_items;
unsigned long num_expand_reallocs;
unsigned long num_expand_reallocs;
unsgined long num_contracts;
unsigned long num_contract_reallocs;
unsigned long num_comp_calls;
unsigned long num_hash_calls;
unsigned long num_insert;
unsgined long num_replace;
unsigned long num_delete;
unsigned long num_retrieve;
unsigned long num_retrieve_miss;
unsigned long num_hash_comps;
int error;
}
4.3 函数说明
a
.LHASH *OPENSSL_lh_new(LLHASH_HASH_FN_TYPE h, LHASH_COMP_FN_TYPE c)
功能:生成哈希表
说明:输入参数h为哈希函数,c为比较函数。这两个函数都是回调函数。因为哈希表用于存放任意的数据结构,哈希表存放、查询、删除等操作都需要比较函数和进行哈希运算,而哈希表不知道数据如何进行比较,也不知道用户数据结构中需要对那些关键项进行散列运算。所以,用户必须提供这两个回调函数。
b.void *OPENSSL_LH_delete(LHASH *lh, ocnst void *data)
功能:删除散列表中的一个数据
说明:data为数据结构指针
c.void OPENSSL_LH_doall(OPENSSL_LHASH *lh, OPENSSL_LH_DOALL_FUNC func)
功能:处理哈希表中的所有数据
说明:func为外不提供的回调函数,本函数遍历所有存储哈谢表中的数据,每个数据被func处理
d.void OPENSSL_LH_free(OPENSSL_LHASH *lh)
功能:释放哈希表
e.void OPENSSL_LH_doall_arg(OPENSSL_LHASH *lh, OPENSSL_LH_DOALL_FUNCARG func, void *arg)
功能:处理哈希表中所有数据
说明:此参数类似于OPENSSL_LH_doall函数,func为外部提供的回调函数,arg为传递给func函数的参数。本函数遍历所有存储的哈希表中的数据,每个数据被func处理。
f.void *OPENSSL_LH_insert(OPENSSL_LHASH *lh, void *data)
功能:往哈希表中添加数据
说明:data为需要添加数据结构的指针地址
g.void *OPENSSL_LH_retrieve(OPENSSL_LHASH *lh, const void *data)
功能:查询数据
说明:从哈希表中查询数据,data为数据结构地址,次数据结构中必须提供关键项(这些关键想对于用户提供的哈希函数和比较函数)以供查询,如果查询成功,返回数据结构的地址,否则返回NULL.
SSL_SESSION *ret = NULL, data;
data.ssl_version=s->version;
data.session_id_length = len;
memcpy(data.session_id, session_id, len);
ret = (SSL_SESSION*)lh_retriev(s->ctx->sessions,&data);
h.void OPENSSL_LH_node_usage_stats_bio(const OPENSSL_LHASH *lh, BIO *out)
源文件:lh_stats.c
功能:将哈希表中每个链表下的数据状态输出到BIO中。
i.void OPENSSL_LH_node_usage_stats_bio(const OPENSSL_LHASH *lh, BIO *out)
源文件:lh_stats.c
功能:将哈希表的使用状态输出到BIO中
j.unsigned long OPENSSL_LH_num_items(const OPENSSL_LHASH *lh)
源文件:lhash.c
功能:输出哈希表统计信息到BIO中
k.void OPENSSL_LH_stats_bio(const OPENSSL_LHASH *lh, BIO *out)
源文件:lh_stats.c
功能:输出哈希表统计信息到BIO中
l.void OPENSSL_LH_stats(const OPENSSL_LHASH *lh,FILE *fp)
源文件:lh_stats.c
功能:输出哈希表统计信息到BIO中
n.unsigned long lh_strhash(const char *c)
源文件:lhash.c
功能:计算本自负穿到哈希表中

转载地址:http://smwdb.baihongyu.com/

你可能感兴趣的文章
VLAN与子网划分区别
查看>>
Cisco Packet Tracer教程
查看>>
02. 交换机的基本配置和管理
查看>>
03. 交换机的Telnet远程登陆配置
查看>>
微信小程序-调用-腾讯视频-解决方案
查看>>
phpStudy安装yaf扩展
查看>>
密码 加密 加盐 常用操作记录
查看>>
TP 分页后,调用指定页。
查看>>
Oracle数据库中的(+)连接
查看>>
java-oracle中几十个实用的PL/SQL
查看>>
PLSQL常用方法汇总
查看>>
几个基本的 Sql Plus 命令 和 例子
查看>>
PLSQL单行函数和组函数详解
查看>>
Oracle PL/SQL语言初级教程之异常处理
查看>>
Oracle PL/SQL语言初级教程之游标
查看>>
Oracle PL/SQL语言初级教程之操作和控制语言
查看>>
Oracle PL/SQL语言初级教程之过程和函数
查看>>
Oracle PL/SQL语言初级教程之表和视图
查看>>
Oracle PL/SQL语言初级教程之完整性约束
查看>>
PL/SQL学习笔记
查看>>