我对编写数据库管理系统非常感兴趣。阅读了一些关于SQL Server 2000实现的页面后,我发现它使用了4KB内存页,每个页都是硬盘上4KB页的直接副本。这些页面在需要时加载到RAM中,然后在空闲时懒惰地写回磁盘(过于简化)。
在我的项目规划阶段,我想知道在CLR上运行的代码是否可能拥有这种级别的控制。我知道C、C++或D可能更适合此任务,但我想先自己证明。其中一部分动机是,我最终希望使用我的数据库作为堆来覆盖CLR垃圾收集器,至少对于相对陈旧的对象。
从CLR直接控制内存是否可能?如果是,我该如何做?
暂时假设我的数据是一些256字节宽的结构/类,存储在硬盘上的平面表中,并且我正在使用64KB页。
在我的项目规划阶段,我想知道在CLR上运行的代码是否可能拥有这种级别的控制。我知道C、C++或D可能更适合此任务,但我想先自己证明。其中一部分动机是,我最终希望使用我的数据库作为堆来覆盖CLR垃圾收集器,至少对于相对陈旧的对象。
从CLR直接控制内存是否可能?如果是,我该如何做?
暂时假设我的数据是一些256字节宽的结构/类,存储在硬盘上的平面表中,并且我正在使用64KB页。