public abstract class MethodHandle extends Object
 Every method handle reports its type via the type accessor.
 This type descriptor is a MethodType object,
 whose structure is a series of classes, one of which is
 the return type of the method (or void.class if none).
 
A method handle's type controls the types of invocations it accepts, and the kinds of transformations that apply to it.
 A method handle contains a pair of special invoker methods
 called invokeExact and invokeGeneric.
 Both invoker methods provide direct access to the method handle's
 underlying method, constructor, field, or other operation,
 as modified by transformations of arguments and return values.
 Both invokers accept calls which exactly match the method handle's own type.
 The invokeGeneric invoker also accepts a range of other call types.
 
Method handles are immutable and have no visible state. Of course, they can be bound to underlying methods or data which exhibit state. With respect to the Java Memory Model, any method handle will behave as if all of its (internal) fields are final variables. This means that any method handle made visible to the application will always be fully formed. This is true even if the method handle is published through a shared variable in a data race.
 Method handles cannot be subclassed by the user.
 Implementations may (or may not) create internal subclasses of MethodHandle
 which may be visible via the Object.getClass
 operation.  The programmer should not draw conclusions about a method handle
 from its specific class, as the method handle class hierarchy (if any)
 may change from time to time or across implementations from different vendors.
 
invokeExact or invokeGeneric
 can invoke a method handle from Java source code.
 From the viewpoint of source code, these methods can take any arguments
 and their result can be cast to any return type.
 Formally this is accomplished by giving the invoker methods
 Object return types and variable-arity Object arguments,
 but they have an additional quality called signature polymorphism
 which connects this freedom of invocation directly to the JVM execution stack.
 
 As is usual with virtual methods, source-level calls to invokeExact
 and invokeGeneric compile to an invokevirtual instruction.
 More unusually, the compiler must record the actual argument types,
 and may not perform method invocation conversions on the arguments.
 Instead, it must push them on the stack according to their own unconverted types.
 The method handle object itself is pushed on the stack before the arguments.
 The compiler then calls the method handle with a type descriptor which
 describes the argument and return types.
 
 To issue a complete type descriptor, the compiler must also determine
 the return type.  This is based on a cast on the method invocation expression,
 if there is one, or else Object if the invocation is an expression
 or else void if the invocation is a statement.
 The cast may be to a primitive type (but not void).
 
 As a corner case, an uncasted null argument is given
 a type descriptor of java.lang.Void.
 The ambiguity with the type Void is harmless, since there are no references of type
 Void except the null reference.
 
invokevirtual instruction is executed
 it is linked, by symbolically resolving the names in the instruction
 and verifying that the method call is statically legal.
 This is true of calls to invokeExact and invokeGeneric.
 In this case, the type descriptor emitted by the compiler is checked for
 correct syntax and names it contains are resolved.
 Thus, an invokevirtual instruction which invokes
 a method handle will always link, as long
 as the type descriptor is syntactically well-formed
 and the types exist.
 
 When the invokevirtual is executed after linking,
 the receiving method handle's type is first checked by the JVM
 to ensure that it matches the descriptor.
 If the type match fails, it means that the method which the
 caller is invoking is not present on the individual
 method handle being invoked.
 
 In the case of invokeExact, the type descriptor of the invocation
 (after resolving symbolic type names) must exactly match the method type
 of the receiving method handle.
 In the case of invokeGeneric, the resolved type descriptor
 must be a valid argument to the receiver's asType method.
 Thus, invokeGeneric is more permissive than invokeExact.
 
 After type matching, a call to invokeExact directly
 and immediately invoke the method handle's underlying method
 (or other behavior, as the case may be).
 
 A call to invokeGeneric works the same as a call to
 invokeExact, if the type descriptor specified by the caller
 exactly matches the method handle's own type.
 If there is a type mismatch, invokeGeneric attempts
 to adjust the type of the receiving method handle,
 as if by a call to asType,
 to obtain an exactly invokable method handle M2.
 This allows a more powerful negotiation of method type
 between caller and callee.
 
 (Note: The adjusted method handle M2 is not directly observable,
 and implementations are therefore not required to materialize it.)
 
