Class ClassCache

  • All Implemented Interfaces:
    java.io.Serializable

    public class ClassCache
    extends java.lang.Object
    implements java.io.Serializable
    Cache of generated classes and data structures to access Java runtime from JavaScript.
    Since:
    Rhino 1.5 Release 5
    See Also:
    Serialized Form
    • Constructor Detail

      • ClassCache

        public ClassCache()
    • Method Detail

      • associate

        public boolean associate​(ScriptableObject topScope)
        Associate ClassCache object with the given top-level scope. The ClassCache object can only be associated with the given scope once.
        Parameters:
        topScope - scope to associate this ClassCache object with.
        Returns:
        true if no previous ClassCache objects were embedded into the scope and this ClassCache were successfully associated or false otherwise.
        See Also:
        get(Scriptable scope)
      • clearCaches

        public void clearCaches()
        Empty caches of generated Java classes and Java reflection information.
      • isCachingEnabled

        public final boolean isCachingEnabled()
        Check if generated Java classes and Java reflection information is cached.
      • setCachingEnabled

        public void setCachingEnabled​(boolean enabled)
        Set whether to cache some values.

        By default, the engine will cache the results of Class.getMethods() and similar calls. This can speed execution dramatically, but increases the memory footprint. Also, with caching enabled, references may be held to objects past the lifetime of any real usage.

        If caching is enabled and this method is called with a false argument, the caches will be emptied.

        Caching is enabled by default.

        Parameters:
        enabled - if true, caching is enabled
        See Also:
        clearCaches()
      • setInvokerOptimizationEnabled

        @Deprecated
        public void setInvokerOptimizationEnabled​(boolean enabled)
        Deprecated.
        The method does nothing. Invoker optimization is no longer used by Rhino. On modern JDK like 1.4 or 1.5 the disadvantages of the optimization like increased memory usage or longer initialization time overweight small speed increase that can be gained using generated proxy class to replace reflection.
      • newClassSerialNumber

        public final int newClassSerialNumber()
        Internal engine method to return serial number for generated classes to ensure name uniqueness.