您的位置:首页 > 其它

LevelDB源码分析-第一印象

2015-02-09 18:07 183 查看
leveldb是google开源的nosql数据库,被很多人推荐,因为良好的C++代码格式,咱们试图来分析一下吧

从github下载源码,代码量不是很大,而且目录结构也很清晰,咱们先写一下入门程序,来熟悉一下基本用法

leveldb::DB* db;
leveldb::Options options;
options.create_if_missing = true;
leveldb::Status status = leveldb::DB::Open(options,"/tmp/testdb",&db);
assert(status.ok());

status = db->put(leveldb::WriteOptions(),"name","phgame");
assert(status.ok());
status = db->get(leveldb::ReadOptions(),"name",&value);
assert(status.ok());

leveldb::ReadOptions readoptions;
readoptions.snapshot = db->getSnapshot();

leveldb::Iterator* itor = db->NewIterator(readoptions);
for(iter->SeekToFirst();iter->Valid();iter->Next()){
std::out<<iter->key().ToString()<<" :" <<iter->value().ToString();

db->ReleaseSnapshot(readoptions.snapshot);

delete db;


上面的代码包含了基本用法,包括打开,关闭,写入,读出,snapshot,iterator,等基本操作,可以看到google的命名规则.

Google C++ Style Guide

http://www.cnblogs.com/chlyzone/archive/2011/04/09/2010455.html

实现简要

leveldb是根据big table的思想来做的,所以咱们还需要理解一下bigtable是怎么回事,当然我也不懂..慢慢来吧
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: