sun.reflect

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » 6.0 JDK Modules sun » reflect » sun.reflect 
sun.reflect

Licensee impact of JDK 1.4 reflection changes

Sun's JDK 1.4 contains a new implementation of java.lang.reflect which offers substantially higher performance than previous JDKs' native code. Licensees can at their discretion port these changes. There are no public API or documentation changes associated with the new reflection implementation aside from a few minor clarifications in the specifications of Method.invoke(), Constructor.newInstance(), and a few methods in java.lang.reflect.Field.

The bulk of the new implementation is Java programming language code which generates bytecodes, and is therefore portable. If licensees desire to port it, the following JVM changes are required:

  1. The following four new JVM entry points must be added:
    • JVM_GetClassDeclaredConstructors
    • JVM_GetClassDeclaredFields
    • JVM_GetClassDeclaredMethods
    • JVM_GetClassAccessFlags
    The first three return the declared constructors, fields, and methods for a given class, with an option to return only the public ones. They are similar in functionality to the earlier GetClassConstructors, GetClassFields, and GetClassMethods. JVM_GetClassDeclaredFields and JVM_GetClassDeclaredMethods must intern the Strings for the names of the Field and Method objects returned. The fouth returns the access flags for a given class as marked in the class file, as opposed to in the InnerClasses attribute if the class is an inner class, and therefore differs from JVM_GetClassModifiers for inner classes (most importantly, protected inner classes; see 4471811.)
  2. The JVM's link resolver must be modified to allow all field and method references from subclasses of sun.reflect.MagicAccessorImpl to any other class (even to private members of other classes) to succeed. This allows setAccessible() and its associated checks to be implemented in Java.
  3. The code which calls the verifier must skip verification for all subclasses of sun.reflect.MagicAccessorImpl. (It was originally intended that only a subset of the stub classes used for serialization would not pass the verifier, specifically, those subclassing SerializationConstructorAccessorImpl; see 4486457 for a case where this does not work.)
  4. The stack walker for security checks must be modified to skip not only all Method.invoke() frames, but also any frames for which the class is a subclass of sun.reflect.MethodAccessorImpl.
  5. The JVM entry points JVM_InvokeMethod and JVM_NewInstanceFromConstructor are currently still used because the first invocation of the bytecode-based reflection is currently slower than the original native code. The security checks they perform can, however, be disabled, as they are now performed by Java programming language code.

The following changes were discovered to be necessary for backward compatibility with certain applications (see bug 4474172):

  1. The existing JVM entry point JVM_LatestUserDefinedLoader (typically used in applications which rely on the 1.1 security framework) must skip reflection-related frames in its stack walk: specifically all frames associated with subclasses of sun.reflect.MethodAccessorImpl and sun.reflect.ConstructorAccessorImpl.
  2. The new reflection implementation can cause class loading to occur in previously-unexpected places (namely during reflective calls). This can cause class loaders which contain subtle bugs to break. In general it is not possible to guarantee complete backward bug compatibility, but one kind of bug has been observed more than once: the inability of a user-defined loader to handle delegation to it for a class it has already loaded. The new reflection implementation is predicated on delegation working properly, as it loads stub classes into newly-fabricated class loaders of type sun.reflect.DelegatingClassLoader, one stub class per loader, to allow unloading of the stub classes to occur more quickly. To handle this kind of bug, the JVM's internal class lookup mechanism must be slightly modified to check for instances of sun.reflect.DelegatingClassLoader as the incoming class loader and silently traverse the "parent" field once for such loaders before entering the bulk of the resolution code. This avoids an upcall to Java programming language code which certain loaders can not handle.

The following JVM entry points may be deleted:

  • JVM_GetClassFields
  • JVM_GetClassMethods
  • JVM_GetClassConstructors
  • JVM_GetClassField
  • JVM_GetClassMethod
  • JVM_GetClassConstructor
  • JVM_NewInstance
  • JVM_GetField
  • JVM_GetPrimitiveField
  • JVM_SetField
  • JVM_SetPrimitiveField

To keep using the previous reflection implementation, licensees should not take changes from Sun's JDK 1.4 relating specifically to the implementation of reflection in the following classes/methods and any associated native code:

  • java.lang.Class.newInstance0
  • java.lang.Class.getClassLoader0
  • java.lang.Class.getFields
  • java.lang.Class.getMethods
  • java.lang.Class.getDeclaredFields
  • java.lang.Class.getDeclaredMethods
  • java.lang.Class.getFields0
  • java.lang.Class.getMethods0
  • java.lang.Class.getConstructors0
  • java.lang.Class.getField0
  • java.lang.Class.getMethod0
  • java.lang.Class.getConstructor0
  • java.lang.ClassLoader.getCallerClassLoader
  • java.lang.System.getCallerClass
  • java.lang.reflect.AccessibleObject
  • java.lang.reflect.Constructor
  • java.lang.reflect.Field
  • java.lang.reflect.Method
  • java.lang.reflect.Modifier
  • sun.misc.ClassReflector

