CMU 15-445 Project Project #1 - Buffer Pool(Task #1 - Extendible Hash Table)

news2025/1/23 7:02:09

Task #1 - Extendible Hash Table

  • 一、题目链接
  • 二、准备工作
  • 三、部分实现
  • 四、自定义测试用例

在这里插入图片描述

一、题目链接


二、准备工作

见 CMU 15-445 Project #0 - C++ Primer 中的准备工作。


三、部分实现

Find

auto Find(const K &key, V &value) -> bool override {
    std::scoped_lock<std::mutex> locker(latch_);
    return dir_.at(IndexOf(key))->Find(key, value);
}

Insert

void Insert(const K &key, const V &value)
override {
std::scoped_lock <std::mutex> locker(latch_);
DoInsert(key, value
);  // 通过DoInsert将整个插入操作整合为一个原子操作
}

void DoInsert(const K &key, const V &value) {
    /* 如果插入成功,直接返回。 */
    if (dir_.at(IndexOf(key))->Insert(key, value)) {
        return;
    }

    /* 获取原始桶的目录下标和分裂桶的目录下标 */
    int mask = (1 << (dir_.at(IndexOf(key))->GetDepth() + 1)) - 1;
    size_t primary_dir_index = IndexOf(key) & mask;
    size_t divide_dir_index = primary_dir_index ^ (1 << dir_.at(IndexOf(key))->GetDepth());

    /* 如果发生桶溢出,需要根据局部深度和全局深度的关系进行相应处理:
     * 如果局部深度等于全局深度,需要进行目录扩展、桶分裂和重映射;
     * 如果局部深度小于全局深度,只需要进行桶分裂和重映射。 */
    /* 目录扩展 */
    if (dir_.at(primary_dir_index)->GetDepth() == global_depth_) {
        int primary_dir_len = dir_.size();  // 扩展前的目录长度

        /* 增加全局深度 */
        global_depth_++;

        /* 新扩展的shared_ptr依次指向原来的桶 */
        for (int i = 0; i < primary_dir_len; i++) {
            dir_.emplace_back(std::shared_ptr<Bucket>(dir_.at(i)));
        }
    }

    /* 增加原始桶的局部深度 */
    dir_.at(primary_dir_index)->IncrementDepth();

    /* 桶分裂 */
    dir_.at(divide_dir_index) = std::make_shared<Bucket>(bucket_size_, dir_.at(primary_dir_index)->GetDepth());
    num_buckets_++;

    /* 重新映射原始桶中的pair */
    auto primary_items = dir_.at(primary_dir_index)->GetItems();  // 单独提取以避免迭代器失效
    for (const auto &[k, v] : primary_items) {
        /* 如果当前pair的key值不再映射到原始桶,需要将对应pair从原始桶中删除后插入到新桶中。 */
        if ((IndexOf(k) & mask) == divide_dir_index) {
            dir_.at(primary_dir_index)->Remove(k);
            dir_.at(divide_dir_index)->Insert(k, v);
        }
    }

    /* 经过重新映射后,如果目标桶未满直接插入即可,否则需要递归插入并再次进行桶分裂。*/
    if (!dir_.at(IndexOf(key))->IsFull()) {
        dir_.at(IndexOf(key))->Insert(key, value);
        return;
    }
    DoInsert(key, value);
}

Remove

auto Remove(const K &key) -> bool override {
    std::scoped_lock<std::mutex> locker(latch_);

    /* 如果查找失败直接返回 */
    V find_value;
    if (!dir_.at(IndexOf(key))->Find(key, find_value)) {
        return false;
    }

    /* 删除 */
    dir_.at(IndexOf(key))->Remove(key);

    return true;
}

提交后的结果如下,其中可扩展哈希表部分只有一个 ExtendibleHashTableTest.ConcurrentInsertFind.ASAN 的测试用例没过,其余全部通过。这里推测可能是多线程加锁时存在死锁,暂时还没有解决,不过整体思路应该没有问题。

在这里插入图片描述


四、自定义测试用例