WrongMethodTypeException,
 either directly (in the case of invokeExact) or indirectly as if
 by a failed call to asType (in the case of invokeGeneric).
 
 Thus, a method type mismatch which might show up as a linkage error
 in a statically typed program can show up as
 a dynamic WrongMethodTypeException
 in a program which uses method handles.
 
 Because method types contain "live" Class objects,
 method type matching takes into account both types names and class loaders.
 Thus, even if a method handle M is created in one
 class loader L1 and used in another L2,
 method handle calls are type-safe, because the caller's type
 descriptor, as resolved in L2,
 is matched against the original callee method's type descriptor,
 as resolved in L1.
 The resolution in L1 happens when M is created
 and its type is assigned, while the resolution in L2 happens
 when the invokevirtual instruction is linked.
 
Apart from the checking of type descriptors, a method handle's capability to call its underlying method is unrestricted. If a method handle is formed on a non-public method by a class that has access to that method, the resulting handle can be used in any place by any caller who receives a reference to it.
 Unlike with the Core Reflection API, where access is checked every time
 a reflective method is invoked,
 method handle access checking is performed
 when the method handle is created.
 In the case of ldc (see below), access checking is performed as part of linking
 the constant pool entry underlying the constant method handle.
 
Thus, handles to non-public methods, or to methods in non-public classes, should generally be kept secret. They should not be passed to untrusted code unless their use from the untrusted code would be harmless.
MethodHandles.Lookup
 For example, a static method handle can be obtained
 from Lookup.findStatic.
 There are also conversion methods from Core Reflection API objects,
 such as Lookup.unreflect.
 
 Like classes and strings, method handles that correspond to accessible
 fields, methods, and constructors can also be represented directly
 in a class file's constant pool as constants to be loaded by ldc bytecodes.
 A new type of constant pool entry, CONSTANT_MethodHandle,
 refers directly to an associated CONSTANT_Methodref,
 CONSTANT_InterfaceMethodref, or CONSTANT_Fieldref
 constant pool entry.
 (For more details on method handle constants,
 see the package summary.)
 
 Method handles produced by lookups or constant loads from methods or
 constructors with the variable arity modifier bit (0x0080)
 have a corresponding variable arity, as if they were defined with
 the help of asVarargsCollector.
 
 A method reference may refer either to a static or non-static method.
 In the non-static case, the method handle type includes an explicit
 receiver argument, prepended before any other arguments.
 In the method handle's type, the initial receiver argument is typed
 according to the class under which the method was initially requested.
 (E.g., if a non-static method handle is obtained via ldc,
 the type of the receiver is the class named in the constant pool entry.)
 
When a method handle to a virtual method is invoked, the method is always looked up in the receiver (that is, the first argument).
 A non-virtual method handle to a specific virtual method implementation
 can also be created.  These do not perform virtual lookup based on
 receiver type.  Such a method handle simulates the effect of
 an invokespecial instruction to the same method.
 
