在此说明一下:我分析的TC版本是1.4.43,我的阅读流程主要是遵循对TC数据文件的标准操作流程进行分析,即打开数据文件->存放record->获取record->关闭数据文件,期间会涉及到一些相关函数,我会逐个分析。
另外,按我粗浅的理解,我觉得TC不能称为一个完整意义上的数据库,它仅仅是一个存储引擎而已,它的所有操作最终都是针对系统中的一个普通文件进行的,因此以后的分析中,我把TC操作的对象统统称为数据文件对象,而不是数据库对象,它打开的文件称为数据文件。
一、TCHDB *tchdbnew(void)
这个函数实现的功能是:分配一个TCHDB类型的数据文件对象,我们以后的操作都是基于这个对象的,它的功能有点类似于我们打开文件后获得的那个文件描述符,不过TCHDB比文件描述符要复杂的多,下面是代码和注释:
TCHDB *tchdbnew(void){
TCHDB *hdb;
TCMALLOC(hdb, sizeof(*hdb)); // 动态分配一个TCHDB对象
tchdbclear(hdb); // 初始化TCHDB对象
return hdb;
}
下面是tchdbclear对应的代码和注释:
二、tchdbopen函数
该函数打开指定的数据文件,并将打开的数据文件信息添加到TCHDB结构体中,打开过程中会检查数据文件是否为空等操作,看代码:
函数tchdbopen仅仅做简单的一些检查转换操作,具体打开操作在函数tchdbopenimpl中,我们来看看代码:
这里补充下上面函数中调用的tchdbwalrestore函数,wal文件的格式为:更新前数据文件大小(8字节) + 一条或多条更新记录,其中,每条更新记录格式如下: