Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
dbdf2653
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
dbdf2653
编写于
2月 08, 2023
作者:
M
Minglei Jin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(tdb/page): remove n^2 implementation of page defragment
上级
a086f83c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
0 addition
and
56 deletion
+0
-56
source/libs/tdb/src/db/tdbPage.c
source/libs/tdb/src/db/tdbPage.c
+0
-56
未找到文件。
source/libs/tdb/src/db/tdbPage.c
浏览文件 @
dbdf2653
...
...
@@ -418,7 +418,6 @@ static int32_t tCellIdxCmprFn(const void *p1, const void *p2) {
}
}
static
int
tdbPageDefragment
(
SPage
*
pPage
)
{
#if 1
int32_t
nFree
=
TDB_PAGE_NFREE
(
pPage
);
int32_t
nCell
=
TDB_PAGE_NCELLS
(
pPage
);
...
...
@@ -449,62 +448,7 @@ static int tdbPageDefragment(SPage *pPage) {
tdbOsFree
(
aCellIdx
);
ASSERT
(
pPage
->
pFreeEnd
-
pPage
->
pFreeStart
==
nFree
);
#else
int
nFree
;
int
nCells
;
SCell
*
pCell
;
SCell
*
pNextCell
;
SCell
*
pTCell
;
int
szCell
;
int
idx
;
int
iCell
;
nFree
=
TDB_PAGE_NFREE
(
pPage
);
nCells
=
TDB_PAGE_NCELLS
(
pPage
);
ASSERT
(
pPage
->
pFreeEnd
-
pPage
->
pFreeStart
<
nFree
);
// Loop to compact the page content
// Here we use an O(n^2) algorithm to do the job since
// this is a low frequency job.
pNextCell
=
(
u8
*
)
pPage
->
pPageFtr
;
pCell
=
NULL
;
for
(
iCell
=
0
;;
iCell
++
)
{
// compact over
if
(
iCell
==
nCells
)
{
pPage
->
pFreeEnd
=
pNextCell
;
break
;
}
for
(
int
i
=
0
;
i
<
nCells
;
i
++
)
{
if
(
TDB_PAGE_CELL_OFFSET_AT
(
pPage
,
i
)
<
pNextCell
-
pPage
->
pData
)
{
pTCell
=
TDB_PAGE_CELL_AT
(
pPage
,
i
);
if
(
pCell
==
NULL
||
pCell
<
pTCell
)
{
pCell
=
pTCell
;
idx
=
i
;
}
}
else
{
continue
;
}
}
ASSERT
(
pCell
!=
NULL
);
szCell
=
(
*
pPage
->
xCellSize
)(
pPage
,
pCell
,
0
,
NULL
,
NULL
);
ASSERT
(
pCell
+
szCell
<=
pNextCell
);
if
(
pCell
+
szCell
<
pNextCell
)
{
memmove
(
pNextCell
-
szCell
,
pCell
,
szCell
);
}
pCell
=
NULL
;
pNextCell
=
pNextCell
-
szCell
;
TDB_PAGE_CELL_OFFSET_AT_SET
(
pPage
,
idx
,
pNextCell
-
pPage
->
pData
);
}
TDB_PAGE_CCELLS_SET
(
pPage
,
pPage
->
pFreeEnd
-
pPage
->
pData
);
TDB_PAGE_FCELL_SET
(
pPage
,
0
);
#endif
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录