Object x, y; String s; int i;
MethodType mt; MethodHandle mh;
MethodHandles.Lookup lookup = MethodHandles.lookup();
// mt is (char,char)String
mt = MethodType.methodType(String.class, char.class, char.class);
mh = lookup.findVirtual(String.class, "replace", mt);
s = (String) mh.invokeExact("daddy",'d','n');
// invokeExact(Ljava/lang/String;CC)Ljava/lang/String;
assert(s.equals("nanny"));
// weakly typed invocation (using MHs.invoke)
s = (String) mh.invokeWithArguments("sappy", 'p', 'v');
assert(s.equals("savvy"));
// mt is (Object[])List
mt = MethodType.methodType(java.util.List.class, Object[].class);
mh = lookup.findStatic(java.util.Arrays.class, "asList", mt);
assert(mh.isVarargsCollector());
x = mh.invokeGeneric("one", "two");
// invokeGeneric(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
assert(x.equals(java.util.Arrays.asList("one","two")));
// mt is (Object,Object,Object)Object
mt = MethodType.genericMethodType(3);
mh = mh.asType(mt);
x = mh.invokeExact((Object)1, (Object)2, (Object)3);
// invokeExact(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
assert(x.equals(java.util.Arrays.asList(1,2,3)));
// mt is int()
mt = MethodType.methodType(int.class);
mh = lookup.findVirtual(java.util.List.class, "size", mt);
i = (int) mh.invokeExact(java.util.Arrays.asList(1,2,3));
// invokeExact(Ljava/util/List;)I
assert(i == 3);
mt = MethodType.methodType(void.class, String.class);
mh = lookup.findVirtual(java.io.PrintStream.class, "println", mt);
mh.invokeExact(System.out, "Hello, world.");
// invokeExact(Ljava/io/PrintStream;Ljava/lang/String;)V
 invokeExact or invokeGeneric
 generates a single invokevirtual instruction with
 the type descriptor indicated in the following comment.
 invokeExact and invokeGeneric are declared
 to throw Throwable,
 which is to say that there is no static restriction on what a method handle
 can throw.  Since the JVM does not distinguish between checked
 and unchecked exceptions (other than by their class, of course),
 there is no particular effect on bytecode shape from ascribing
 checked exceptions to method handle invocations.  But in Java source
 code, methods which perform method handle calls must either explicitly
 throw java.lang.Throwable Throwable, or else must catch all
 throwables locally, rethrowing only those which are legal in the context,
 and wrapping ones which are illegal.
 invokeExact and invokeGeneric
 is referenced by the term signature polymorphism.
 A signature polymorphic method is one which can operate with
 any of a wide range of call signatures and return types.
 In order to make this work, both the Java compiler and the JVM must
 give special treatment to signature polymorphic methods.
 
 In source code, a call to a signature polymorphic method will
 compile, regardless of the requested type descriptor.
 As usual, the Java compiler emits an invokevirtual
 instruction with the given type descriptor against the named method.
 The unusual part is that the type descriptor is derived from
 the actual argument and return types, not from the method declaration.
 
When the JVM processes bytecode containing signature polymorphic calls, it will successfully link any such call, regardless of its type descriptor. (In order to retain type safety, the JVM will guard such calls with suitable dynamic type checks, as described elsewhere.)
Bytecode generators, including the compiler back end, are required to emit untransformed type descriptors for these methods. Tools which determine symbolic linkage are required to accept such untransformed descriptors, without reporting linkage errors.
 For the sake of tools (but not as a programming API), the signature polymorphic
 methods are marked with a private yet standard annotation,
 @java.lang.invoke.MethodHandle.PolymorphicSignature.
 The annotation's retention is RUNTIME, so that all tools can see it.
 
The following methods (and no others) are signature polymorphic:
A signature polymorphic method will be declared with the following properties:
Object....
 Object.
 java.lang.invoke package.
 
 When a call to a signature polymorphic method is compiled, the associated linkage information for
 its arguments is not array of Object (as for other similar varargs methods)
 but rather the erasure of the static types of all the arguments.
 
 In an argument position of a method invocation on a signature polymorphic method,
 a null literal has type java.lang.Void, unless cast to a reference type.
 (Note: This typing rule allows the null type to have its own encoding in linkage information
 distinct from other types.
 
The linkage information for the return type is derived from a context-dependent target typing convention. The return type for a signature polymorphic method invocation is determined as follows:
void.
 Object.
 Object expression.)
 The linkage information for argument and return types is stored in the descriptor for the compiled (bytecode) call site. As for any invocation instruction, the arguments and return value will be passed directly on the JVM stack, in accordance with the descriptor, and without implicit boxing or unboxing.
Lookup API,
 any class member represented by a Core Reflection API object
 can be converted to a behaviorally equivalent method handle.
 For example, a reflective Method can
 be converted to a method handle using
 Lookup.unreflect.
 The resulting method handles generally provide more direct and efficient
 access to the underlying class members.
 
 As a special case,
 when the Core Reflection API is used to view the signature polymorphic
 methods invokeExact or invokeGeneric in this class,
 they appear as single, non-polymorphic native methods.
 Calls to these native methods do not result in method handle invocations.
 Since invokevirtual instructions can natively
 invoke method handles under any type descriptor, this reflective view conflicts
 with the normal presentation via bytecodes.
 Thus, these two native methods, as viewed by
 Class.getDeclaredMethod,
 are placeholders only.
 If invoked via Method.invoke,
 they will throw UnsupportedOperationException.
 
 In order to obtain an invoker method for a particular type descriptor,
 use MethodHandles.exactInvoker,
 or MethodHandles.genericInvoker.
 The Lookup.findVirtual
 API is also able to return a method handle
 to call invokeExact or invokeGeneric,
 for any specified type descriptor .
 