Java Source File NameTypeComment
AccessorGenerator.javaClass
BootstrapConstructorAccessorImpl.javaClass Uses Unsafe.allocateObject() to instantiate classes; only used for bootstrapping.
ByteVector.javaInterface A growable array of bytes.
ByteVectorFactory.javaClass
ByteVectorImpl.javaClass
ClassDefiner.javaClass Utility class which assists in calling Unsafe.defineClass() by creating a new class loader which delegates to the one needed in order for proper resolution of the given bytecodes to occur.
ClassFileAssembler.javaClass
ClassFileConstants.javaInterface Minimal set of class file constants for assembly of field and method accessors.
ConstantPool.javaClass Provides reflective access to the constant pools of classes. Currently this is needed to provide reflective access to annotations but may be used by other internal subsystems in the future.
ConstructorAccessor.javaInterface This interface provides the declaration for java.lang.reflect.Constructor.invoke().
ConstructorAccessorImpl.javaClass Package-private implementation of the ConstructorAccessor interface which has access to all classes and all fields, regardless of language restrictions.
DelegatingConstructorAccessorImpl.javaClass Delegates its invocation to another ConstructorAccessorImpl and can change its delegate at run time.
DelegatingMethodAccessorImpl.javaClass Delegates its invocation to another MethodAccessorImpl and can change its delegate at run time.
FieldAccessor.javaInterface This interface provides the declarations for the accessor methods of java.lang.reflect.Field.
FieldAccessorImpl.javaClass Package-private implementation of the FieldAccessor interface which has access to all classes and all fields, regardless of language restrictions.
FieldInfo.javaClass
InstantiationExceptionConstructorAccessorImpl.javaClass
Label.javaClass Allows forward references in bytecode streams emitted by ClassFileAssembler.
LangReflectAccess.javaInterface An interface which gives privileged packages Java-level access to internals of java.lang.reflect.
MagicAccessorImpl.javaClass

MagicAccessorImpl (named for parity with FieldAccessorImpl and others, not because it actually implements an interface) is a marker class in the hierarchy.

MethodAccessor.javaInterface This interface provides the declaration for java.lang.reflect.Method.invoke().
MethodAccessorGenerator.javaClass Generator for sun.reflect.MethodAccessor and sun.reflect.ConstructorAccessor objects using bytecodes to implement reflection.
MethodAccessorImpl.javaClass

Package-private implementation of the MethodAccessor interface which has access to all classes and all fields, regardless of language restrictions.

NativeConstructorAccessorImpl.javaClass
NativeMethodAccessorImpl.javaClass
Reflection.javaClass
ReflectionFactory.javaClass

The master factory for all reflective objects, both those in java.lang.reflect (Fields, Methods, Constructors) as well as their delegates (FieldAccessors, MethodAccessors, ConstructorAccessors).

The methods in this class are extremely unsafe and can cause subversion of both the language and the verifier.

SerializationConstructorAccessorImpl.javaClass

Java serialization (in java.io) expects to be able to instantiate a class and invoke a no-arg constructor of that class's first non-Serializable superclass.

SignatureIterator.javaClass
UnsafeBooleanFieldAccessorImpl.javaClass
UnsafeByteFieldAccessorImpl.javaClass
UnsafeCharacterFieldAccessorImpl.javaClass
UnsafeDoubleFieldAccessorImpl.javaClass
UnsafeFieldAccessorFactory.javaClass
UnsafeFieldAccessorImpl.javaClass Base class for sun.misc.Unsafe-based FieldAccessors.
UnsafeFloatFieldAccessorImpl.javaClass
UnsafeIntegerFieldAccessorImpl.javaClass
UnsafeLongFieldAccessorImpl.javaClass
UnsafeObjectFieldAccessorImpl.javaClass
UnsafeQualifiedBooleanFieldAccessorImpl.javaClass
UnsafeQualifiedByteFieldAccessorImpl.javaClass
UnsafeQualifiedCharacterFieldAccessorImpl.javaClass
UnsafeQualifiedDoubleFieldAccessorImpl.javaClass
UnsafeQualifiedFieldAccessorImpl.javaClass Base class for sun.misc.Unsafe-based FieldAccessors for fields with final or volatile qualifiers.
UnsafeQualifiedFloatFieldAccessorImpl.javaClass
UnsafeQualifiedIntegerFieldAccessorImpl.javaClass
UnsafeQualifiedLongFieldAccessorImpl.javaClass
UnsafeQualifiedObjectFieldAccessorImpl.javaClass
UnsafeQualifiedShortFieldAccessorImpl.javaClass
UnsafeQualifiedStaticBooleanFieldAccessorImpl.javaClass
UnsafeQualifiedStaticByteFieldAccessorImpl.javaClass
UnsafeQualifiedStaticCharacterFieldAccessorImpl.javaClass
UnsafeQualifiedStaticDoubleFieldAccessorImpl.javaClass
UnsafeQualifiedStaticFieldAccessorImpl.javaClass Base class for sun.misc.Unsafe-based FieldAccessors for final or volatile static fields.
UnsafeQualifiedStaticFloatFieldAccessorImpl.javaClass
UnsafeQualifiedStaticIntegerFieldAccessorImpl.javaClass
UnsafeQualifiedStaticLongFieldAccessorImpl.javaClass
UnsafeQualifiedStaticObjectFieldAccessorImpl.javaClass
UnsafeQualifiedStaticShortFieldAccessorImpl.javaClass
UnsafeShortFieldAccessorImpl.javaClass
UnsafeStaticBooleanFieldAccessorImpl.javaClass
UnsafeStaticByteFieldAccessorImpl.javaClass
UnsafeStaticCharacterFieldAccessorImpl.javaClass
UnsafeStaticDoubleFieldAccessorImpl.javaClass
UnsafeStaticFieldAccessorImpl.javaClass Base class for sun.misc.Unsafe-based FieldAccessors for static fields.
UnsafeStaticFloatFieldAccessorImpl.javaClass
UnsafeStaticIntegerFieldAccessorImpl.javaClass
UnsafeStaticLongFieldAccessorImpl.javaClass
UnsafeStaticObjectFieldAccessorImpl.javaClass
UnsafeStaticShortFieldAccessorImpl.javaClass
UTF8.javaClass It is necessary to use a "bootstrap" UTF-8 encoder for encoding constant pool entries because the character set converters rely on Class.newInstance().
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.