比较器用于确定键是否不同,因此重载它无济于事,因为当您扫描数据库时 - 您必须能够比较完整的键(而不仅仅是前缀)。不需要重载迭代器:键在 leveldb 中排序,您会知道如果遇到具有不同前缀的键,它已经超出范围。你可以像往常一样使用迭代器,只要你的键被正确评估,你应该得到正确的结果:
void ScanRecordRange(const leveldb::Slice& startSlice, const leveldb::Slice& endSlice)
{
// Get a database iterator
shared_ptr<leveldb::Iterator> dbIter(_database->NewIterator(leveldb::ReadOptions()));
// Possible optimization suggested by Google engineers
// for critical loops. Reduces memory thrash.
for(dbIter->Seek(startSlice); dbIter->Valid() && _options.comparator->Compare(dbIter->key(), endSlice)<=0 ;dbIter->Next())
{
// Read the record
if( !dbIter->value().empty() )
{
leveldb::Slice keySlice(dbIter->key());
leveldb::Slice dataSlice(dbIter->data());
// TODO: process the key/data
}
}
}