Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
dotNET Platform
runtime
提交
25e369ff
R
runtime
项目概览
dotNET Platform
/
runtime
11 个月 前同步成功
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
runtime
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
25e369ff
编写于
6月 28, 2022
作者:
Z
Zoltan Varga
提交者:
GitHub
6月 28, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[mono] Avoid a linear search in the GENERICPARAMCONSTRAINT table, its sorted by owner. (#71349)
上级
4b1a1213
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
22 addition
and
2 deletion
+22
-2
src/mono/mono/metadata/metadata.c
src/mono/mono/metadata/metadata.c
+22
-2
未找到文件。
src/mono/mono/metadata/metadata.c
浏览文件 @
25e369ff
...
...
@@ -7109,7 +7109,8 @@ get_constraints (MonoImage *image, int owner, MonoClass ***constraints, MonoGene
{
MonoTableInfo
*
tdef
=
&
image
->
tables
[
MONO_TABLE_GENERICPARAMCONSTRAINT
];
guint32
cols
[
MONO_GENPARCONSTRAINT_SIZE
];
guint32
i
,
token
,
found
;
locator_t
loc
;
guint32
i
,
token
,
found
,
start
;
MonoClass
*
klass
,
**
res
;
GSList
*
cons
=
NULL
,
*
tmp
;
MonoGenericContext
*
context
=
&
container
->
context
;
...
...
@@ -7120,7 +7121,26 @@ get_constraints (MonoImage *image, int owner, MonoClass ***constraints, MonoGene
found
=
0
;
/* FIXME: metadata-update */
guint32
rows
=
table_info_get_rows
(
tdef
);
for
(
i
=
0
;
i
<
rows
;
++
i
)
{
loc
.
idx
=
owner
;
loc
.
col_idx
=
MONO_GENPARCONSTRAINT_GENERICPAR
;
loc
.
t
=
tdef
;
loc
.
result
=
0
;
gboolean
is_found
=
tdef
->
base
&&
mono_binary_search
(
&
loc
,
tdef
->
base
,
table_info_get_rows
(
tdef
),
tdef
->
row_size
,
table_locator
)
!=
NULL
;
if
(
!
is_found
&&
!
image
->
has_updates
)
return
TRUE
;
if
(
is_found
)
{
/* Find the first entry by searching backwards */
while
((
loc
.
result
>
0
)
&&
(
mono_metadata_decode_row_col
(
tdef
,
loc
.
result
-
1
,
MONO_GENPARCONSTRAINT_GENERICPAR
)
==
owner
))
loc
.
result
--
;
start
=
loc
.
result
;
}
else
{
start
=
0
;
}
for
(
i
=
start
;
i
<
rows
;
++
i
)
{
mono_metadata_decode_row
(
tdef
,
i
,
cols
,
MONO_GENPARCONSTRAINT_SIZE
);
if
(
cols
[
MONO_GENPARCONSTRAINT_GENERICPAR
]
==
owner
)
{
token
=
mono_metadata_token_from_dor
(
cols
[
MONO_GENPARCONSTRAINT_CONSTRAINT
]);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录