亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hashmap.cc

?? Click is a modular router toolkit. To use it you ll need to know how to compile and install the sof
?? CC
?? 第 1 頁 / 共 2 頁
字號:
/* * hashmap.{cc,hh} -- a hash table template * Eddie Kohler * * Copyright (c) 2000 Mazu Networks, Inc. * Copyright (c) 2003 International Computer Science Institute * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, subject to the conditions * listed in the Click LICENSE file. These conditions include: you must * preserve this copyright notice, and you cannot mention the copyright * holders in advertising related to the Software without their permission. * The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This * notice is a summary of the Click LICENSE file; the license in that file is * legally binding. */#ifndef CLICK_HASHMAP_CC#define CLICK_HASHMAP_CC#include <click/hashmap.hh>#include <click/bighashmap_arena.hh>#include <click/glue.hh>CLICK_DECLS#define BIGHASHMAP_REARRANGE_ON_FIND 0template <class K, class V>voidHashMap<K, V>::initialize(HashMap_ArenaFactory *factory, size_t initial_nbuckets){  _nbuckets = initial_nbuckets;  _buckets = (Elt **) CLICK_LALLOC(_nbuckets * sizeof(Elt *));  for (size_t i = 0; i < _nbuckets; i++)    _buckets[i] = 0;  set_dynamic_resizing(true);  _n = 0;  set_arena(factory);}template <class K, class V>HashMap<K, V>::HashMap()  : _default_value(), _arena(0){  initialize(0, DEFAULT_INITIAL_NBUCKETS);}template <class K, class V>HashMap<K, V>::HashMap(const V &def, HashMap_ArenaFactory *factory)  : _default_value(def), _arena(0){  initialize(factory, DEFAULT_INITIAL_NBUCKETS);}template <class K, class V>voidHashMap<K, V>::copy_from(const HashMap<K, V> &o)  // requires that 'this' is empty and has the same number of buckets as 'o'  // and the same resize policy{  for (size_t i = 0; i < _nbuckets; i++) {    Elt **pprev = &_buckets[i];    *pprev = 0;    for (const Elt *e = o._buckets[i]; e; e = e->next) {      Elt *ee = reinterpret_cast<Elt *>(_arena->alloc());      new(reinterpret_cast<void *>(&ee->key)) K(e->key);      new(reinterpret_cast<void *>(&ee->value)) V(e->value);      ee->next = 0;      *pprev = ee;      pprev = &ee->next;    }  }  _n = o._n;}template <class K, class V>HashMap<K, V>::HashMap(const HashMap<K, V> &o)    : _buckets((Elt **) CLICK_LALLOC(o._nbuckets * sizeof(Elt *))),      _nbuckets(o._nbuckets), _default_value(o._default_value),      _capacity(o._capacity), _arena(o._arena){  _arena->use();  copy_from(o);}template <class K, class V>HashMap<K, V> &HashMap<K, V>::operator=(const HashMap<K, V> &o){  if (&o != this) {    clear();    _default_value = o._default_value;    if (_nbuckets < o._nbuckets)      resize0(o._nbuckets);    _nbuckets = o._nbuckets;    _capacity = o._capacity;    copy_from(o);  }  return *this;}template <class K, class V>HashMap<K, V>::~HashMap(){  for (size_t i = 0; i < _nbuckets; i++)    for (Elt *e = _buckets[i]; e; ) {      Elt *next = e->next;      e->key.~K();      e->value.~V();      _arena->free(e);      e = next;    }  CLICK_LFREE(_buckets, _nbuckets * sizeof(Elt *));  _arena->unuse();}template <class K, class V>voidHashMap<K, V>::set_dynamic_resizing(bool on){  if (!on)    _capacity = 0x7FFFFFFF;  else if (_nbuckets >= MAX_NBUCKETS)    _capacity = 0x7FFFFFFE;  else    _capacity = DEFAULT_RESIZE_THRESHOLD * _nbuckets;}template <class K, class V>voidHashMap<K, V>::set_arena(HashMap_ArenaFactory *factory){  assert(empty());  if (_arena)    _arena->unuse();  _arena = HashMap_ArenaFactory::get_arena(sizeof(Elt), factory);  _arena->use();}template <class K, class V>inline size_tHashMap<K, V>::bucket(const K &key) const{  return ((size_t) hashcode(key)) % _nbuckets;}template <class K, class V>typename HashMap<K, V>::Pair *HashMap<K, V>::find_pair(const K &key) const{#if BIGHASHMAP_REARRANGE_ON_FIND  Elt *prev = 0;  size_t b = bucket(key);  for (Elt *e = _buckets[b]; e; prev = e, e = e->next)    if (e->key == key) {      if (prev) {        // move to front        prev->next = e->next;	e->next = _buckets[b];	_buckets[b] = e;      }      return e;    }  return 0;#else  for (Elt *e = _buckets[bucket(key)]; e; e = e->next)    if (e->key == key)      return e;  return 0;#endif}template <class K, class V>voidHashMap<K, V>::resize0(size_t new_nbuckets){    Elt **new_buckets = (Elt **) CLICK_LALLOC(new_nbuckets * sizeof(Elt *));    for (size_t i = 0; i < new_nbuckets; i++)	new_buckets[i] = 0;  size_t old_nbuckets = _nbuckets;  Elt **old_buckets = _buckets;  _nbuckets = new_nbuckets;  _buckets = new_buckets;  if (dynamic_resizing())    set_dynamic_resizing(true);	// reset threshold  for (size_t i = 0; i < old_nbuckets; i++)    for (Elt *e = old_buckets[i]; e; ) {      Elt *n = e->next;      size_t b = bucket(e->key);      e->next = new_buckets[b];      new_buckets[b] = e;      e = n;    }  CLICK_LFREE(old_buckets, old_nbuckets * sizeof(Elt *));}template <class K, class V>voidHashMap<K, V>::resize(size_t want_nbuckets){  size_t new_nbuckets = 1;  while (new_nbuckets < want_nbuckets && new_nbuckets < MAX_NBUCKETS)    new_nbuckets = ((new_nbuckets + 1) << 1) - 1;  assert(new_nbuckets > 0 && new_nbuckets <= MAX_NBUCKETS);  if (_nbuckets != new_nbuckets)    resize0(new_nbuckets);}template <class K, class V>boolHashMap<K, V>::insert(const K &key, const V &value){  size_t b = bucket(key);  for (Elt *e = _buckets[b]; e; e = e->next)    if (e->key == key) {      e->value = value;      return false;    }  if (_n >= _capacity) {    resize(_nbuckets + 1);    b = bucket(key);  }  if (Elt *e = reinterpret_cast<Elt *>(_arena->alloc())) {    new(reinterpret_cast<void *>(&e->key)) K(key);    new(reinterpret_cast<void *>(&e->value)) V(value);    e->next = _buckets[b];    _buckets[b] = e;    _n++;  }  return true;}template <class K, class V>boolHashMap<K, V>::erase(const K &key){  size_t b = bucket(key);  Elt *prev = 0;  Elt *e = _buckets[b];  while (e && !(e->key == key)) {    prev = e;    e = e->next;  }  if (e) {    if (prev)      prev->next = e->next;    else      _buckets[b] = e->next;    e->key.~K();    e->value.~V();    _arena->free(e);    _n--;    return true;  } else    return false;}template <class K, class V>typename HashMap<K, V>::Pair *HashMap<K, V>::find_pair_force(const K &key, const V &default_value){  size_t b = bucket(key);  for (Elt *e = _buckets[b]; e; e = e->next)    if (e->key == key)      return e;  if (_n >= _capacity) {    resize(_nbuckets + 1);    b = bucket(key);  }  if (Elt *e = reinterpret_cast<Elt *>(_arena->alloc())) {    new(reinterpret_cast<void *>(&e->key)) K(key);    new(reinterpret_cast<void *>(&e->value)) V(default_value);    e->next = _buckets[b];    _buckets[b] = e;    _n++;    return e;  } else    return 0;}template <class K, class V>voidHashMap<K, V>::clear(){  for (size_t i = 0; i < _nbuckets; i++) {    for (Elt *e = _buckets[i]; e; ) {      Elt *next = e->next;      e->key.~K();      e->value.~V();      _arena->free(e);      e = next;    }    _buckets[i] = 0;  }  _n = 0;}template <class K, class V>voidHashMap<K, V>::swap(HashMap<K, V> &o){  Elt **t_elts;  V t_v;  size_t t_size;  HashMap_Arena *t_arena;  t_elts = _buckets; _buckets = o._buckets; o._buckets = t_elts;  t_size = _nbuckets; _nbuckets = o._nbuckets; o._nbuckets = t_size;  t_v = _default_value; _default_value = o._default_value; o._default_value = t_v;  t_size = _n; _n = o._n; o._n = t_size;  t_size = _capacity; _capacity = o._capacity; o._capacity = t_size;  t_arena = _arena; _arena = o._arena; o._arena = t_arena;}template <class K, class V>_HashMap_const_iterator<K, V>::_HashMap_const_iterator(const HashMap<K, V> *hm, bool begin)  : _hm(hm){  size_t nb = _hm->_nbuckets;  typename HashMap<K, V>::Elt **b = _hm->_buckets;  for (_bucket = 0; _bucket < nb && begin; _bucket++)    if (b[_bucket]) {      _elt = b[_bucket];      return;    }  _elt = 0;}template <class K, class V>void_HashMap_const_iterator<K, V>::operator++(int){  if (_elt->next)    _elt = _elt->next;  else {    size_t nb = _hm->_nbuckets;    typename HashMap<K, V>::Elt **b = _hm->_buckets;    for (_bucket++; _bucket < nb; _bucket++)      if (b[_bucket]) {	_elt = b[_bucket];	return;      }    _elt = 0;  }}#if 0static size_tHashMap_partition_elts(void **elts, size_t left, size_t right){  void *pivot = elts[(left + right) / 2];

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美伊人久久久久久久久影院| 欧美一卡在线观看| 久久综合久久综合久久| 一区二区三区欧美亚洲| www.成人网.com| 成人免费在线视频观看| gogo大胆日本视频一区| 中文字幕字幕中文在线中不卡视频| 丰满少妇在线播放bd日韩电影| 亚洲精品在线免费观看视频| 久久99蜜桃精品| 国产欧美日韩另类一区| 国内外精品视频| 国产欧美日韩麻豆91| 91在线观看成人| 亚洲成av人影院| 欧美电影免费观看高清完整版| 久久99精品久久久久| 亚洲国产精品黑人久久久| 97se亚洲国产综合自在线不卡| 亚洲免费在线观看视频| 666欧美在线视频| 国产又黄又大久久| 中文字幕一区二区三区四区| 欧美伦理影视网| 国产福利一区二区三区视频在线| 久久精品国产99国产| 精品国产乱子伦一区| 色婷婷久久久综合中文字幕| 激情五月激情综合网| 亚洲在线一区二区三区| 久久久久久久久久电影| 欧美久久久久久久久中文字幕| 不卡视频在线观看| 蜜桃久久av一区| 一区二区三区中文字幕电影| 精品欧美乱码久久久久久1区2区| 99麻豆久久久国产精品免费优播| 日韩国产高清影视| 亚洲国产毛片aaaaa无费看| 国产午夜精品一区二区三区视频| 欧美日韩在线综合| 99亚偷拍自图区亚洲| 国产精品一区二区在线观看不卡 | 蜜臀91精品一区二区三区| 综合色天天鬼久久鬼色| 久久蜜桃av一区二区天堂| 欧美高清www午色夜在线视频| 91免费版pro下载短视频| 欧美一级欧美一级在线播放| 不卡的av中国片| 成人黄页在线观看| 中文字幕在线观看不卡视频| 欧美精品一区二区三区高清aⅴ| 国产色产综合色产在线视频| 日韩免费一区二区| 91.成人天堂一区| 欧美日产国产精品| 这里只有精品免费| 3atv在线一区二区三区| 欧美四级电影在线观看| 国产亚洲精品精华液| 色又黄又爽网站www久久| 欧美日韩一区二区三区四区五区 | 日本高清免费不卡视频| 欧美撒尿777hd撒尿| 在线看国产一区| 欧美精品123区| 日本一二三不卡| 三级不卡在线观看| 国产综合色产在线精品| 一本久久a久久精品亚洲| 色偷偷一区二区三区| 国产精品99久久久久久久女警 | 亚洲尤物在线视频观看| 青青草97国产精品免费观看无弹窗版| 香蕉成人啪国产精品视频综合网| 精品一区二区三区影院在线午夜| eeuss鲁一区二区三区| 欧美一区二区三区系列电影| 中文字幕视频一区| 另类人妖一区二区av| 欧美撒尿777hd撒尿| 亚洲国产精品成人综合色在线婷婷| 一区二区三区四区不卡在线| 国产精品乡下勾搭老头1| 欧美大片免费久久精品三p| 亚洲精品一二三| 波多野结衣一区二区三区 | www.视频一区| 久久亚洲欧美国产精品乐播| 蜜臂av日日欢夜夜爽一区| 欧美性三三影院| 日日摸夜夜添夜夜添精品视频| 国产在线精品一区二区不卡了| 成人美女在线观看| 欧美一级久久久| 亚洲小说春色综合另类电影| 一本色道久久综合狠狠躁的推荐| 精品成人一区二区三区| 麻豆精品视频在线| 日韩欧美黄色影院| 免费av网站大全久久| 欧美日韩和欧美的一区二区| 国产亚洲一区二区在线观看| 国产成人在线网站| 久久久精品国产免大香伊| 精品在线免费视频| 欧美精品一区视频| 成人av电影免费观看| 中文字幕在线观看一区二区| 99精品黄色片免费大全| 《视频一区视频二区| 在线亚洲高清视频| 亚洲视频小说图片| 欧美一区二区性放荡片| 蜜臀av性久久久久蜜臀aⅴ| 精品福利一二区| 国产成人99久久亚洲综合精品| 在线观看欧美黄色| 国产精品看片你懂得| 不卡区在线中文字幕| 亚洲综合男人的天堂| 欧美成人性福生活免费看| 日韩激情中文字幕| 国产午夜精品理论片a级大结局| 成人精品免费看| 亚洲午夜日本在线观看| 国产亚洲午夜高清国产拍精品| 波多野结衣中文字幕一区| 亚洲成人免费电影| www国产成人| 91美女片黄在线观看| 国产亚洲欧美日韩日本| av中文一区二区三区| 亚洲男人电影天堂| 91老师国产黑色丝袜在线| 国产99一区视频免费| 亚洲第一福利视频在线| 亚洲男女一区二区三区| 亚洲精品成a人| 欧美精品一区二区三区视频| 国产呦精品一区二区三区网站| 国产精品乱码妇女bbbb| 精品久久人人做人人爱| 欧美日韩精品三区| 色婷婷综合久久久久中文一区二区| 国产精品主播直播| 美女任你摸久久| 日本成人在线网站| 国产精品久久久久久久久免费相片| 欧美亚洲丝袜传媒另类| 在线一区二区三区做爰视频网站| 成人深夜视频在线观看| 成人av网站在线观看免费| 天堂成人免费av电影一区| 一区二区三区日韩| 亚洲自拍另类综合| 亚洲曰韩产成在线| 五月天国产精品| 另类小说综合欧美亚洲| 国产ts人妖一区二区| thepron国产精品| 欧美色精品天天在线观看视频| 制服丝袜av成人在线看| 国产日韩欧美精品综合| 自拍偷在线精品自拍偷无码专区| 亚洲第一福利一区| 成人晚上爱看视频| 在线视频一区二区三区| 色成人在线视频| 日本精品视频一区二区| 欧美日韩免费一区二区三区| 欧美日韩一区二区在线观看视频| 在线电影一区二区三区| 久久影院电视剧免费观看| 亚洲欧洲国产专区| 亚洲电影你懂得| 毛片不卡一区二区| 男男成人高潮片免费网站| eeuss鲁片一区二区三区在线观看| 欧美日韩在线播放一区| 26uuu欧美| 亚洲国产日韩在线一区模特| 九九视频精品免费| 在线欧美日韩精品| 一本色道亚洲精品aⅴ| 69久久99精品久久久久婷婷| 中文子幕无线码一区tr| 美脚の诱脚舐め脚责91| 一本久久a久久精品亚洲| 欧美mv日韩mv| 亚洲精品国产a| 国v精品久久久网| 欧美日韩一区三区四区| 国产精品国产自产拍高清av| 奇米精品一区二区三区四区| 91小视频在线免费看| 中文字幕一区二区日韩精品绯色| 精品一区二区在线播放|