Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
4d67e4ad
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看板
提交
4d67e4ad
编写于
6月 09, 2014
作者:
V
vlivanov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8032400: JSR292: invokeSpecial: InternalError attempting to lookup a method
Reviewed-by: psandoz, jrose
上级
9ac615ba
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
209 addition
and
8 deletion
+209
-8
src/share/classes/java/lang/invoke/MethodHandles.java
src/share/classes/java/lang/invoke/MethodHandles.java
+15
-8
test/java/lang/invoke/lookup/SpecialStatic.java
test/java/lang/invoke/lookup/SpecialStatic.java
+194
-0
未找到文件。
src/share/classes/java/lang/invoke/MethodHandles.java
浏览文件 @
4d67e4ad
...
@@ -1611,23 +1611,30 @@ return mh1;
...
@@ -1611,23 +1611,30 @@ return mh1;
checkSecurityManager
(
refc
,
method
);
checkSecurityManager
(
refc
,
method
);
assert
(!
method
.
isMethodHandleInvoke
());
assert
(!
method
.
isMethodHandleInvoke
());
Class
<?>
refcAsSuper
;
if
(
refKind
==
REF_invokeSpecial
&&
if
(
refKind
==
REF_invokeSpecial
&&
refc
!=
lookupClass
()
&&
refc
!=
lookupClass
()
&&
!
refc
.
isInterface
()
&&
!
refc
.
isInterface
()
&&
refc
!=
(
refcAsSuper
=
lookupClass
().
getSuperclass
()
)
&&
refc
!=
lookupClass
().
getSuperclass
(
)
&&
refc
.
isAssignableFrom
(
lookupClass
()))
{
refc
.
isAssignableFrom
(
lookupClass
()))
{
assert
(!
method
.
getName
().
equals
(
"<init>"
));
// not this code path
assert
(!
method
.
getName
().
equals
(
"<init>"
));
// not this code path
// Per JVMS 6.5, desc. of invokespecial instruction:
// Per JVMS 6.5, desc. of invokespecial instruction:
// If the method is in a superclass of the LC,
// If the method is in a superclass of the LC,
// and if our original search was above LC.super,
// and if our original search was above LC.super,
// repeat the search (symbolic lookup) from LC.super.
// repeat the search (symbolic lookup) from LC.super
// and continue with the direct superclass of that class,
// and so forth, until a match is found or no further superclasses exist.
// FIXME: MemberName.resolve should handle this instead.
// FIXME: MemberName.resolve should handle this instead.
MemberName
m2
=
new
MemberName
(
refcAsSuper
,
Class
<?>
refcAsSuper
=
lookupClass
();
MemberName
m2
;
do
{
refcAsSuper
=
refcAsSuper
.
getSuperclass
();
m2
=
new
MemberName
(
refcAsSuper
,
method
.
getName
(),
method
.
getName
(),
method
.
getMethodType
(),
method
.
getMethodType
(),
REF_invokeSpecial
);
REF_invokeSpecial
);
m2
=
IMPL_NAMES
.
resolveOrNull
(
refKind
,
m2
,
lookupClassOrNull
());
m2
=
IMPL_NAMES
.
resolveOrNull
(
refKind
,
m2
,
lookupClassOrNull
());
}
while
(
m2
==
null
&&
// no method is found yet
refc
!=
refcAsSuper
);
// search up to refc
if
(
m2
==
null
)
throw
new
InternalError
(
method
.
toString
());
if
(
m2
==
null
)
throw
new
InternalError
(
method
.
toString
());
method
=
m2
;
method
=
m2
;
refc
=
refcAsSuper
;
refc
=
refcAsSuper
;
...
...
test/java/lang/invoke/lookup/SpecialStatic.java
0 → 100644
浏览文件 @
4d67e4ad
/*
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/* @test
* @bug 8032400
* @summary JSR292: invokeSpecial: InternalError attempting to lookup a method
* @compile -XDignore.symbol.file SpecialStatic.java
* @run junit test.java.lang.invoke.lookup.SpecialStatic
*/
package
test.java.lang.invoke.lookup
;
import
java.lang.invoke.MethodHandle
;
import
java.lang.invoke.MethodHandles
;
import
java.lang.invoke.MethodType
;
import
jdk.internal.org.objectweb.asm.*
;
import
org.junit.Test
;
import
static
jdk
.
internal
.
org
.
objectweb
.
asm
.
Opcodes
.*;
import
static
org
.
junit
.
Assert
.*;
/**
* Test case:
* class T1 { int m() { return 1; }}
* class T2 extends T1 { static int m() { return 2; }}
* class T3 extends T2 { int m() { return 3; }}
*
* T3::test { invokespecial T1.m() T3 } ==> T1::m
*/
public
class
SpecialStatic
{
static
class
CustomClassLoader
extends
ClassLoader
{
public
Class
<?>
loadClass
(
String
name
)
throws
ClassNotFoundException
{
if
(
findLoadedClass
(
name
)
!=
null
)
{
return
findLoadedClass
(
name
);
}
if
(
"T1"
.
equals
(
name
))
{
byte
[]
classFile
=
dumpT1
();
return
defineClass
(
"T1"
,
classFile
,
0
,
classFile
.
length
);
}
if
(
"T2"
.
equals
(
name
))
{
byte
[]
classFile
=
dumpT2
();
return
defineClass
(
"T2"
,
classFile
,
0
,
classFile
.
length
);
}
if
(
"T3"
.
equals
(
name
))
{
byte
[]
classFile
=
dumpT3
();
return
defineClass
(
"T3"
,
classFile
,
0
,
classFile
.
length
);
}
return
super
.
loadClass
(
name
);
}
}
private
static
ClassLoader
cl
=
new
CustomClassLoader
();
private
static
Class
t1
,
t3
;
static
{
try
{
t1
=
cl
.
loadClass
(
"T1"
);
t3
=
cl
.
loadClass
(
"T3"
);
}
catch
(
ClassNotFoundException
e
)
{
throw
new
Error
(
e
);
}
}
public
static
void
main
(
String
[]
args
)
throws
Throwable
{
SpecialStatic
test
=
new
SpecialStatic
();
test
.
testConstant
();
test
.
testFindSpecial
();
}
@Test
public
void
testConstant
()
throws
Throwable
{
MethodHandle
mh
=
(
MethodHandle
)
t3
.
getDeclaredMethod
(
"getMethodHandle"
).
invoke
(
null
);
int
result
=
(
int
)
mh
.
invoke
(
t3
.
newInstance
());
assertEquals
(
result
,
1
);
// T1.m should be invoked.
}
@Test
public
void
testFindSpecial
()
throws
Throwable
{
MethodHandles
.
Lookup
lookup
=
(
MethodHandles
.
Lookup
)
t3
.
getDeclaredMethod
(
"getLookup"
).
invoke
(
null
);
MethodHandle
mh
=
lookup
.
findSpecial
(
t1
,
"m"
,
MethodType
.
methodType
(
int
.
class
),
t3
);
int
result
=
(
int
)
mh
.
invoke
(
t3
.
newInstance
());
assertEquals
(
result
,
1
);
// T1.m should be invoked.
}
public
static
byte
[]
dumpT1
()
{
ClassWriter
cw
=
new
ClassWriter
(
0
);
MethodVisitor
mv
;
cw
.
visit
(
52
,
ACC_PUBLIC
+
ACC_SUPER
,
"T1"
,
null
,
"java/lang/Object"
,
null
);
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
,
"<init>"
,
"()V"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitVarInsn
(
ALOAD
,
0
);
mv
.
visitMethodInsn
(
INVOKESPECIAL
,
"java/lang/Object"
,
"<init>"
,
"()V"
,
false
);
mv
.
visitInsn
(
RETURN
);
mv
.
visitMaxs
(
1
,
1
);
mv
.
visitEnd
();
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
,
"m"
,
"()I"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitIntInsn
(
BIPUSH
,
1
);
mv
.
visitInsn
(
IRETURN
);
mv
.
visitMaxs
(
1
,
1
);
mv
.
visitEnd
();
cw
.
visitEnd
();
return
cw
.
toByteArray
();
}
public
static
byte
[]
dumpT2
()
{
ClassWriter
cw
=
new
ClassWriter
(
0
);
MethodVisitor
mv
;
cw
.
visit
(
52
,
ACC_PUBLIC
+
ACC_SUPER
,
"T2"
,
null
,
"T1"
,
null
);
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
,
"<init>"
,
"()V"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitVarInsn
(
ALOAD
,
0
);
mv
.
visitMethodInsn
(
INVOKESPECIAL
,
"T1"
,
"<init>"
,
"()V"
,
false
);
mv
.
visitInsn
(
RETURN
);
mv
.
visitMaxs
(
1
,
1
);
mv
.
visitEnd
();
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
|
ACC_STATIC
,
"m"
,
"()I"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitIntInsn
(
BIPUSH
,
2
);
mv
.
visitInsn
(
IRETURN
);
mv
.
visitMaxs
(
1
,
1
);
mv
.
visitEnd
();
cw
.
visitEnd
();
return
cw
.
toByteArray
();
}
public
static
byte
[]
dumpT3
()
{
ClassWriter
cw
=
new
ClassWriter
(
0
);
MethodVisitor
mv
;
cw
.
visit
(
52
,
ACC_PUBLIC
+
ACC_SUPER
,
"T3"
,
null
,
"T2"
,
null
);
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
,
"<init>"
,
"()V"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitVarInsn
(
ALOAD
,
0
);
mv
.
visitMethodInsn
(
INVOKESPECIAL
,
"T2"
,
"<init>"
,
"()V"
,
false
);
mv
.
visitInsn
(
RETURN
);
mv
.
visitMaxs
(
1
,
1
);
mv
.
visitEnd
();
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
,
"m"
,
"()I"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitIntInsn
(
BIPUSH
,
3
);
mv
.
visitInsn
(
IRETURN
);
mv
.
visitMaxs
(
1
,
1
);
mv
.
visitEnd
();
// getMethodHandle
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
+
ACC_STATIC
,
"getMethodHandle"
,
"()Ljava/lang/invoke/MethodHandle;"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitLdcInsn
(
new
Handle
(
H_INVOKESPECIAL
,
"T1"
,
"m"
,
"()I"
));
mv
.
visitInsn
(
ARETURN
);
mv
.
visitMaxs
(
1
,
0
);
mv
.
visitEnd
();
// getLookup
mv
=
cw
.
visitMethod
(
ACC_PUBLIC
+
ACC_STATIC
,
"getLookup"
,
"()Ljava/lang/invoke/MethodHandles$Lookup;"
,
null
,
null
);
mv
.
visitCode
();
mv
.
visitMethodInsn
(
INVOKESTATIC
,
"java/lang/invoke/MethodHandles"
,
"lookup"
,
"()Ljava/lang/invoke/MethodHandles$Lookup;"
,
false
);
mv
.
visitInsn
(
ARETURN
);
mv
.
visitMaxs
(
1
,
0
);
mv
.
visitEnd
();
cw
.
visitEnd
();
return
cw
.
toByteArray
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录