|
|
|||||||||||||||
Raw Native Interface EnhancementsThe Raw Native Interface (RNI) has been extended as a result of feedback and performance enhancements. The enhancements made to RNI are in the following four primary areas:
Reflection APIsA number of native reflection APIs have been added to improve accessibility of an object's methods and fields. Using these APIs insulates DLLs from changes to the underlying object model or changes in the class hierarchy. Users of RNI should use the new write barrier support functions to set an object field inside another object. These APIs are GCSetObjectReferenceForObject and GCSetObjectReferenceForHandle. Also, Field_SetValue, already in RevE (the VM version in SDK 1.5), will support the write barrier. RNI developers are encouraged to use the "Field_" reflection APIs added in RevE because these APIs abstract the object layout. Since these APIs are available on RevE, it should be possible to make a single DLL that will work on RevE and Internet Explorer 4.0. Future Garbage Collection Performance EnhancementsTo support future garbage collection enhancements, the internal object model was changed to enable more effective garbage collection, and enable future write-barrier support in the garbage collector (see Details of the New GC Model below for details). To insulate code from these or future changes to the object model, developers are encouraged to use the reflection APIs described previously. A Java object may still be accessed as a C structure, but code will need to be recompiled using the updated msjavah tool provided in this SDK. RNIGetCompatibleVersion RequirementDue to the object model changes described previously, many RNI DLLs designed for earlier versions of the Microsoft virtual machine need to be recompiled. To identify whether an RNI DLL is compatible with the current version of the VM, it will call the RNI DLL's RNIGetCompatibleVersion export. RNI DLLs that do not export this API will not be loaded by the current VM. RNI Invocation APIsThe virtual machine supports two new invocation APIs, PrepareThreadForJava and UnprepareThreadForJava, which can be used to execute RNI APIs on any Win32 thread. An invocation sample is provided in this SDK. Details of the New GC ModelThe ordering of values laid out within objects has changed. Previously, if you had a class A with a string, an int and a string, followed by class B with an int and a string, the object layout in memory is as follows: From A string (can be garbage collected) int (atomic non-collectable) string From B int string The new Garbage Collection model reduces the number of GC roots (in this example there are three). The new object layout coalesces collectable objects within a class, and alternates object location from beginning to end, to coalesce between classes. The object layout for this would be as follows: From A int (atomic non-collectable) string (can be garbage collected) string From B string int This gives just one GC root rather than three. Because of this model change, all code that uses RNI needs to be rebuilt and recompiled with the new msjavah tool. Existing code that hasn't been recompiled will not run on existing VMs. Also, existing code that relies on accessing strings directly, rather than using a provided API, will not function.
|
© 1998 Microsoft Corporation. All rights reserved. Terms of use. |