leveldb Slice 分析
版權(quán)聲明:本文為 cheng-zhi 原創(chuàng)文章婉徘,可以隨意轉(zhuǎn)載,但必須在明確位置注明出處!
什么是 leveldb Slice逮光?
有許多優(yōu)秀的 C++
框架都沒有直接使用 C++
提供的 string
代箭,而是自己封裝了一份字符串的操作,Slice
就是 leveldb
自己使用的字符串操作類涕刚。
源碼位置
slice
位于源碼的這個(gè)位置:
leveldb/include/leveldb/slice.h
模仿實(shí)現(xiàn)
學(xué)習(xí)大神的代碼嗡综,最好的方式我認(rèn)為是理解之后自己動(dòng)手寫一遍,即使是抄杜漠,對(duì)我們也是有幫助的极景,因?yàn)閷?shí)踐過(guò)的東西記憶更加深刻。
#ifndef SLICE_H_
#define SLICE_H_
#include <assert.h>
#include <stddef.h>
#include <string.h>
#include <string>
namespace myspace {
class Slice {
public:
// Create an empty slice.
Slice() : data_(""), size_(0) { }
// Create a slice that refers to cstr[0, n - 1].
Slice(const char* cstr, size_t n) : data_(cstr), size_(n) { }
// Create a slice that refers to the contents of "str"
Slice(const std::string& str) : data_(str.data()), size_(s.size()) { }
// Create a slice that refers to cstr[0, strlen(cstr) - 1].
Slice(const char* cstr) : data_(cstr), size_(strlen(cstr)) { }
// Return a pointer to the beginning of the referenced data.
const char* data() const { return data_; }
// Return the length (in bytes) of the referenced data.
size_t size() const { return size_; }
// Return true if the length of the referenced data id zero.
bool empty() const { return size_; }
// Return the it byte in the referenced data.
// REQUESTS: n < size()
char operator[](size_t n) const {
assert(n < size());
return data_[n];
}
bool operator==(const slice& lhs, const Slice& rhs) {
return ((lhs.size_() == rhs.size()) && (memcmp(lhs.data(), rhs.data(), lhs.size()) == 0));
}
bool operator!=(const Slice& lhs, const Slice& rhs) {
return !(lhs == rhs);
}
// Change this slice to refer to an empty array.
void clear() { data_ = ""; size_ = 0; }
// Drop the first "n" bytes from this slice.
void remove_prefix(size_t n) {
assert(n <= size());
data_ += n;
size_ -= n;
}
// Return a string that contains the copy of the referenced data.
std::string to_string() const { return std::string(data_, size_); }
// Three-way comparison.
// Return value:
// < 0 if "*this" < "b"
// == 0 if "*this" == "b"
// > 0 if "*this" > "b"
int compare(const Slice& b) const {
const size_t min_len = (size_ < b.size_) ? size_ : b.size_;
int r = memcmp(data_, b.data_, min_len);
// if equal
if (0 == r) {
if (size_ < b.size_)
r = -1;
else if (size_ > b.size_)
r = +1;
}
return r;
}
private:
const char* data_;
size_t size_;
};
}
#endif //SLICE_H_
函數(shù)的定義都放在了類的聲明里面驾茴,這些函數(shù)默認(rèn)都是 inline
函數(shù)盼樟。