摘要 | 第4-5页 |
Abstract | 第5页 |
第1章 绪论 | 第9-14页 |
1.1 课题来源以及背景 | 第9-11页 |
1.1.1 课题来源 | 第9-10页 |
1.1.2 课题背景 | 第10-11页 |
1.2 与课题相关的国内外研究现状 | 第11-12页 |
1.2.1 国内研究现状 | 第11页 |
1.2.2 国际研究现状 | 第11-12页 |
1.3 论文的主要工作以及章节安排 | 第12-14页 |
1.3.1 本人的工作内容 | 第12页 |
1.3.2 论文的章节安排 | 第12-14页 |
第2章 文件恢复程序的需求分析 | 第14-23页 |
2.1 文件恢复程序的总体结构以及功能需求分析 | 第14-16页 |
2.1.1 总体结构需求分析 | 第14-15页 |
2.1.2 文件恢复程序的功能需求分析 | 第15-16页 |
2.2 文件恢复程序的主要技术需求分析 | 第16-22页 |
2.2.1 对 NTFS 整体结构的技术分析 | 第16-19页 |
2.2.2 对 MFT 主文件分配表的技术分析 | 第19-20页 |
2.2.3 对 MFT 项的头信息的技术分析 | 第20-21页 |
2.2.4 对 MFT 项属性数据的技术分析 | 第21-22页 |
2.3 本章小结 | 第22-23页 |
第3章 文件恢复程序的设计 | 第23-37页 |
3.1 功能的设计 | 第23-28页 |
3.1.1 读入 BPB 的算法设计 | 第23-24页 |
3.1.2 读入 MFT 表文件的算法设计 | 第24-25页 |
3.1.3 读入 MFT 项名字属性数据的算法设计 | 第25-27页 |
3.1.4 读入 Bitmap 数据的算法设计 | 第27页 |
3.1.5 构建已删除文件目录树的算法设计 | 第27-28页 |
3.2 界面的设计 | 第28-30页 |
3.2.1 虚拟列表的设计 | 第29-30页 |
3.2.2 虚拟列表的排序的设计 | 第30页 |
3.3 减小程序运行期内存占用的一种方法 | 第30-32页 |
3.3.1 内存数据的数据特点分析 | 第31页 |
3.3.2 针对 Unicode 编码的再编码设计 | 第31-32页 |
3.4 大内存块存储的算法设计 | 第32-35页 |
3.4.1 频繁申请内存造成效率低下的成因研究 | 第32-33页 |
3.4.2 解决之道 | 第33-35页 |
3.5 线性查找的算法设计 | 第35-36页 |
3.6 本章小结 | 第36-37页 |
第4章 文件恢复程序的实现 | 第37-58页 |
4.1 开发环境 | 第37页 |
4.2 数据层实现 | 第37-52页 |
4.2.1 读入 BPB 和 MFT 表项信息的实现 | 第39-41页 |
4.2.2 读入 MFT 和 Bitmap 数据的实现 | 第41-50页 |
4.2.3 建立已删除文件目录树的实现 | 第50-52页 |
4.3 UI 层的具体实现 | 第52-55页 |
4.4 数据恢复的实现 | 第55-56页 |
4.5 本章小结 | 第56-58页 |
第5章 文件恢复程序的测试 | 第58-67页 |
5.1 结果展示 | 第58-60页 |
5.2 测试以及测试结果 | 第60-66页 |
5.2.1 测试功能说明 | 第60页 |
5.2.2 测试注意事项 | 第60-61页 |
5.2.3 测试数据 | 第61页 |
5.2.4 测试方法 | 第61-62页 |
5.2.5 功能测试 | 第62-63页 |
5.2.6 性能测试 | 第63-64页 |
5.2.7 测试结果 | 第64-66页 |
5.3 本章小结 | 第66-67页 |
结论 | 第67-69页 |
参考文献 | 第69-73页 |
致谢 | 第73-74页 |
个人简历 | 第74页 |