mirror of
https://github.com/google/flatbuffers.git
synced 2026-06-29 17:22:03 +00:00
Merge pull request #205 from zachreizner/fb_bsearch
Use std::bsearch in LookupByKey for binary search
This commit is contained in:
@@ -305,28 +305,17 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template<typename K> return_type LookupByKey(K key) const {
|
template<typename K> return_type LookupByKey(K key) const {
|
||||||
auto span = size();
|
std::size_t count = size();
|
||||||
uoffset_t start = 0;
|
void *search_result = std::bsearch(&key, Data(), count,
|
||||||
// Perform binary search for key.
|
IndirectHelper<T>::element_stride, KeyCompare<K>);
|
||||||
while (span) {
|
|
||||||
// Compare against middle element of current span.
|
if (!search_result) {
|
||||||
auto middle = span / 2;
|
return nullptr; // Key not found.
|
||||||
auto table = Get(start + middle);
|
|
||||||
auto comp = table->KeyCompareWithValue(key);
|
|
||||||
if (comp > 0) {
|
|
||||||
// Greater than. Adjust span and try again.
|
|
||||||
span = middle;
|
|
||||||
} else if (comp < 0) {
|
|
||||||
// Less than. Adjust span and try again.
|
|
||||||
middle++;
|
|
||||||
start += middle;
|
|
||||||
span -= middle;
|
|
||||||
} else {
|
|
||||||
// Found element.
|
|
||||||
return table;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return nullptr; // Key not found.
|
|
||||||
|
const uint8_t *data = reinterpret_cast<const uint8_t *>(search_result);
|
||||||
|
|
||||||
|
return IndirectHelper<T>::Read(data, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@@ -335,6 +324,17 @@ protected:
|
|||||||
Vector();
|
Vector();
|
||||||
|
|
||||||
uoffset_t length_;
|
uoffset_t length_;
|
||||||
|
|
||||||
|
private:
|
||||||
|
template<typename K> static int KeyCompare(const void *ap, const void *bp) {
|
||||||
|
const K *key = reinterpret_cast<const K *>(ap);
|
||||||
|
const uint8_t *data = reinterpret_cast<const uint8_t *>(bp);
|
||||||
|
auto table = IndirectHelper<T>::Read(data, 0);
|
||||||
|
|
||||||
|
// std::bsearch compares with the operands transposed, so we negate the
|
||||||
|
// result here.
|
||||||
|
return -table->KeyCompareWithValue(*key);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Convenient helper function to get the length of any vector, regardless
|
// Convenient helper function to get the length of any vector, regardless
|
||||||
|
|||||||
Reference in New Issue
Block a user