Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
d0a286ef
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看板
提交
d0a286ef
编写于
10月 20, 2013
作者:
R
rfield
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8025631: Enhance Lambda construction
Reviewed-by: ksrini, ahgross
上级
02330e5b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
5 addition
and
60 deletion
+5
-60
src/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java
...classes/java/lang/invoke/InnerClassLambdaMetafactory.java
+5
-21
src/share/classes/java/lang/invoke/MagicLambdaImpl.java
src/share/classes/java/lang/invoke/MagicLambdaImpl.java
+0
-39
未找到文件。
src/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java
浏览文件 @
d0a286ef
...
...
@@ -33,7 +33,6 @@ import java.io.FilePermission;
import
java.lang.reflect.Constructor
;
import
java.security.AccessController
;
import
java.security.PrivilegedAction
;
import
java.security.ProtectionDomain
;
import
java.util.concurrent.atomic.AtomicInteger
;
import
java.util.PropertyPermission
;
...
...
@@ -50,14 +49,13 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*;
private
static
final
int
CLASSFILE_VERSION
=
51
;
private
static
final
String
METHOD_DESCRIPTOR_VOID
=
Type
.
getMethodDescriptor
(
Type
.
VOID_TYPE
);
private
static
final
String
NAME_MAGIC_ACCESSOR_IMPL
=
"java/lang/invoke/MagicLambdaImpl
"
;
private
static
final
String
JAVA_LANG_OBJECT
=
"java/lang/Object
"
;
private
static
final
String
NAME_CTOR
=
"<init>"
;
//Serialization support
private
static
final
String
NAME_SERIALIZED_LAMBDA
=
"java/lang/invoke/SerializedLambda"
;
private
static
final
String
DESCR_METHOD_WRITE_REPLACE
=
"()Ljava/lang/Object;"
;
private
static
final
String
NAME_METHOD_WRITE_REPLACE
=
"writeReplace"
;
private
static
final
String
NAME_OBJECT
=
"java/lang/Object"
;
private
static
final
String
DESCR_CTOR_SERIALIZED_LAMBDA
=
MethodType
.
methodType
(
void
.
class
,
Class
.
class
,
...
...
@@ -235,7 +233,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*;
}
cw
.
visit
(
CLASSFILE_VERSION
,
ACC_SUPER
+
ACC_FINAL
+
ACC_SYNTHETIC
,
lambdaClassName
,
null
,
NAME_MAGIC_ACCESSOR_IMPL
,
interfaces
);
JAVA_LANG_OBJECT
,
interfaces
);
// Generate final fields to be filled in by constructor
for
(
int
i
=
0
;
i
<
argTypes
.
length
;
i
++)
{
...
...
@@ -287,21 +285,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*;
new
PropertyPermission
(
"user.dir"
,
"read"
));
}
ClassLoader
loader
=
targetClass
.
getClassLoader
();
ProtectionDomain
pd
=
(
loader
==
null
)
?
null
:
AccessController
.
doPrivileged
(
new
PrivilegedAction
<
ProtectionDomain
>()
{
@Override
public
ProtectionDomain
run
()
{
return
targetClass
.
getProtectionDomain
();
}
}
);
return
UNSAFE
.
defineClass
(
lambdaClassName
,
classBytes
,
0
,
classBytes
.
length
,
loader
,
pd
);
return
UNSAFE
.
defineAnonymousClass
(
targetClass
,
classBytes
,
null
);
}
/**
...
...
@@ -313,7 +297,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*;
constructorDesc
,
null
,
null
);
ctor
.
visitCode
();
ctor
.
visitVarInsn
(
ALOAD
,
0
);
ctor
.
visitMethodInsn
(
INVOKESPECIAL
,
NAME_MAGIC_ACCESSOR_IMPL
,
NAME_CTOR
,
ctor
.
visitMethodInsn
(
INVOKESPECIAL
,
JAVA_LANG_OBJECT
,
NAME_CTOR
,
METHOD_DESCRIPTOR_VOID
);
int
lvIndex
=
0
;
for
(
int
i
=
0
;
i
<
argTypes
.
length
;
i
++)
{
...
...
@@ -353,7 +337,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*;
mv
.
visitLdcInsn
(
instantiatedMethodType
.
toMethodDescriptorString
());
mv
.
iconst
(
argTypes
.
length
);
mv
.
visitTypeInsn
(
ANEWARRAY
,
NAME
_OBJECT
);
mv
.
visitTypeInsn
(
ANEWARRAY
,
JAVA_LANG
_OBJECT
);
for
(
int
i
=
0
;
i
<
argTypes
.
length
;
i
++)
{
mv
.
visitInsn
(
DUP
);
mv
.
iconst
(
i
);
...
...
src/share/classes/java/lang/invoke/MagicLambdaImpl.java
已删除
100644 → 0
浏览文件 @
02330e5b
/*
* Copyright (c) 2012, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
package
java.lang.invoke
;
/** <P> MagicLambdaImpl (named for similarity to MagicAccessorImpl and
others, not because it actually implements an interface) is a
marker class in the hierarchy. All subclasses of this class are
"magically" granted access by the VM to otherwise inaccessible
fields and methods of other classes. It is distinct from MagicAccessorImpl
because, while we want to bypass accessibility checks, we do not want to
bypass verification.</P>
<P> Do not change the name of this class without also changing the
VM's code. </P> */
class
MagicLambdaImpl
{
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录