Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
f02b149f
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
f02b149f
编写于
2月 06, 2017
作者:
P
prr
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8172461: Service Registration Lifecycle
Reviewed-by: serb, vadim, skoivu, shurailine
上级
7fe61077
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
17 addition
and
4 deletion
+17
-4
src/share/classes/javax/imageio/spi/ServiceRegistry.java
src/share/classes/javax/imageio/spi/ServiceRegistry.java
+17
-4
未找到文件。
src/share/classes/javax/imageio/spi/ServiceRegistry.java
浏览文件 @
f02b149f
...
...
@@ -26,6 +26,9 @@
package
javax.imageio.spi
;
import
java.io.File
;
import
java.security.AccessControlContext
;
import
java.security.AccessController
;
import
java.security.PrivilegedAction
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.Iterator
;
...
...
@@ -701,11 +704,12 @@ class SubRegistry {
Class
category
;
// Provider Objects organized by partial or
i
dering
PartiallyOrderedSet
poset
=
new
PartiallyOrderedSet
();
// Provider Objects organized by partial ordering
final
PartiallyOrderedSet
poset
=
new
PartiallyOrderedSet
();
// Class -> Provider Object of that class
Map
<
Class
<?>,
Object
>
map
=
new
HashMap
();
final
Map
<
Class
<?>,
Object
>
map
=
new
HashMap
();
final
Map
<
Class
<?>,
AccessControlContext
>
accMap
=
new
HashMap
<>();
public
SubRegistry
(
ServiceRegistry
registry
,
Class
category
)
{
this
.
registry
=
registry
;
...
...
@@ -720,6 +724,7 @@ class SubRegistry {
deregisterServiceProvider
(
oprovider
);
}
map
.
put
(
provider
.
getClass
(),
provider
);
accMap
.
put
(
provider
.
getClass
(),
AccessController
.
getContext
());
poset
.
add
(
provider
);
if
(
provider
instanceof
RegisterableService
)
{
RegisterableService
rs
=
(
RegisterableService
)
provider
;
...
...
@@ -739,6 +744,7 @@ class SubRegistry {
if
(
provider
==
oprovider
)
{
map
.
remove
(
provider
.
getClass
());
accMap
.
remove
(
provider
.
getClass
());
poset
.
remove
(
provider
);
if
(
provider
instanceof
RegisterableService
)
{
RegisterableService
rs
=
(
RegisterableService
)
provider
;
...
...
@@ -785,10 +791,17 @@ class SubRegistry {
if
(
provider
instanceof
RegisterableService
)
{
RegisterableService
rs
=
(
RegisterableService
)
provider
;
rs
.
onDeregistration
(
registry
,
category
);
AccessControlContext
acc
=
accMap
.
get
(
provider
.
getClass
());
if
(
acc
!=
null
||
System
.
getSecurityManager
()
==
null
)
{
AccessController
.
doPrivileged
((
PrivilegedAction
<
Void
>)
()
->
{
rs
.
onDeregistration
(
registry
,
category
);
return
null
;
},
acc
);
}
}
}
poset
.
clear
();
accMap
.
clear
();
}
public
void
finalize
()
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录