TEST(ExtendibleHashTableTest, GetNumBucketsTest) {
  auto table = std::make_unique<ExtendibleHashTable<int, std::string>>(2);

  table->Insert(0b0000100, "01");  // 04
  table->Insert(0b0001100, "02");  // 12
  table->Insert(0b0010000, "03");  // 16
  EXPECT_EQ(4, table->GetNumBuckets());
  
  table->Insert(0b1000000, "04");  // 64
  table->Insert(0b0011111, "05");  // 31
  table->Insert(0b0001010, "06");  // 10
  table->Insert(0b0110011, "07");  // 51
  EXPECT_EQ(4, table->GetNumBuckets());
  
  table->Insert(0b0001111, "08");  // 15
  table->Insert(0b0010010, "09");  // 18
  table->Insert(0b0010100, "10");  // 20
  EXPECT_EQ(7, table->GetNumBuckets());
  
  table->Insert(0b0000111, "11");  // 07
  table->Insert(0b0010111, "12");  // 23
  EXPECT_EQ(8, table->GetNumBuckets());
}

在这里插入图片描述


参考 :

https://zhuanlan.zhihu.com/p/622221722
https://www.geeksforgeeks.org/extendible-hashing-dynamic-approach-to-dbms/

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/612937.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【是C++,不是C艹】 类与对象 | 默认成员函数 | 构造函数 | 析构函数

&#x1f49e;&#x1f49e;欢迎来到 Claffic 的博客&#x1f49e;&#x1f49e; &#x1f449; 专栏&#xff1a;《是C&#xff0c;不是C艹》&#x1f448; 前言&#xff1a; 在完成类与对象的认识后&#xff0c;我们接着学习类与对象的第二部分&#xff1a;默认成员函数&…

基于深度学习的高精度野外烟雾检测识别系统(PyTorch+Pyside6+YOLOv5模型)

摘要&#xff1a;基于深度学习的高精度野外烟雾检测识别系统可用于日常生活中检测与定位野外烟雾目标&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方式的野外烟雾目标检测识别&#xff0c;另外支持结果可视化与图片或视频检测结果的导出。本系统采用YOLOv5目标检测…

FastReport Business Graphics .NET crack

FastReport Business Graphics .NET crack FastReport Business Graphics.NET允许您可视化层次结构信息并创建业务图以进行进一步分析。FastCube.NET允许您连接到任何应用程序。包括树图、太阳爆发图和冰柱图。 FastReport Business Graphics库允许您可视化分层数据&#xff0c…

虚幻ue镜头试拍录制器用法 5.2录制角色的的操作并按特定键播放探索

在窗口-开启镜头试拍录制器 image.png 添加源为Player image.png 这个时候录制的圆形按钮警告已经消失, 切换游戏模式为模拟 image.png 运行后点击手柄切换 进行实际的控制 image.png 点击录制之后,在cinema 的take文件夹找到文件 把文件拖动到关卡,然后 创建蓝图按L键 然后创建…

(CVPR-2023)通过有效的时空特征融合进行多模态步态识别

通过有效的时空特征融合进行多模态步态识别 paper题目&#xff1a;Multi-modal Gait Recognition via Effective Spatial-Temporal Feature Fusion paper是北航发表在CVPR 2023的工作 paper地址 Abstract 步态识别是一种生物识别技术&#xff0c;通过步行模式识别人。基于剪影…

指针 --- 进阶

先看目录&#xff0c;看你知道多少 目录 1.字符指针 2.指针数组 3.数组指针 4.数组传参和指针传参 5.函数指针 6.函数指针数组 7.指向函数指针数组的指针 8.回调函数 什么是指针&#xff0c;我们在之前的《指针》章节已经接触过了&#xff0c;我们知道了指针的概念: 1…

软件测试——功能测试,使用Java,IDEA,Selenium进行web自动化测试

视频地址&#xff1a;03-web元素定位ID_哔哩哔哩_bilibili p1.下载jdk,maven,idea p2.配置java-selenium环境正式开始&#xff1a; &#xff08;1&#xff09;创建代码&#xff1a; &#xff08;2&#xff09;第一次运行会报错&#xff1a;要下载东西 &#xff08;3&…

如何设计一个过压保护电路

有时候在电源输入处我们希望当电源的输入电压超过允许的最大值后电源与后级电路就自动断开&#xff0c;防止输入电压过高而损坏后级电路。 具有这种功能的电路叫做过压保护电路&#xff0c;英文简称叫OVP。 现在大家看到的就是一个典型的过压保护电压电路&#xff0c;主要包含…

(一)springboot实战——为什么是springboot?

前言 为什么是springboot&#xff1f;江湖夜雨&#xff0c;传说依旧&#xff0c;不懂springboot一技之长&#xff0c;如何混迹java圈&#xff0c;本节内容我们介绍一下spring的一些基本特性。尤其是springboot3的基本特性&#xff0c;使得我们更好的理解springboot3。 正文 …

【vue3】07-vue组件之间的通信-父子互传-事件总线

文章目录 Vue的组件嵌套Vue组件化-组件间通信父子组件之间通信非父子组件间的通信 Vue的组件嵌套 前面我们是将所有的逻辑放到一个App.vue中: 在之前的案例中&#xff0c;我们只是创建了一个组件App;如果我们一个应用程序将所有的逻辑都放在一个组件中&#xff0c;那么这个组…

linux下一次复制cp多个文件(含scp命令)

linux cp 参数说明 -a&#xff1a;此选项通常在复制目录时使用&#xff0c;它保留链接、文件属性&#xff0c;并复制目录下的所有内容。其作用等于dpR参数组合。 -d&#xff1a;复制时保留链接。这里所说的链接相当于Windows系统中的快捷方式。 -f&#xff1a;覆盖已经存在的目…

实训笔记6.5

实训笔记 6.5一、座右铭二、上周回顾Java基本语法1、Java的安装和环境变量的配置2、Java的标识符、关键字和保留字3、Java中的变量和常量、字面量4、数据类型5、运算符6、流程控制7、数组8、JVM内存图9、面向对象的两大概念-类和对象 三、类的组成3.1 属性的声明和使用3.1.1 属…

扩散模型之DDPM

扩散模型之DDPM 文章前置生成模型总结 Design of DDPM正向加噪过程反向去噪过程 文章前置 最原文链接&#xff08;英文&#xff09;&#xff1a;What are Diffusion Models? 原文链接&#xff1a;Diffusion扩散模型大白话讲解&#xff0c;看完还不懂&#xff1f;不可能 原文链…

第10章 对象和类

第10章 对象和类 10.1 过程性编程和面相对象编程10.2 抽象和类10.2.1 类型是什么10.2.2 C中的类10.2.3 实现类成员函数10.2.4 使用类 10.1 过程性编程和面相对象编程 采用OOP方法时&#xff0c;首先从用户的角度考虑对象——描述对象所需的数据以及描述用户与数据交互所需的操…

【蓝桥刷题】备战国赛——异或三角

蓝桥杯2021国赛真题——异或三角 &#x1f680; 每日一题&#xff0c;冲刺国赛 &#x1f680; 题目导航&#xff1a; 异或三角 &#x1f387;思路&#xff1a;数位 d p dp dp d f s dfs dfs 思维 &#x1f531;思路分析&#xff1a; ✅数理基础&#xff1a; 按位异或&am…

(2017,AdaIN)用自适应实例归一化进行实时的任意风格迁移

Arbitrary Style Transfer in Real-time with Adaptive Instance Normalization 公众号&#xff1a;EDPJ 目录 ​​​​​​​0. 摘要 1. 简介 2. 相关工作 3. 背景 3.1 批量归一化&#xff08;Batch Normalization&#xff0c;BN&#xff09; 3.2 实例归一化&#xff…

入驻京东直播间、成功借壳上市,交个朋友和时间“交朋友”

交个朋友一直走在“交朋友”的路上。 5月31日晚&#xff0c;交个朋友正式入驻京东直播间&#xff0c;首播销售额超1.5亿元&#xff0c;直播热度榜达人榜第一名&#xff0c;累计访问人次超1700万。据了解&#xff0c;京东618期间&#xff0c;除了日常直播外&#xff0c;交个朋友…

java并发编程:可见性、原子性、有序性三大特性详解

文章目录 可见性导致可见性的原因线程交叉执行重排序结合线程交叉执行共享变量更新后没有及时更新 如何解决可见性问题 原子性出现原子性问题的原因如何解决原子性问题 有序性导致有序性的原因如何解决有序性问题 总结 可见性 内存可见性&#xff0c;指的是线程之间的可见性&am…

IPv6NAT-PT实验:IPv4和IPv6地址转换的配置和验证

IPv6NAT-PT实验&#xff1a;IPv4和IPv6地址转换的配置和验证 【实验目的】 熟悉IPv6NAT-PT的概念。 掌握静态IPv6NAT-PT的配置 掌握动态IPv6NAT-PT的配置。 验证配置。 【实验拓扑】 设备参数如下表所示。 设备 接口 IP地址 子网掩码 默认网关 R1 S0/0 192.168.12…

2023HW护网红队必备工具总结

一、信息收集 1、AppInfoScanner 一款适用于以HVV行动/红队/渗透测试团队为场景的移动端(Android、iOS、WEB、H5、静态网站)信息收集扫描工具&#xff0c;可以帮助渗透测试工程师、红队成员快速收集到移动端或者静态WEB站点中关键的资产信息并提供基本的信息输出,如&#xff…