invokevirtual instruction.
 Method handles do not represent their function-like types in terms of Java parameterized (generic) types, because there are three mismatches between function-like types and parameterized Java types.
MethodType, 
MethodHandles| Modifier and Type | Method and Description | 
|---|---|
| MethodHandle | asCollector(Class<?> arrayType,
           int arrayLength)Makes an adapter which accepts a given number of trailing
 positional arguments and collects them into an array argument. | 
| MethodHandle | asSpreader(Class<?> arrayType,
          int arrayLength)Makes an adapter which accepts a trailing array argument
 and spreads its elements as positional arguments. | 
| MethodHandle | asType(MethodType newType)Produces an adapter method handle which adapts the type of the
 current method handle to a new type. | 
| MethodHandle | asVarargsCollector(Class<?> arrayType)Makes a variable arity adapter which is able to accept
 any number of trailing positional arguments and collect them
 into an array argument. | 
| MethodHandle | bindTo(Object x)Binds a value  xto the first argument of a method handle, without invoking it. | 
| Object | invokeExact(Object... args)Invokes the method handle, allowing any caller type descriptor, but requiring an exact type match. | 
| Object | invokeGeneric(Object... args)Invokes the method handle, allowing any caller type descriptor,
 and optionally performing conversions on arguments and return values. | 
| Object | invokeWithArguments(List<?> arguments)Performs a varargs invocation, passing the arguments in the given array
 to the method handle, as if via  invokeGenericfrom a call site
 which mentions only the typeObject, and whose arity is the length
 of the argument array. | 
| Object | invokeWithArguments(Object... arguments)Performs a varargs invocation, passing the arguments in the given array
 to the method handle, as if via  invokeGenericfrom a call site
 which mentions only the typeObject, and whose arity is the length
 of the argument array. | 
| boolean | isVarargsCollector()Determines if this method handle
 supports variable arity calls. | 
| String | toString()Returns a string representation of the method handle,
 starting with the string  "MethodHandle"and
 ending with the string representation of the method handle's type. | 
| MethodType | type()Reports the type of this method handle. | 
public MethodType type()
invokeExact must exactly match this type.public final Object invokeExact(Object... args) throws Throwable
invokeExact must
 exactly match this method handle's type.
 No conversions are allowed on arguments or return values.
 
 When this method is observed via the Core Reflection API,
 it will appear as a single native method, taking an object array and returning an object.
 If this native method is invoked directly via
 Method.invoke, via JNI,
 or indirectly via Lookup.unreflect,
 it will throw an UnsupportedOperationException.
WrongMethodTypeException - if the target's type is not identical with the caller's type descriptorThrowable - anything thrown by the underlying method propagates unchanged through the method handle callpublic final Object invokeGeneric(Object... args) throws Throwable
 If the call site type descriptor exactly matches this method handle's type,
 the call proceeds as if by invokeExact.
 
 Otherwise, the call proceeds as if this method handle were first
 adjusted by calling asType to adjust this method handle
 to the required type, and then the call proceeds as if by
 invokeExact on the adjusted method handle.
 
 There is no guarantee that the asType call is actually made.
 If the JVM can predict the results of making the call, it may perform
 adaptations directly on the caller's arguments,
 and call the target method handle according to its own exact type.
 
 The type descriptor at the call site of invokeGeneric must
 be a valid argument to the receivers asType method.
 In particular, the caller must specify the same argument arity
 as the callee's type,
 if the callee is not a variable arity collector.
 
 When this method is observed via the Core Reflection API,
 it will appear as a single native method, taking an object array and returning an object.
 If this native method is invoked directly via
 Method.invoke, via JNI,
 or indirectly via Lookup.unreflect,
 it will throw an UnsupportedOperationException.
