⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hash.h

📁 PPPoE在Linux上的源代码
💻 H
字号:
/***********************************************************************
*
* hash.h
*
* Hash table utilities
*
* Copyright (C) 2002 Roaring Penguin Software Inc.
*
* LIC: GPL
*
***********************************************************************/

#ifndef HASH_H
#define HASH_H

#include <stdlib.h>
/* Fixed-size hash tables for now */
#define HASHTAB_SIZE 67

/* A hash bucket */
typedef struct hash_bucket_t {
    struct hash_bucket_t *next;
    struct hash_bucket_t *prev;
    unsigned int hashval;
} hash_bucket;

/* A hash table */
typedef struct hash_table_t {
    hash_bucket *buckets[HASHTAB_SIZE];
    size_t hash_offset;
    unsigned int (*compute_hash)(void *data);
    int (*compare)(void *item1, void *item2);
    size_t num_entries;
} hash_table;

/* Functions */
void hash_init(hash_table *tab,
	       size_t hash_offset,
	       unsigned int (*compute)(void *data),
	       int (*compare)(void *item1, void *item2));
void hash_insert(hash_table *tab, void *item);
void hash_remove(hash_table *tab, void *item);
void *hash_find(hash_table *tab, void *item);
void *hash_find_next(hash_table *tab, void *item);
size_t hash_num_entries(hash_table *tab);

/* Iteration functions */
void *hash_start(hash_table *tab, void **cursor);
void *hash_next(hash_table *tab, void **cursor);

/* Utility function: hashpjw for strings */
unsigned int hash_pjw(char const *str);

#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -