CMU15-445 Project0

CMU14445

Task #1 - Copy-On-Write Trie

  • Get()思路:
    获取根节点指针,顺着key逐字符往下找节点,最后根据题意可以使用dynamic_cast检查是否是TrieNodeWithValue(dynamic_pointer_cast也可以),以下为两者用法:

    auto value_node = std::dynamic_pointer_cast<const TrieNodeWithValue<T>>(cur));
    auto value_node = dynamic_cast<const TrieNodeWithValue<T>*>(cur.get())
    
  • Put()思路:
    1)若Trie是空,先创建新节点作为根节点,否则,克隆根节点。
    2)若key为空,根节点转化为TrieNodeWithValue后返回。
    3)指针cur指向原Trie以便顺着key逐字符往下找节点,指针ret_prev,ret_cur,ret_next分别用于指向上一个节点,当前节点,下一个节点。ret_next cur下一个节点的克隆,随后修改ret_cur的对于字符索引为ret_next
    4)key处理完后,通过ret_prevret_cur处理最后的节点,即通过ret_cur构造TrieNodeWithValue节点挂在ret_prev上即可。

  • Remove()思路:
    1)若Trie是空,直接返回空Trie
    2)顺着key逐字符向下找路径,用栈记录,栈中元素为即为map对应的键和值。
    3)此时,从栈顶到栈底的顺序即为key路径节点的逆序,其中栈底对应根节点。先将key对应的节点TrieNodeWithValue替换为TrieNode
    4)若是key是空,则直接将根节点TrieNodeWithValue替换为TrieNode返回。
    5)若是key对应的节点没有分支,则通过栈回溯路径节点,该删的删,一旦删不了就break
    6)若栈空且根节点无分支就说明Trie删成了空,返回空Trie,否则不断出栈,获取根节点并返回。

Task #2 - Concurrent Key-Value Store

没啥难度,仔细读题,理解题意即可,需要注意Trie.Put()并不是在原Trie上添加,而是返回一个新的Trie。加锁和解锁可以简单使用mutex.unlock() mutex.lock()即可。

Task #3 - Debugging

我个人是使用Clion进行该项目的,按要求进行断点设置,查看变量即可,很快。

Task #4 - SQL String Functions

upperlower按要求写就行,当时我用的时std::transform算法来实现的,并遇到了一些问题,见此。随后在plan_func_call.cpp中按所给注释写就行。

总结

这个project除了Task1刚上手有些陌生且思路不是太清晰写起来费些时间,之后几个就很快。借此,复习太久没动过的C++,重新认识了智能指针等C++技术和特性。

在这里插入图片描述

所遇问题

简单记下所遇问题,希望会对你有所帮助。

  • 关于项目本身,不一定是要clone这个项目的最新版,而是要根据你所处的学期clone对应的版本

  • 关于代码编辑器,我选择Clion,相比于VScode更加便于调试和上手

  • 关于编译器,项目要求是clang,但我这里默认是gcc g++,可以按照下面在bustub目录下CMakeLists.txt的开始处添加如下两行进行设置

    set(CMAKE_C_COMPILER "/usr/bin/clang-14")
    set(CMAKE_CXX_COMPILER "/usr/bin/clang++-14")
    
  • 关于格式化,网上找对应google格式clang-format文件,复制到bustub目录下的clang-format文件,并确保如下设置,所若google那个代码规格文档,说行长不过80,但一些特殊的情形除外,但clang-format并无法识别,故在这里认为设置为120,避免上传提交时再次修改

    ColumnLimit:     120
    

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

签到业务流程

1.技术选型 Redis主写入查询&#xff0c;Mysql辅助查询&#xff0c;传统签到多数都是直接采用mysql为存储DB,在大数据的情况下数据库的压力较大.查询速率也会随着数据量增大而增加.所以在需求定稿以后查阅了很多签到实现方式,发现用redis做签到会有很大的优势.本功能主要用到r…

字节8年经验之谈 —— 如何编写出色的接口测试用例?

简介&#xff1a;在所有的开发测试中&#xff0c;接口测试是必不可少的一项。有效且覆盖完整的接口测试&#xff0c;不仅能保障新功能的开发质量&#xff0c;还能让开发在修改功能逻辑的时候有回归的能力&#xff0c;同时也是能优雅地进行重构的前提。编写接口测试要遵守哪些原…

项目中日历管理学习使用

一些项目中会有日历或日期设置&#xff0c;最基本的会显示工作日&#xff0c;休息日&#xff0c;节假日等等&#xff0c;下面就是基于项目中的日历管理功能&#xff0c;要显示工作日&#xff0c;休息日&#xff0c;节假日 效果图 获取国家法定节假日工具类 public class Holi…

Go语言grpc服务开发——Protocol Buffer

文章目录 一、Protocol Buffer简介二、Protocol Buffer编译器安装三、proto3语言指南四、序列化与反序列化五、引入grpc-gateway1、插件安装2、定义proto文件3、生成go文件4、实现Service服务5、gRPC服务启动方法6、gateway服务启动方法7、main函数启动8、验证 相关参考链接&am…

msvcp140.dll丢失的解决方法

当你在尝试打开一个需要msvcp140.dll文件支持的程序或游戏时&#xff0c;如果系统提示该文件丢失&#xff0c;那么意味着在执行过程中缺少了这个关键的DLL文件。当系统无法找到或加载msvcp140.dll文件时&#xff0c;相应的程序将无法正常启动&#xff0c;这对于用户来说可能会非…

上位机图像处理和嵌入式模块部署(python opencv)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 前面我们谈到了qt&#xff0c;谈到了opencv&#xff0c;也谈到了嵌入式&#xff0c;但是没有说明python在这个过程当中应该扮演什么样的角色。open…

mac滚动截图

参考博客 https://www.zhihu.com/question/313673726/answer/2938671835 首先去AppStore搜索 iShot 这个也是要钱的&#xff0c;不过我输入appleID后&#xff0c;并没有扣我钱&#xff0c;不知道设么回事 然后打开iShot 点击观看视频&#xff0c;然后mac会自动打开一个新的…

JVM-字节码应用

一、字节码的应用远超你的想象 二、ASM介绍与读取字节码实战 用CoreAPI解析和TreeAPI都能做字节码解析&#xff0c;区别&#xff0c;TreeAPI必须读取完整字节码信息&#xff0c;才能做解析。 下面代码&#xff0c;使用CoreAPI做解析&#xff1a; package asm;public class MyM…

拦截器的简单使用

拦截器的简单使用 拦截器的使用创建拦截器preHandle 目标方法执行前执行postHandle 目标方法执行后执行afterCompletion 视图渲染后执行 拦截器使用场景返回值注册拦截器运用拦截器 拦截器的使用 创建拦截器 首先,我们需要创建一个拦截器器的类,并且需要继承自HandlerIntercep…

DEM高程地形瓦片数据Cesium使用教程

一、简介 从开始写文章到现在&#xff0c;陆续发布了全球90m、30m(包括哥白尼及ALOS)、12.5m全球级瓦片数据&#xff0c;以及中国12.5、日本10m、新西兰8m、等国家级瓦片数据&#xff0c;同时也发布了台湾20m、中国34省区12.5m等地区级瓦片数据。在数据发布的文章中对数据如何…

docker之部署青龙面板

青龙面板是一个用于管理和监控 Linux 服务器的工具&#xff0c;具有定时运行脚本任务的功能。在实际情况下也可以用于一些定期自动签到等任务脚本的运行。 本次记录下简单的安装与使用&#xff0c;请提前安装好docker&#xff0c;参考之前的文章。 一、安装部署 1、拉取镜像 # …

力扣每日一题 ---- 1039. 多边形三角剖分的最低得分

这题的难点在哪部分呢&#xff0c;其实是怎么思考。这道题如果之前没做过类似的话&#xff0c;还是很难看出一些性质的&#xff0c;这题原本的话是没有图片把用例显示的这么详细的。这题中有个很隐晦的点没有说出来 剖出来的三角形是否有交叉&#xff0c;这题中如果加一个三角…