2021SC@SDUSC
本博客系列将在接下来的三个月内开始对Sqlite的部分源码进行解读。Sqlite源码解读部分将由我和我的三个同伴合作完成。本团队将Sqlite源码分为四部分:SQL Command Processor、B-Tree、Pager、OS Interface,而我主要负责OS Interface部分。
该部分的核心是VFS(Virtual File System),VFS是位于提供跨操作系统可移植性的SQLite实现栈底层的一个模块,它用来调用读写位于不同物理介质上的不同文件系统,即给各种文件系统提供统一的应用编程接口和操作界面,它是可以让open()、read()、write()、close()等系统调用不用关心底层的存储介质和文件系统类型就可以进行调用的粘合剂。通过VFS,一个抽象的通用访问接口就可以屏蔽底层文件系统和物理介质的差异性。
抽象对象VFS为Sqlite提供跨操作系统的可移植性,Sqlite为unix和Windows都提供了VFSes,分别在各自的os_unix.c文件和os_win.c文件中。每个VFS都提供了在磁盘上开闭和读写文件的方法,以及操作系统特定的一些任务,如查找当前时间、获得随机性以初始化内置的伪随机数生成器。