Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Possible more robust method reference resolution #25

Open
jroper opened this issue May 6, 2016 · 1 comment
Open

Possible more robust method reference resolution #25

jroper opened this issue May 6, 2016 · 1 comment

Comments

@jroper
Copy link

jroper commented May 6, 2016

This isn't really an issue, but I just thought I'd let you know because in my project I was resolving method references from lambda instances and had copied some code from here to do it, but then I found out about a more robust way that uses 100% specced features, and so it will never break if the JDK version changes. The catch is, it only works if the SAM extends Serializable, so it's not useful as a general purpose solution for method reference resolution, however it may be worth doing as a more robust (and maybe more performant) solution before falling back to the current approach of attempting to read the constant pool.

The JDK spec requires that any lambda that implements a Serializable SAM must implement the writeReplace method, and this must return an instance of java.lang.invoke.SerializedLambda (See here and search for writeReplace to see the spec). SerializedLambda gives access to the method signature. So to use this you only have to reflectively invoke writeReplace if it exists, and check that the return type is SerializedLambda, the rest is public API. For my particular use case this works really well because I control the API that the lambdas are passed to that I want to resolve, so I can ensure that all the SAMs it accepts are Serializable.

@jhalterman
Copy link
Owner

jhalterman commented May 6, 2016

Thanks for the heads up @jroper. I was aware of the Serializable solution, but dismissed it early on since it obviously only works with Serializable lambdas. I think you're right though, it would be a nice, and possibly more reliable, adaptive solution for lambdas that do happen to be Serializable.

I'd be interested to learn how the performance of serializing a lambda to obtain type arguments compares to the constant pool approach. I'll probably look into this sometime when I get a chance...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants