Java JDK11基于嵌套的访问控制的实现
2019-10-14 18:07
1456 查看
Java(和其他语言)通过内部类支持嵌套类。要使其正常工作,需要编译器执行一些技巧。这是一个例子:
public class Outer { private int outerInt; class Inner { public void printOuterInt() { System.out.println("Outer int = " + outerInt); } } }
在执行编译之前,编译器会修改它以创建类似的东西:
public class Outer { private int outerInt; public int access$000() { return outerInt; } } class Inner$Outer { Outer outer; public void printOuterInt() { System.out.println("Outer int = " + outer.access$000()); } }
虽然从逻辑上讲,内部类是与外部类相同的代码实体的一部分,但它被编译为一个单独的类。因此,它需要编译器创建合成桥接方法,以提供对外部类的私有字段的访问。
这个JEP引入了巢的概念,其中同一巢的两个成员(我们的例子中的外部和内部)是同窝。为类文件格式NestHost和NestMembers定义了两个新属性。这些更改对于支持嵌套类并编译为字节码的其他语言非常有用。
此功能为java.lang.Class引入了三个新方法:
- Class getNestHost()
- Class[] getNestMembers()
- boolean isNestmateOf(Class)
此功能还需要更改Java虚拟机规范(JVMS),特别是第5.4.4节“访问控制”。
以上就是本文的全部内容,希望对大家的学习有所帮助
相关文章推荐
- 利用 AOP 实现 .NET 上完整的基于角色的访问控制(RBAC)模型
- 利用 AOP 实现 .NET 上完整的基于角色的访问控制(RBAC)模型
- http服务--基于用户的访问控制实现
- 基于BIND实现DNS的解析、主从、子域、请求转发、访问控制
- Java随手笔记8之包、环境变量和访问控制及maven profile实现多环境打包
- elasticsearch6.1在java中的连接基于xpack实现权限访问配置
- RBAC(基于角色的访问控制)的实现
- Xianfeng轻量级Java中间件平台:基于RBAC模型实现权限控制的原理
- 基于AOP实现权限管理:访问控制模型RBAC和ACL
- ACEGI实现对 Java 对象的访问控制
- AngularJS – 实现基于角色访问控制的 GUI
- 基于java过滤器实现web系统的IP访问控制
- 基于角色的访问控制'的权限管理的数据库的设计实现
- 动态Proxy与Java ACL用户访问控制机制实现
- Xianfeng轻量级Java中间件平台:基于RBAC模型实现权限控制的原理
- SpringMVC3.1.1+Spring3.1.1+Hibernate4+Velocity+EasyUI+ZTree实现RBAC基于角色的访问控制(二)
- 基于java语言的给cube添加custom view来实现权限控制
- 权限管理:RBAC(基于角色的访问控制)SpringMVC实现
- 基于java过滤器实现web系统的IP访问控制