AccessController.doPrivileged and default methods

Adam Petcher adam.petcher at oracle.com
Wed Jul 5 20:01:48 UTC 2017


Very interesting. The exception originates in the VM, so I added the 
hotspot-dev list to the discussion. It looks like the VM either can't 
find the method, or it decides that it's not the right kind of method.

On 7/4/2017 7:57 AM, Michael Rasmussen wrote:
> Hi
>
> I was playing around with having an easy way to have doPrivileged call
> void methods via lambdas/method references, and noticed that if you
> use AccessController.doPrivileged(PrivilegedAction), and the run
> method is implemented as a default method, then you get the following
> exception: java.lang.InternalError: No run method
>
> I failed finding anywhere in the documentation stating this should not
> be supported, or a bug report about it, so writing/asking here.
>
> See example code below
>
> Kind regards
> Michael Rasmussen
>
>
> //----
>
> package com.test;
>
> import java.security.AccessController;
> import java.security.PrivilegedAction;
>
> public class Test {
>    interface VoidPrivilegedAction extends PrivilegedAction<Void> {
>      void perform();
>
>      @Override
>      default Void run() {
>        perform();
>        return null;
>      }
>    }
>
>    static void doPrivileged(VoidPrivilegedAction act) {
>      AccessController.doPrivileged(act);
>    }
>
>    public static void main(String[] args) throws Exception {
>      doPrivileged(() -> System.out.println(System.getProperty("java.home")));
>    }
> }
>
> //----
>
> Exception in thread "main" java.lang.InternalError: No run method
> at java.security.AccessController.doPrivileged(Native Method)
> at com.test.Test.doPrivileged(Test.java:18)
> at com.test.Test.main(Test.java:22)




More information about the security-dev mailing list