WrongMethodTypeException - if the target's type cannot be adjusted to the caller's type descriptorClassCastException - if the target's type can be adjusted to the caller, but a reference cast failsThrowable - anything thrown by the underlying method propagates unchanged through the method handle callpublic Object invokeWithArguments(Object... arguments) throws Throwable
invokeGeneric from a call site
 which mentions only the type Object, and whose arity is the length
 of the argument array.
 Specifically, execution proceeds as if by the following steps, although the methods are not guaranteed to be called if the JVM can predict their effects.
N.
     For a null reference, N=0. TN of N arguments as
     as TN=MethodType.genericMethodType(N).MH0 to the
     required type, as MH1 = MH0.asType(TN). N separate arguments A0, .... Object reference. 
 Because of the action of the asType step, the following argument
 conversions are applied as necessary:
 
The result returned by the call is boxed if it is a primitive, or forced to null if the return type is void.
This call is equivalent to the following code:
MethodHandle invoker = MethodHandles.spreadInvoker(this.type(), 0); Object result = invoker.invokeExact(this, arguments);
 Unlike the signature polymorphic methods invokeExact and invokeGeneric,
 invokeWithArguments can be accessed normally via the Core Reflection API and JNI.
 It can therefore be used as a bridge between native or reflective code and method handles.
arguments - the arguments to pass to the targetClassCastException - if an argument cannot be converted by reference castingWrongMethodTypeException - if the target's type cannot be adjusted to take the given number of Object argumentsThrowable - anything thrown by the target method invocationMethodHandles.spreadInvoker(java.lang.invoke.MethodType, int)public Object invokeWithArguments(List<?> arguments) throws Throwable
invokeGeneric from a call site
 which mentions only the type Object, and whose arity is the length
 of the argument array.
 This method is also equivalent to the following code:
invokeWithArguments(arguments.toArray())
arguments - the arguments to pass to the targetClassCastException - if an argument cannot be converted by reference castingWrongMethodTypeException - if the target's type cannot be adjusted to take the given number of Object argumentsThrowable - anything thrown by the target method invocationpublic MethodHandle asType(MethodType newType)
 If the original type and new type are equal, returns this.
 
 This method provides the crucial behavioral difference between
 invokeExact and invokeGeneric.  The two methods
 perform the same steps when the caller's type descriptor is identical
 with the callee's, but when the types differ, invokeGeneric
 also calls asType (or some internal equivalent) in order
 to match up the caller's and callee's types.
 
 This method is equivalent to convertArguments,
 except for variable arity method handles produced by asVarargsCollector.
newType - the expected type of the new method handlethis after performing
           any necessary argument conversions, and arranges for any
           necessary return value conversionsWrongMethodTypeException - if the conversion cannot be madeMethodHandles.convertArguments(java.lang.invoke.MethodHandle, java.lang.invoke.MethodType)public MethodHandle asSpreader(Class<?> arrayType, int arrayLength)
arrayLength parameters of the target's type are replaced
 by a single array parameter of type arrayType.
 
 If the array element type differs from any of the corresponding
 argument types on the original target,
 the original target is adapted to take the array elements directly,
 as if by a call to asType.
 
When called, the adapter replaces a trailing array argument by the array's elements, each as its own argument to the target. (The order of the arguments is preserved.) They are converted pairwise by casting and/or unboxing to the types of the trailing parameters of the target. Finally the target is called. What the target eventually returns is returned unchanged by the adapter.
Before calling the target, the adapter verifies that the array contains exactly enough elements to provide a correct argument count to the target method handle. (The array may also be null when zero elements are required.)
arrayType - usually Object[], the type of the array argument from which to extract the spread argumentsarrayLength - the number of arguments to spread from an incoming array argumentIllegalArgumentException - if arrayType is not an array typeIllegalArgumentException - if target does not have at least
         arrayLength parameter typesWrongMethodTypeException - if the implied asType call failsasCollector(java.lang.Class>, int)public MethodHandle asCollector(Class<?> arrayType, int arrayLength)
