Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
510a0427
提交
510a0427
authored
12 年前
作者:
noelgrandin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
use Collections.binarySearch for searching through oldRoots
上级
4fd45327
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
27 行增加
和
16 行删除
+27
-16
MVMap.java
h2/src/tools/org/h2/dev/store/btree/MVMap.java
+27
-16
没有找到文件。
h2/src/tools/org/h2/dev/store/btree/MVMap.java
浏览文件 @
510a0427
...
@@ -9,6 +9,8 @@ package org.h2.dev.store.btree;
...
@@ -9,6 +9,8 @@ package org.h2.dev.store.btree;
import
java.util.AbstractMap
;
import
java.util.AbstractMap
;
import
java.util.AbstractSet
;
import
java.util.AbstractSet
;
import
java.util.ArrayList
;
import
java.util.ArrayList
;
import
java.util.Collections
;
import
java.util.Comparator
;
import
java.util.HashMap
;
import
java.util.HashMap
;
import
java.util.Iterator
;
import
java.util.Iterator
;
import
java.util.Map
;
import
java.util.Map
;
...
@@ -564,15 +566,8 @@ public class MVMap<K, V> extends AbstractMap<K, V> {
...
@@ -564,15 +566,8 @@ public class MVMap<K, V> extends AbstractMap<K, V> {
return
;
return
;
}
}
ArrayList
<
Page
>
list
=
oldRoots
;
ArrayList
<
Page
>
list
=
oldRoots
;
int
i
=
0
;
int
i
=
Collections
.
binarySearch
(
list
,
oldest
,
PAGE_VERSION_COMPARATOR
);
// TODO iterate over the list is inefficient
if
(
i
<
0
)
{
for
(;
i
<
list
.
size
();
i
++)
{
Page
p
=
list
.
get
(
i
);
if
(
p
.
getVersion
()
>
oldest
)
{
break
;
}
}
if
(
i
==
0
)
{
return
;
return
;
}
}
// create a new instance
// create a new instance
...
@@ -582,6 +577,21 @@ public class MVMap<K, V> extends AbstractMap<K, V> {
...
@@ -582,6 +577,21 @@ public class MVMap<K, V> extends AbstractMap<K, V> {
oldRoots
=
list
;
oldRoots
=
list
;
}
}
private
static
final
Comparator
<
Object
>
PAGE_VERSION_COMPARATOR
=
new
Comparator
<
Object
>()
{
@Override
public
int
compare
(
Object
o1
,
Object
o2
)
{
Page
p
=
(
Page
)
o1
;
Long
key
=
(
Long
)
o2
;
if
(
p
.
getVersion
()
==
key
)
return
0
;
else
if
(
p
.
getVersion
()
<
key
)
return
-
1
;
else
return
1
;
}
};
public
void
setReadOnly
(
boolean
readOnly
)
{
public
void
setReadOnly
(
boolean
readOnly
)
{
this
.
readOnly
=
readOnly
;
this
.
readOnly
=
readOnly
;
}
}
...
@@ -674,14 +684,15 @@ public class MVMap<K, V> extends AbstractMap<K, V> {
...
@@ -674,14 +684,15 @@ public class MVMap<K, V> extends AbstractMap<K, V> {
if
(
r
.
getVersion
()
==
version
)
{
if
(
r
.
getVersion
()
==
version
)
{
newest
=
r
;
newest
=
r
;
}
else
{
}
else
{
// TODO could do a binary search
ArrayList
<
Page
>
list
=
oldRoots
;
ArrayList
<
Page
>
list
=
oldRoots
;
for
(
int
i
=
0
;
i
<
list
.
size
();
i
++)
{
// find the newest page that has a getVersion() <= version
Page
p
=
list
.
get
(
i
);
int
i
=
Collections
.
binarySearch
(
list
,
version
,
PAGE_VERSION_COMPARATOR
);
if
(
p
.
getVersion
()
<=
version
)
{
if
(
i
>
0
)
{
newest
=
p
;
newest
=
list
.
get
(
i
)
;
}
else
{
}
else
{
break
;
i
=
-(
i
+
1
);
// calculate insertion point
if
(
i
>
0
)
{
newest
=
list
.
get
(
i
-
1
);
}
}
}
}
}
}
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论