当前位置: 首页>>代码示例>>C++>>正文


C++ LeafNode::clone方法代码示例

本文整理汇总了C++中LeafNode::clone方法的典型用法代码示例。如果您正苦于以下问题:C++ LeafNode::clone方法的具体用法?C++ LeafNode::clone怎么用?C++ LeafNode::clone使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在LeafNode的用法示例。


在下文中一共展示了LeafNode::clone方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: begin

BPlusTreeIterator* BPlusTree::begin() {
	BPlusTreeIterator* iterator = NULL;
	LeafNode* leaf = static_cast <LeafNode*> (hidratateNode(firstLeaf));
	if (leaf) {
		iterator = new BPlusTreeIterator(leaf->clone(), 0, fileBlockManager);
		freeNodeMemory(leaf);
	}
	return iterator;
}
开发者ID:busiris2014,项目名称:7506Condor1C2014,代码行数:9,代码来源:BPlusTree.cpp

示例2: getPosition

pair<Record*, BPlusTreeIterator*> BPlusTree::search(Key k) {
	Node *aNode = root;
	if (!aNode)
		return pair<Record*, BPlusTreeIterator*> (NULL, NULL);

	while (!aNode->isLeaf()) {
		InnerNode *innerNode = static_cast<InnerNode*> (aNode);
		int position = getPosition(innerNode, k);
		aNode = hidratateNode(innerNode->sons[position]);
		if (innerNode != root)
			freeNodeMemory(innerNode);
	}
	LeafNode *leafNode = static_cast<LeafNode*> (aNode);
	Record* record = NULL;
	BPlusTreeIterator* iterator = NULL;
	int pos = getPosition(leafNode, k);
	if (pos < leafNode->keyMount && equalKey(k, leafNode->keys[pos])) {
		record = new Record(leafNode->keys[pos].Clone(), new ByteString(leafNode->byteData[pos]));
		iterator = new BPlusTreeIterator(leafNode->clone(), pos, fileBlockManager);
	}
	if (leafNode != root)
		freeNodeMemory(leafNode);
	return pair<Record*, BPlusTreeIterator*> (record, iterator);
}
开发者ID:busiris2014,项目名称:7506Condor1C2014,代码行数:24,代码来源:BPlusTree.cpp


注:本文中的LeafNode::clone方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。