arrayType) is replaced by
 arrayLength parameters whose type is element type of arrayType.
 
 If the array type differs from the final argument type on the original target,
 the original target is adapted to take the array type directly,
 as if by a call to asType.
 
 When called, the adapter replaces its trailing arrayLength
 arguments by a single new array of type arrayType, whose elements
 comprise (in order) the replaced arguments.
 Finally the target is called.
 What the target eventually returns is returned unchanged by the adapter.
 
 (The array may also be a shared constant when arrayLength is zero.)
 
 (Note: The arrayType is often identical to the last
 parameter type of the original target.
 It is an explicit argument for symmetry with asSpreader, and also
 to allow the target to use a simple Object as its last parameter type.)
 
 In order to create a collecting adapter which is not restricted to a particular
 number of collected arguments, use asVarargsCollector instead.
arrayType - often Object[], the type of the array argument which will collect the argumentsarrayLength - the number of arguments to collect into a new array argumentIllegalArgumentException - if arrayType is not an array type
         or arrayType is not assignable to this method handle's trailing parameter type,
         or arrayLength is not a legal array sizeWrongMethodTypeException - if the implied asType call failsasSpreader(java.lang.Class>, int), 
asVarargsCollector(java.lang.Class>)public MethodHandle asVarargsCollector(Class<?> arrayType)
 The type and behavior of the adapter will be the same as
 the type and behavior of the target, except that certain
 invokeGeneric and asType requests can lead to
 trailing positional arguments being collected into target's
 trailing parameter.
 Also, the last parameter type of the adapter will be
 arrayType, even if the target has a different
 last parameter type.
 
 When called with invokeExact, the adapter invokes
 the target with no argument changes.
 (Note: This behavior is different from a
 fixed arity collector,
 since it accepts a whole array of indeterminate length,
 rather than a fixed number of arguments.)
 
 When called with invokeGeneric, if the caller
 type is the same as the adapter, the adapter invokes the target as with
 invokeExact.
 (This is the normal behavior for invokeGeneric when types match.)
 
 Otherwise, if the caller and adapter arity are the same, and the
 trailing parameter type of the caller is a reference type identical to
 or assignable to the trailing parameter type of the adapter,
 the arguments and return values are converted pairwise,
 as if by convertArguments.
 (This is also normal behavior for invokeGeneric in such a case.)
 
 Otherwise, the arities differ, or the adapter's trailing parameter
 type is not assignable from the corresponding caller type.
 In this case, the adapter replaces all trailing arguments from
 the original trailing argument position onward, by
 a new array of type arrayType, whose elements
 comprise (in order) the replaced arguments.
 
 The caller type must provides as least enough arguments,
 and of the correct type, to satisfy the target's requirement for
 positional arguments before the trailing array argument.
 Thus, the caller must supply, at a minimum, N-1 arguments,
 where N is the arity of the target.
 Also, there must exist conversions from the incoming arguments
 to the target's arguments.
 As with other uses of invokeGeneric, if these basic
 requirements are not fulfilled, a WrongMethodTypeException
 may be thrown.
 
