CMU15445-project1-满分收获总结


TASK #0 gradescope
0.0 关于线上测试的天坑
在gradescope上测试代码时,没有通过的案例如果显示的是超时,那不一定是因为死锁或者死循环!
- 我没有写线程安全的代码,显示的是超时
- 我代码有的部分会造成内存泄漏,显示的还是超时
- 死锁或者replacer复杂度太高确实有可能造成超时
TASK #1 - LRU REPLACEMENT POLICY
1.1线程安全
要求了线程安全但又没有说具体怎么做,以至于在最后才回来考虑上锁的问题。
其实很简单,在头文件内声明一个锁。在实现的每个函数开头上锁,结尾释放就行。
// 头文件
#include<mutex>
// 声明
std::mutex lock_;
//上锁(请求锁),释放锁
lock_.lock();
lock_

这篇博客分享了CMU15445项目的经验,涉及LRU替换策略的线程安全实现、upin和pin的理解以及搜索效率优化。在BUFFERPOOLMANAGERINSTANCE中,讨论了frame_id与page_id的关系,DeletePgImp的返回值陷阱,以及UnpinPgImp的注意事项。项目最后部分介绍了PARALLELBUFFERPOOLMANAGER的线程安全处理。
最低0.47元/天 解锁文章
1195





