On this page
Class DefaultInternalObjectFilter
- java.lang.Object
-
- jdk.dynalink.linker.support.DefaultInternalObjectFilter
- All Implemented Interfaces:
-
MethodHandleTransformer
public class DefaultInternalObjectFilter
extends Object
implements MethodHandleTransformer
Default implementation for a DynamicLinkerFactory.setInternalObjectsFilter(MethodHandleTransformer)
that delegates to a pair of filtering method handles. It takes a method handle of Object(Object)
type for filtering parameter values and another one of the same type for filtering return values. It applies them as parameter and return value filters on method handles passed to its MethodHandleTransformer.transform(MethodHandle)
method, on those parameters and return values that are declared to have type Object
. Also handles method handles that support variable arity calls
with a last Object[]
parameter. You can broadly think of the parameter filter as being a wrapping method for exposing internal runtime objects wrapped into an adapter with some public interface, and the return value filter as being its inverse unwrapping method.
Constructors
Constructor | Description |
---|---|
DefaultInternalObjectFilter(MethodHandle parameterFilter, MethodHandle returnFilter) |
Creates a new filter. |
Methods
Methods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods declared in interface jdk.dynalink.linker.MethodHandleTransformer
transform
Constructors
DefaultInternalObjectFilter
public DefaultInternalObjectFilter(MethodHandle parameterFilter,
MethodHandle returnFilter)
Creates a new filter.
- Parameters:
parameterFilter
- the filter for method parameters. Must be of typeObject(Object)
, ornull
.returnFilter
- the filter for return values. Must be of typeObject(Object)
, ornull
.- Throws:
IllegalArgumentException
- if one or both filters are not of the expected type.
© 1993, 2020, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/11/docs/api/jdk.dynalink/jdk/dynalink/linker/support/DefaultInternalObjectFilter.html