Some small code changes to improve Next() (#5200)

Summary:
Several small changes for Next():
1. Reducing branching by always update local_stats_.next_count_++ even if statistics is null. This should be faster than a branching.
2. Replacing ResetInternalKeysSkippedCounter() in Next() because the valid_ check is not needed in this case.
3. iter_->Valid() should always be true for non merge case. Remove this check.
4. Adding an inline annotation. It ends up with not picked up by my compiler, but it shouldn't hurt.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/5200

Differential Revision: D15000391

Pulled By: siying

fbshipit-source-id: be97f61c708968234fb8e5cf272b5c2ac07dc4dd
main
Siying Dong 6 years ago committed by Facebook Github Bot
parent 992dfc7811
commit 01cfea6637
  1. 15
      db/db_iter.cc

@ -257,7 +257,7 @@ class DBIter final: public Iterator {
bool FindValueForCurrentKeyUsingSeek(); bool FindValueForCurrentKeyUsingSeek();
bool FindUserKeyBeforeSavedKey(); bool FindUserKeyBeforeSavedKey();
inline bool FindNextUserEntry(bool skipping, bool prefix_check); inline bool FindNextUserEntry(bool skipping, bool prefix_check);
bool FindNextUserEntryInternal(bool skipping, bool prefix_check); inline bool FindNextUserEntryInternal(bool skipping, bool prefix_check);
bool ParseKey(ParsedInternalKey* key); bool ParseKey(ParsedInternalKey* key);
bool MergeValuesNewToOld(); bool MergeValuesNewToOld();
@ -379,25 +379,26 @@ void DBIter::Next() {
PERF_CPU_TIMER_GUARD(iter_next_cpu_nanos, env_); PERF_CPU_TIMER_GUARD(iter_next_cpu_nanos, env_);
// Release temporarily pinned blocks from last operation // Release temporarily pinned blocks from last operation
ReleaseTempPinnedData(); ReleaseTempPinnedData();
ResetInternalKeysSkippedCounter(); local_stats_.skip_count_ += num_internal_keys_skipped_;
local_stats_.skip_count_--;
num_internal_keys_skipped_ = 0;
bool ok = true; bool ok = true;
if (direction_ == kReverse) { if (direction_ == kReverse) {
if (!ReverseToForward()) { if (!ReverseToForward()) {
ok = false; ok = false;
} }
} else if (iter_->Valid() && !current_entry_is_merged_) { } else if (!current_entry_is_merged_) {
// If the current value is not a merge, the iter position is the // If the current value is not a merge, the iter position is the
// current key, which is already returned. We can safely issue a // current key, which is already returned. We can safely issue a
// Next() without checking the current key. // Next() without checking the current key.
// If the current key is a merge, very likely iter already points // If the current key is a merge, very likely iter already points
// to the next internal position. // to the next internal position.
assert(iter_->Valid());
iter_->Next(); iter_->Next();
PERF_COUNTER_ADD(internal_key_skipped_count, 1); PERF_COUNTER_ADD(internal_key_skipped_count, 1);
} }
if (statistics_ != nullptr) { local_stats_.next_count_++;
local_stats_.next_count_++;
}
if (ok && iter_->Valid()) { if (ok && iter_->Valid()) {
FindNextUserEntry(true /* skipping the current user key */, FindNextUserEntry(true /* skipping the current user key */,
prefix_same_as_start_); prefix_same_as_start_);
@ -430,7 +431,7 @@ inline bool DBIter::FindNextUserEntry(bool skipping, bool prefix_check) {
} }
// Actual implementation of DBIter::FindNextUserEntry() // Actual implementation of DBIter::FindNextUserEntry()
bool DBIter::FindNextUserEntryInternal(bool skipping, bool prefix_check) { inline bool DBIter::FindNextUserEntryInternal(bool skipping, bool prefix_check) {
// Loop until we hit an acceptable entry to yield // Loop until we hit an acceptable entry to yield
assert(iter_->Valid()); assert(iter_->Valid());
assert(status_.ok()); assert(status_.ok());

Loading…
Cancel
Save