In all cases, what the target eventually returns is returned unchanged by the adapter.
 In the final case, it is exactly as if the target method handle were
 temporarily adapted with a fixed arity collector
 to the arity required by the caller type.
 (As with asCollector, if the array length is zero,
 a shared constant may be used instead of a new array.
 If the implied call to asCollector would throw
 an IllegalArgumentException or WrongMethodTypeException,
 the call to the variable arity adapter must throw
 WrongMethodTypeException.)
 
 The behavior of asType is also specialized for
 variable arity adapters, to maintain the invariant that
 invokeGeneric is always equivalent to an asType
 call to adjust the target type, followed by invokeExact.
 Therefore, a variable arity adapter responds
 to an asType request by building a fixed arity collector,
 if and only if the adapter and requested type differ either
 in arity or trailing argument type.
 The resulting fixed arity collector has its type further adjusted
 (if necessary) to the requested type by pairwise conversion,
 as if by another application of asType.
 
 When a method handle is obtained by executing an ldc instruction
 of a CONSTANT_MethodHandle constant, and the target method is marked
 as a variable arity method (with the modifier bit 0x0080),
 the method handle will accept multiple arities, as if the method handle
 constant were created by means of a call to asVarargsCollector.
 
 In order to create a collecting adapter which collects a predetermined
 number of arguments, and whose type reflects this predetermined number,
 use asCollector instead.
 
 No method handle transformations produce new method handles with
 variable arity, unless they are documented as doing so.
 Therefore, besides asVarargsCollector,
 all methods in MethodHandle and MethodHandles
 will return a method handle with fixed arity,
 except in the cases where they are specified to return their original
 operand (e.g., asType of the method handle's own type).
 
 Calling asVarargsCollector on a method handle which is already
 of variable arity will produce a method handle with the same type and behavior.
 It may (or may not) return the original variable arity method handle.
 
Here is an example, of a list-making variable arity method handle:
MethodHandle asList = publicLookup()
  .findStatic(Arrays.class, "asList", methodType(List.class, Object[].class))
  .asVarargsCollector(Object[].class);
assertEquals("[]", asList.invokeGeneric().toString());
assertEquals("[1]", asList.invokeGeneric(1).toString());
assertEquals("[two, too]", asList.invokeGeneric("two", "too").toString());
Object[] argv = { "three", "thee", "tee" };
assertEquals("[three, thee, tee]", asList.invokeGeneric(argv).toString());
List ls = (List) asList.invokeGeneric((Object)argv);
assertEquals(1, ls.size());
assertEquals("[three, thee, tee]", Arrays.toString((Object[])ls.get(0)));
 Discussion: These rules are designed as a dynamically-typed variation of the Java rules for variable arity methods. In both cases, callers to a variable arity method or method handle can either pass zero or more positional arguments, or else pass pre-collected arrays of any length. Users should be aware of the special role of the final argument, and of the effect of a type match on that final argument, which determines whether or not a single trailing argument is interpreted as a whole array or a single element of an array to be collected. Note that the dynamic type of the trailing argument has no effect on this decision, only a comparison between the static type descriptor of the call site and the type of the method handle.)
As a result of the previously stated rules, the variable arity behavior of a method handle may be suppressed, by binding it to the exact invoker of its own type, as follows:
MethodHandle vamh = publicLookup()
  .findStatic(Arrays.class, "asList", methodType(List.class, Object[].class))
  .asVarargsCollector(Object[].class);
MethodHandle mh = MethodHandles.exactInvoker(vamh.type()).bindTo(vamh);
assert(vamh.type().equals(mh.type()));
assertEquals("[1, 2, 3]", vamh.invokeGeneric(1,2,3).toString());
boolean failed = false;
try { mh.invokeGeneric(1,2,3); }
catch (WrongMethodTypeException ex) { failed = true; }
assert(failed);
 arrayType - often Object[], the type of the array argument which will collect the argumentsIllegalArgumentException - if arrayType is not an array type
         or arrayType is not assignable to this method handle's trailing parameter typeasCollector(java.lang.Class>, int), 
isVarargsCollector()public boolean isVarargsCollector()
ldc instruction of a CONSTANT_MethodHandle
     which resolves to a variable arity Java method or constructor
 invokeGeneric callsasVarargsCollector(java.lang.Class>)public MethodHandle bindTo(Object x)
x to the first argument of a method handle, without invoking it.
 The new method handle adapts, as its target,
 the current method handle by binding it to the given argument.
 The type of the bound handle will be
 the same as the type of the target, except that a single leading
 reference parameter will be omitted.
 
 When called, the bound handle inserts the given value x
 as a new leading argument to the target.  The other arguments are
 also passed unchanged.
 What the target eventually returns is returned unchanged by the bound handle.
 
 The reference x must be convertible to the first parameter
 type of the target.
 
(Note: Because method handles are immutable, the target method handle retains its original type and behavior.)
x - the value to bind to the first argument of the targetIllegalArgumentException - if the target does not have a
         leading parameter type that is a reference typeClassCastException - if x cannot be converted
         to the leading parameter type of the targetMethodHandles.insertArguments(java.lang.invoke.MethodHandle, int, java.lang.Object...)public String toString()
"MethodHandle" and
 ending with the string representation of the method handle's type.
 In other words, this method returns a string equal to the value of:
 "MethodHandle" + type().toString()
(Note: Future releases of this API may add further information to the string representation. Therefore, the present syntax should not be parsed by applications.)
 Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2011, Oracle and/or its affiliates.  All rights reserved. 
DRAFT ea-b138