{"id":288582,"date":"2018-08-27T16:50:06","date_gmt":"2018-08-27T12:50:06","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=288582"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=288582","title":{"rendered":"\u041a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u043e\u0435 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u0435 \u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u043a default \u043c\u0435\u0442\u043e\u0434\u0430\u043c \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e \u0432 Java 8, 9, 10"},"content":{"rendered":"\n<div data-io-article-url=\"https:\/\/habr.com\/company\/haulmont\/blog\/421413\/\" class=\"post__text post__text-html js-mediator-article\"><i>\u041f\u0440\u0438\u043c\u0435\u0447\u0430\u043d\u0438\u0435 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0447\u0438\u043a\u0430: \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u0435 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430 CUBA \u043f\u043e\u0440\u043e\u0436\u0434\u0430\u0435\u0442 \u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e R&amp;D \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432. \u0412 \u0445\u043e\u0434\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0442\u0430\u043a\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0432\u044b\u044f\u0441\u043d\u0438\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0442\u044c default \u043c\u0435\u0442\u043e\u0434\u044b \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0438\u0437 \u043f\u0440\u043e\u043a\u0441\u0438 \u043a\u043b\u0430\u0441\u0441\u043e\u0432. \u041d\u0430\u0442\u043a\u043d\u0443\u043b\u0438\u0441\u044c \u043d\u0430 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043b\u0435\u0437\u043d\u0443\u044e \u0441\u0442\u0430\u0442\u044c\u044e, \u043c\u043d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u043e\u043f\u044b\u0442, \u0438\u0437\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439 \u0432 \u043d\u0435\u0439, \u0431\u0443\u0434\u0435\u0442, \u043a\u0430\u043a \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0435\u043d, \u043a\u0430\u043a \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u2014 \u043f\u043e\u043b\u0435\u0437\u0435\u043d \u0448\u0438\u0440\u043e\u043a\u043e\u043c\u0443 \u043a\u0440\u0443\u0433\u0443 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432. <\/i><\/p>\n<p>  \u041a\u043e\u0433\u0434\u0430 \u0434\u0435\u043b\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u043a default \u043c\u0435\u0442\u043e\u0434\u0430\u043c \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0432 Java \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e, \u0433\u0443\u0433\u043b\u0435\u043d\u0438\u0435 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, <a href=\"https:\/\/stackoverflow.com\/a\/37816247\/521799\">\u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043d\u0430 StackOverflow<\/a> \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u044b\u0445 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f\u0445 \u0438 \u043d\u0435 \u043d\u0430 \u0432\u0441\u0435\u0445 \u0432\u0435\u0440\u0441\u0438\u044f\u0445 Java.<\/p>\n<p>  \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u044b \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u043a \u0432\u044b\u0437\u043e\u0432\u0430\u043c default \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e, \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043d\u0443\u0436\u043d\u043e, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043f\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u043f\u0440\u043e\u043a\u0441\u0438-\u043a\u043b\u0430\u0441\u0441\u043e\u0432.<br \/>  <b>TL;DR<\/b> \u0415\u0441\u043b\u0438 \u0432\u0430\u043c \u043d\u0435 \u0442\u0435\u0440\u043f\u0438\u0442\u0441\u044f, \u0442\u043e \u0432\u0441\u0435 \u0441\u043f\u043e\u0441\u043e\u0431\u044b \u0432\u044b\u0437\u043e\u0432\u0430 default \u043c\u0435\u0442\u043e\u0434\u043e\u0432, \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0435 \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435, \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b <a href=\"https:\/\/gist.github.com\/lukaseder\/f47f5a0d156bf7b80b67da9d14422d4a\">\u043f\u043e \u044d\u0442\u043e\u0439 \u0441\u0441\u044b\u043b\u043a\u0435<\/a>, \u0430 \u0442\u0430\u043a\u0436\u0435 \u044d\u0442\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0443\u0436\u0435 \u0440\u0435\u0448\u0435\u043d\u0430 \u0432 \u043d\u0430\u0448\u0435\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 <a href=\"https:\/\/github.com\/jOOQ\/jOOR\">jOOR<\/a>. <br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h3>\u041f\u0440\u043e\u043a\u0441\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0441 default \u043c\u0435\u0442\u043e\u0434\u0430\u043c\u0438<\/h3>\n<p>  \u041f\u043e\u043b\u0435\u0437\u043d\u044b\u0439 API java.lang.reflect.Proxy \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0434\u0430\u0432\u043d\u043e, \u0441 \u0435\u0433\u043e \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0434\u0435\u043b\u0430\u0442\u044c \u043a\u043b\u0435\u0432\u044b\u0435 \u0448\u0442\u0443\u043a\u0438, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440:  <\/p>\n<pre><code class=\"java\">import java.lang.reflect.Proxy;   public class ProxyDemo {     interface Duck {         void quack();     }       public static void main(String[] a) {         Duck duck = (Duck) Proxy.newProxyInstance(             Thread.currentThread().getContextClassLoader(),             new Class[] { Duck.class },             (proxy, method, args) -&gt; {                 System.out.println(\"Quack\");                 return null;             }         );           duck.quack();     } } <\/code><\/pre>\n<p>  \u042d\u0442\u043e\u0442 \u043a\u043e\u0434 \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u044b\u0432\u043e\u0434\u0438\u0442:  <\/p>\n<pre><code>Quack <\/code><\/pre>\n<p>  \u0412 \u044d\u0442\u043e\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u043c\u044b \u0441\u043e\u0437\u0434\u0430\u043b\u0438 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440 \u043f\u0440\u043e\u043a\u0441\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u0442 API \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 Duck \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c <a href=\"https:\/\/docs.oracle.com\/javase\/10\/docs\/api\/java\/lang\/reflect\/InvocationHandler.html\">InvocationHandler<\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439, \u043f\u043e \u0441\u0443\u0442\u0438, \u043f\u0440\u043e\u0441\u0442\u043e \u043b\u044f\u043c\u0431\u0434\u0430, \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c\u0430\u044f \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 Duck. <br \/>  \u0418\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0435 \u043d\u0430\u0447\u043d\u0435\u0442\u0441\u044f, \u043a\u043e\u0433\u0434\u0430 \u043c\u044b \u0437\u0430\u0445\u043e\u0442\u0438\u043c \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044e \u043c\u0435\u0442\u043e\u0434\u0430 \u0432 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0438 \u0434\u0435\u043b\u0435\u0433\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432\u044b\u0437\u043e\u0432 \u0432 \u044d\u0442\u043e\u0442 \u043c\u0435\u0442\u043e\u0434:  <\/p>\n<pre><code class=\"java\">interface Duck {     default void quack() {         System.out.println(\"Quack\");     } } <\/code><\/pre>\n<p>  \u0421\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e, \u0437\u0430\u0445\u043e\u0447\u0435\u0442\u0441\u044f \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u0442\u0430\u043a\u043e\u0439 \u043a\u043e\u0434:  <\/p>\n<pre><code class=\"java\">import java.lang.reflect.Proxy;   public class ProxyDemo {     interface Duck {         default void quack() {             System.out.println(\"Quack\");         }     }       public static void main(String[] a) {         Duck duck = (Duck) Proxy.newProxyInstance(             Thread.currentThread().getContextClassLoader(),             new Class[] { Duck.class },             (proxy, method, args) -&gt; {                 method.invoke(proxy);                 return null;             }         );           duck.quack();     } } <\/code><\/pre>\n<p>  \u041d\u043e \u044d\u0442\u043e \u0432\u0441\u0435\u0433\u043e \u043b\u0438\u0448\u044c \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 \u0434\u043b\u0438\u043d\u043d\u044e\u0449\u0438\u0439 \u0441\u0442\u0435\u043a \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0445 \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0439 (\u0438 \u044d\u0442\u043e \u043d\u0435 \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0441 \u0432\u044b\u0437\u043e\u0432\u043e\u043c \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043c\u0435\u0442\u043e\u0434\u0430 \u0432 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0435, \u0442\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u043e \u0437\u0430\u043f\u0440\u0435\u0449\u0435\u043d\u043e \u0434\u0435\u043b\u0430\u0442\u044c):  <\/p>\n<pre><code>Exception in thread \"main\" java.lang.reflect.UndeclaredThrowableException \tat $Proxy0.quack(Unknown Source) \tat ProxyDemo.main(ProxyDemo.java:20) Caused by: java.lang.reflect.InvocationTargetException \tat sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) \tat sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) \tat sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) \tat java.lang.reflect.Method.invoke(Method.java:498) \tat ProxyDemo.lambda$0(ProxyDemo.java:15) \t... 2 more Caused by: java.lang.reflect.UndeclaredThrowableException \tat $Proxy0.quack(Unknown Source) \t... 7 more Caused by: java.lang.reflect.InvocationTargetException \tat sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) \tat sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) \tat sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) \tat java.lang.reflect.Method.invoke(Method.java:498) \tat ProxyDemo.lambda$0(ProxyDemo.java:15) \t... 8 more Caused by: java.lang.reflect.UndeclaredThrowableException \tat $Proxy0.quack(Unknown Source) \t... 13 more Caused by: java.lang.reflect.InvocationTargetException \tat sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) \tat sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) \tat sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) \tat java.lang.reflect.Method.invoke(Method.java:498) \tat ProxyDemo.lambda$0(ProxyDemo.java:15) \t... 14 more Caused by: java.lang.reflect.UndeclaredThrowableException \tat $Proxy0.quack(Unknown Source) \t... 19 more ... ... ... goes on forever <\/code><\/pre>\n<p>  \u041d\u0435 \u043e\u0447\u0435\u043d\u044c-\u0442\u043e \u043f\u043e\u043b\u0435\u0437\u043d\u043e.<\/p>\n<h2>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 Method Handles API<\/h2>\n<p>  \u0422\u0430\u043a, \u043f\u043e\u0438\u0441\u043a \u0432 \u0413\u0443\u0433\u043b\u0435 \u0432\u044b\u0434\u0430\u0435\u0442 \u043d\u0430\u043c, \u0447\u0442\u043e <a href=\"https:\/\/stackoverflow.com\/a\/37816247\/521799\">\u043d\u0443\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c MethodHandles API<\/a>. \u041d\u0443 \u0447\u0442\u043e, \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c!  <\/p>\n<pre><code class=\"java\">import java.lang.invoke.MethodHandles; import java.lang.reflect.Proxy;   public class ProxyDemo {     interface Duck {         default void quack() {             System.out.println(\"Quack\");         }     }       public static void main(String[] a) {         Duck duck = (Duck) Proxy.newProxyInstance(             Thread.currentThread().getContextClassLoader(),             new Class[] { Duck.class },             (proxy, method, args) -&gt; {                 MethodHandles                     .lookup()                     .in(Duck.class)                     .unreflectSpecial(method, Duck.class)                     .bindTo(proxy)                     .invokeWithArguments();                 return null;             }         );           duck.quack();     } } <\/code><\/pre>\n<p>  \u041a\u0440\u0443\u0442\u043e, \u043f\u043e\u0445\u043e\u0436\u0435, \u0447\u0442\u043e \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u043b\u043e!   <\/p>\n<pre><code>Quack <\/code><\/pre>\n<p>  \u2026 \u043d\u043e \u043d\u0435\u0442.<\/p>\n<h2>\u0412\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430 \u0441 \u043d\u0435 \u043f\u0440\u0438\u0432\u0430\u0442\u043d\u044b\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u043e\u043c<\/h2>\n<p>  \u0418\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0438\u0437 \u043f\u0440\u0438\u043c\u0435\u0440\u0430 \u0432\u044b\u0448\u0435 \u0431\u044b\u043b \u0430\u043a\u043a\u0443\u0440\u0430\u0442\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u043d \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u0443 \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0449\u0435\u0433\u043e \u043a\u043e\u0434\u0430 \u043a \u043d\u0435\u043c\u0443 \u0431\u044b\u043b \u043f\u0440\u0438\u0432\u0430\u0442\u043d\u044b\u0439 \u0434\u043e\u0441\u0442\u0443\u043f, \u0442.\u0435. \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0431\u044b\u043b \u0432\u043b\u043e\u0436\u0435\u043d \u0432 \u0432\u044b\u0437\u044b\u0432\u0430\u044e\u0449\u0438\u0439 \u043a\u043b\u0430\u0441\u0441. \u0410 \u0447\u0442\u043e, \u0435\u0441\u043b\u0438 \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u043d\u0435 \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441?  <\/p>\n<pre><code class=\"java\">import java.lang.invoke.MethodHandles; import java.lang.reflect.Proxy;   interface Duck {     default void quack() {         System.out.println(\"Quack\");     } }   public class ProxyDemo {     public static void main(String[] a) {         Duck duck = (Duck) Proxy.newProxyInstance(             Thread.currentThread().getContextClassLoader(),             new Class[] { Duck.class },             (proxy, method, args) -&gt; {                 MethodHandles                     .lookup()                     .in(Duck.class)                     .unreflectSpecial(method, Duck.class)                     .bindTo(proxy)                     .invokeWithArguments();                 return null;             }         );        duck.quack();     } } <\/code><\/pre>\n<p>  \u041f\u043e\u0447\u0442\u0438 \u0442\u0430\u043a\u043e\u0439 \u0436\u0435 \u043a\u043e\u0434 \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 IllegalAccessException:  <\/p>\n<pre><code>Exception in thread \"main\" java.lang.reflect.UndeclaredThrowableException \tat $Proxy0.quack(Unknown Source) \tat ProxyDemo.main(ProxyDemo.java:26) Caused by: java.lang.IllegalAccessException: no private access for invokespecial: interface Duck, from Duck\/package \tat java.lang.invoke.MemberName.makeAccessException(MemberName.java:850) \tat java.lang.invoke.MethodHandles$Lookup.checkSpecialCaller(MethodHandles.java:1572) \tat java.lang.invoke.MethodHandles$Lookup.unreflectSpecial(MethodHandles.java:1231) \tat ProxyDemo.lambda$0(ProxyDemo.java:19) \t... 2 more <\/code><\/pre>\n<p>  \u0424\u0438\u0433\u043d\u044f \u0432\u044b\u0448\u043b\u0430. \u0415\u0441\u043b\u0438 \u043f\u043e\u0433\u0443\u0433\u043b\u0438\u0442\u044c \u0435\u0449\u0435, \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0439\u0442\u0438 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u043e\u0441\u0442\u044f\u043c <a href=\"https:\/\/docs.oracle.com\/javase\/8\/docs\/api\/java\/lang\/invoke\/MethodHandles.Lookup.html\">MethodHandles.Lookup<\/a> \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e.  <\/p>\n<pre><code class=\"java\">import java.lang.invoke.MethodHandles.Lookup; import java.lang.reflect.Constructor; import java.lang.reflect.Proxy;   interface Duck {     default void quack() {         System.out.println(\"Quack\");     } }   public class ProxyDemo {     public static void main(String[] a) {         Duck duck = (Duck) Proxy.newProxyInstance(             Thread.currentThread().getContextClassLoader(),             new Class[] { Duck.class },             (proxy, method, args) -&gt; {                 Constructor&lt;Lookup&gt; constructor = Lookup.class                     .getDeclaredConstructor(Class.class);                 constructor.setAccessible(true);                 constructor.newInstance(Duck.class)                     .in(Duck.class)                     .unreflectSpecial(method, Duck.class)                     .bindTo(proxy)                     .invokeWithArguments();                 return null;             }         );           duck.quack();     } } <\/code><\/pre>\n<p>  \u0418, \u0443\u0440\u0430, \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c:  <\/p>\n<pre><code>Quack <\/code><\/pre>\n<p>  \u0423 \u043d\u0430\u0441 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0442\u043e \u043d\u0430 JDK 8. \u041a\u0430\u043a \u043d\u0430\u0441\u0447\u0435\u0442 JDK 9 \u0438\u043b\u0438 10?  <\/p>\n<pre><code>WARNING: An illegal reflective access operation has occurred WARNING: Illegal reflective access by ProxyDemo (file:\/C:\/Users\/lukas\/workspace\/playground\/target\/classes\/) to constructor java.lang.invoke.MethodHandles$Lookup(java.lang.Class) WARNING: Please consider reporting this to the maintainers of ProxyDemo WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations WARNING: All illegal access operations will be denied in a future release Quack <\/code><\/pre>\n<p>  \u041e\u043f\u0430\u0447\u043a\u0438. \u042d\u0442\u043e \u0442\u043e, \u0447\u0442\u043e \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 <a href=\"https:\/\/jaxenter.com\/jdk-9-replace-permit-illegal-access-134180.html\">\u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e<\/a>. \u0415\u0441\u043b\u0438 \u043c\u044b \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u043c \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u0443 \u0441 \u0444\u043b\u0430\u0433\u043e\u043c <code>--illegal-access=deny<\/code>:  <\/p>\n<pre><code>java --illegal-access=deny ProxyDemo <\/code><\/pre>\n<p>  \u041d\u0443, \u0442\u043e\u0433\u0434\u0430 \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c (\u0438 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e!):  <\/p>\n<pre><code>Exception in thread \"main\" java.lang.reflect.InaccessibleObjectException: Unable to make java.lang.invoke.MethodHandles$Lookup(java.lang.Class) accessible: module java.base does not \"opens java.lang.invoke\" to unnamed module @357246de         at java.base\/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:337)         at java.base\/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:281)         at java.base\/java.lang.reflect.Constructor.checkCanSetAccessible(Constructor.java:192)         at java.base\/java.lang.reflect.Constructor.setAccessible(Constructor.java:185)         at ProxyDemo.lambda$0(ProxyDemo.java:18)         at $Proxy0.quack(Unknown Source)         at ProxyDemo.main(ProxyDemo.java:28) <\/code><\/pre>\n<p>  \u041e\u0434\u043d\u0430 \u0438\u0437 \u0446\u0435\u043b\u0435\u0439 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 Jigsaw \u0431\u044b\u043b\u0430 \u043a\u0430\u043a \u0440\u0430\u0437 \u0438\u043c\u0435\u043d\u043d\u043e \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e\u0431\u044b \u043d\u0435 \u0434\u043e\u043f\u0443\u0441\u043a\u0430\u0442\u044c \u043f\u043e\u0434\u043e\u0431\u043d\u044b\u0445 \u0445\u0430\u043a\u043e\u0432. \u0422\u0430\u043a, \u0430 \u043a\u0430\u043a\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043b\u0443\u0447\u0448\u0435? \u042d\u0442\u043e?  <\/p>\n<pre><code class=\"java\">import java.lang.invoke.MethodHandles; import java.lang.invoke.MethodType; import java.lang.reflect.Proxy;   interface Duck {     default void quack() {         System.out.println(\"Quack\");     } }   public class ProxyDemo {     public static void main(String[] a) {         Duck duck = (Duck) Proxy.newProxyInstance(             Thread.currentThread().getContextClassLoader(),             new Class[] { Duck.class },             (proxy, method, args) -&gt; {                 MethodHandles.lookup()                     .findSpecial(                           Duck.class,                           \"quack\",                            MethodType.methodType(                               void.class,                               new Class[0]),                            Duck.class)                     .bindTo(proxy)                     .invokeWithArguments();                 return null;             }         );           duck.quack();     } } <\/code><\/pre>\n<p>  <\/p>\n<pre><code>Quack <\/code><\/pre>\n<p>  \u041e\u0442\u043b\u0438\u0447\u043d\u043e, \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 Java 9 \u0438 10, \u0430 \u043a\u0430\u043a \u043d\u0430\u0441\u0447\u0435\u0442 Java 8?  <\/p>\n<pre><code>Exception in thread \"main\" java.lang.reflect.UndeclaredThrowableException \tat $Proxy0.quack(Unknown Source) \tat ProxyDemo.main(ProxyDemo.java:25) Caused by: java.lang.IllegalAccessException: no private access for invokespecial: interface Duck, from ProxyDemo \tat java.lang.invoke.MemberName.makeAccessException(MemberName.java:850) \tat java.lang.invoke.MethodHandles$Lookup.checkSpecialCaller(MethodHandles.java:1572) \tat java.lang.invoke.MethodHandles$Lookup.findSpecial(MethodHandles.java:1002) \tat ProxyDemo.lambda$0(ProxyDemo.java:18) \t... 2 more <\/code><\/pre>\n<p>  \u0412\u044b \u0438\u0437\u0434\u0435\u0432\u0430\u0435\u0442\u0435\u0441\u044c, \u0434\u0430?<\/p>\n<p>  \u0418\u0442\u0430\u043a, \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u0440\u0435\u0448\u0435\u043d\u0438\u0435 (\u0445\u0430\u043a), \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 Java 8, \u043d\u043e \u043d\u0435 \u0432 9 \u0438 10, \u0438 \u0435\u0441\u0442\u044c \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 9 \u0438 10, \u043d\u043e \u043d\u0435 \u0432 8<\/p>\n<h2>\u0411\u043e\u043b\u0435\u0435 \u0433\u043b\u0443\u0431\u043e\u043a\u043e\u0435 \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u0435<\/h2>\n<p>  \u041d\u0443 \u0447\u0442\u043e, \u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0447\u0442\u043e \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u0440\u0430\u0437\u043d\u044b\u0439 \u043a\u043e\u0434 \u043d\u0430 \u0440\u0430\u0437\u043d\u044b\u0445 JDK. \u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043a\u043b\u0430\u0441\u0441 \u043f\u0440\u043e\u0431\u0443\u0435\u0442 \u0432\u0441\u0435 \u0432\u044b\u0448\u0435\u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u044b\u0435 \u043a\u043e\u043c\u0431\u0438\u043d\u0430\u0446\u0438\u0438. \u041e\u043d \u0442\u0430\u043a\u0436\u0435 \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0432 \u0432\u0438\u0434\u0435 GIST <a href=\"https:\/\/gist.github.com\/lukaseder\/f47f5a0d156bf7b80b67da9d14422d4a\">\u0437\u0434\u0435\u0441\u044c<\/a>.<\/p>\n<p>  \u041a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u0439\u0442\u0435 \u043a\u043e\u0434 \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c JDK 9 \u0438\u043b\u0438 10 (\u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044f JDK 9+ API: <a href=\"https:\/\/docs.oracle.com\/javase\/10\/docs\/api\/java\/lang\/invoke\/MethodHandles.html#privateLookupIn(java.lang.Class,java.lang.invoke.MethodHandles.Lookup)\">MethodHandles.privateLookupIn()<\/a>), \u043d\u043e \u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043d\u0443\u0436\u043d\u043e \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439, \u0443\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0439 \u043d\u0438\u0436\u0435, \u0447\u0442\u043e\u0431\u044b \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0437\u0430\u043f\u0443\u0441\u0442\u0438\u0442\u044c \u043a\u043b\u0430\u0441\u0441 \u043d\u0430 JDK 8:  <\/p>\n<pre><code>javac -source 1.8 -target 1.8 CallDefaultMethodThroughReflection.java <\/code><\/pre>\n<p>  <\/p>\n<pre><code class=\"java\">import java.lang.invoke.MethodHandles; import java.lang.invoke.MethodHandles.Lookup; import java.lang.invoke.MethodType; import java.lang.reflect.Constructor; import java.lang.reflect.Method; import java.lang.reflect.Proxy;     interface PrivateInaccessible {     default void quack() {         System.out.println(\" -&gt; PrivateInaccessible.quack()\");     } }   public class CallDefaultMethodThroughReflection {     interface PrivateAccessible {         default void quack() {             System.out.println(\" -&gt; PrivateAccessible.quack()\");         }     }       public static void main(String[] args) {         System.out.println(\"PrivateAccessible\");         System.out.println(\"-----------------\");         System.out.println();         proxy(PrivateAccessible.class).quack();           System.out.println();         System.out.println(\"PrivateInaccessible\");         System.out.println(\"-------------------\");         System.out.println();         proxy(PrivateInaccessible.class).quack();     }       private static void quack(Lookup lookup, Class&lt;?&gt; type, Object proxy) {         System.out.println(\"Lookup.in(type).unreflectSpecial(...)\");           try {             lookup.in(type)                   .unreflectSpecial(type.getMethod(\"quack\"), type)                   .bindTo(proxy)                   .invokeWithArguments();         }         catch (Throwable e) {             System.out.println(\" -&gt; \" + e.getClass() + \": \" + e.getMessage());         }           System.out.println(\"Lookup.findSpecial(...)\");         try {             lookup.findSpecial(type, \"quack\", MethodType.methodType(void.class, new Class[0]), type)                   .bindTo(proxy)                   .invokeWithArguments();         }         catch (Throwable e) {             System.out.println(\" -&gt; \" + e.getClass() + \": \" + e.getMessage());         }     }       @SuppressWarnings(\"unchecked\")     private static &lt;T&gt; T proxy(Class&lt;T&gt; type) {         return (T) Proxy.newProxyInstance(             Thread.currentThread().getContextClassLoader(),             new Class[] { type },             (Object proxy, Method method, Object[] arguments) -&gt; {                 System.out.println(\"MethodHandles.lookup()\");                 quack(MethodHandles.lookup(), type, proxy);                   try {                     System.out.println();                     System.out.println(\"Lookup(Class)\");                     Constructor&lt;Lookup&gt; constructor = Lookup.class.getDeclaredConstructor(Class.class);                     constructor.setAccessible(true);                     constructor.newInstance(type);                     quack(constructor.newInstance(type), type, proxy);                 }                 catch (Exception e) {                     System.out.println(\" -&gt; \" + e.getClass() + \": \" + e.getMessage());                 }                   try {                     System.out.println();                     System.out.println(\"MethodHandles.privateLookupIn()\");                     quack(MethodHandles.privateLookupIn(type, MethodHandles.lookup()), type, proxy);                 }                 catch (Error e) {                     System.out.println(\" -&gt; \" + e.getClass() + \": \" + e.getMessage());                 }                   return null;             }         );     } } <\/code><\/pre>\n<p>  \u0412\u044b\u0432\u043e\u0434 \u0432\u044b\u0448\u0435\u043f\u0440\u0438\u0432\u0435\u0434\u0435\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b:<br \/>  <b>Java 8<\/b>  <\/p>\n<pre><code>$ java -version java version \"1.8.0_141\" Java(TM) SE Runtime Environment (build 1.8.0_141-b15) Java HotSpot(TM) 64-Bit Server VM (build 25.141-b15, mixed mode)  $ java CallDefaultMethodThroughReflection PrivateAccessible -----------------  MethodHandles.lookup() Lookup.in(type).unreflectSpecial(...)  -&gt; PrivateAccessible.quack() Lookup.findSpecial(...)  -&gt; class java.lang.IllegalAccessException: no private access for invokespecial: interface CallDefaultMethodThroughReflection$PrivateAccessible, from CallDefaultMethodThroughReflection  Lookup(Class) Lookup.in(type).unreflectSpecial(...)  -&gt; PrivateAccessible.quack() Lookup.findSpecial(...)  -&gt; PrivateAccessible.quack()  MethodHandles.privateLookupIn()  -&gt; class java.lang.NoSuchMethodError: java.lang.invoke.MethodHandles.privateLookupIn(Ljava\/lang\/Class;Ljava\/lang\/invoke\/MethodHandles$Lookup;)Ljava\/lang\/invoke\/MethodHandles$Lookup;  PrivateInaccessible -------------------  MethodHandles.lookup() Lookup.in(type).unreflectSpecial(...)  -&gt; class java.lang.IllegalAccessException: no private access for invokespecial: interface PrivateInaccessible, from PrivateInaccessible\/package Lookup.findSpecial(...)  -&gt; class java.lang.IllegalAccessException: no private access for invokespecial: interface PrivateInaccessible, from CallDefaultMethodThroughReflection  Lookup(Class) Lookup.in(type).unreflectSpecial(...)  -&gt; PrivateInaccessible.quack() Lookup.findSpecial(...)  -&gt; PrivateInaccessible.quack()  MethodHandles.privateLookupIn()  -&gt; class java.lang.NoSuchMethodError: java.lang.invoke.MethodHandles.privateLookupIn(Ljava\/lang\/Class;Ljava\/lang\/invoke\/MethodHandles$Lookup;)Ljava\/lang\/invoke\/MethodHandles$Lookup; <\/code><\/pre>\n<p>  <b>Java 9<\/b>  <\/p>\n<pre><code>$ java -version java version \"9.0.4\" Java(TM) SE Runtime Environment (build 9.0.4+11) Java HotSpot(TM) 64-Bit Server VM (build 9.0.4+11, mixed mode)  $ java --illegal-access=deny CallDefaultMethodThroughReflection PrivateAccessible -----------------  MethodHandles.lookup() Lookup.in(type).unreflectSpecial(...)  -&gt; PrivateAccessible.quack() Lookup.findSpecial(...)  -&gt; PrivateAccessible.quack()  Lookup(Class)  -&gt; class java.lang.reflect.InaccessibleObjectException: Unable to make java.lang.invoke.MethodHandles$Lookup(java.lang.Class) accessible: module java.base does not \"opens java.lang.invoke\" to unnamed module @30c7da1e  MethodHandles.privateLookupIn() Lookup.in(type).unreflectSpecial(...)  -&gt; PrivateAccessible.quack() Lookup.findSpecial(...)  -&gt; PrivateAccessible.quack()  PrivateInaccessible -------------------  MethodHandles.lookup() Lookup.in(type).unreflectSpecial(...)  -&gt; class java.lang.IllegalAccessException: no private access for invokespecial: interface PrivateInaccessible, from PrivateInaccessible\/package (unnamed module @30c7da1e) Lookup.findSpecial(...)  -&gt; PrivateInaccessible.quack()  Lookup(Class)  -&gt; class java.lang.reflect.InaccessibleObjectException: Unable to make java.lang.invoke.MethodHandles$Lookup(java.lang.Class) accessible: module java.base does not \"opens java.lang.invoke\" to unnamed module @30c7da1e  MethodHandles.privateLookupIn() Lookup.in(type).unreflectSpecial(...)  -&gt; PrivateInaccessible.quack() Lookup.findSpecial(...)  -&gt; PrivateInaccessible.quack() <\/code><\/pre>\n<p>  <b>Java 10<\/b>  <\/p>\n<pre><code>$ java -version java version \"10\" 2018-03-20 Java(TM) SE Runtime Environment 18.3 (build 10+46) Java HotSpot(TM) 64-Bit Server VM 18.3 (build 10+46, mixed mode)  $ java --illegal-access=deny CallDefaultMethodThroughReflection ... \u0442\u0430\u043a\u043e\u0439 \u0436\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442, \u043a\u0430\u043a \u0432 Java 9 <\/code><\/pre>\n<h2>\u0417\u0430\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435<\/h2>\n<p>  \u041f\u043e\u043d\u044f\u0442\u044c \u0432\u0441\u0435 \u044d\u0442\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0441\u043b\u043e\u0436\u043d\u043e\u0432\u0430\u0442\u043e.  <\/p>\n<ul>\n<li>\u0412 Java 8 \u043d\u0430\u0438\u043b\u0443\u0447\u0448\u0438\u0439 \u0440\u0430\u0431\u043e\u0447\u0438\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u2013 \u0445\u0430\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u043b\u0435\u0437\u0430\u0435\u0442 \u0432\u043e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u043e\u0441\u0442\u0438 JDK \u0447\u0435\u0440\u0435\u0437 \u0434\u043e\u0441\u0442\u0443\u043f \u043a package-private \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0443 \u043a\u043b\u0430\u0441\u0441\u0430 <code>Lookup<\/code>. \u042d\u0442\u043e \u0435\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0435\u0434\u0438\u043d\u043e\u043e\u0431\u0440\u0430\u0437\u043d\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0442\u044c \u043c\u0435\u0442\u043e\u0434\u044b \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u043a\u0430\u043a \u0441 \u043f\u0440\u0438\u0432\u0430\u0442\u043d\u044b\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u043e\u043c, \u0442\u0430\u043a \u0438 \u0441 \u043d\u0435 \u043f\u0440\u0438\u0432\u0430\u0442\u043d\u044b\u043c \u0434\u043e\u0441\u0442\u0443\u043f\u043e\u043c \u0438\u0437 \u043b\u044e\u0431\u043e\u0433\u043e \u043a\u043b\u0430\u0441\u0441\u0430.<\/li>\n<li>\u0412 Java 9 \u0438 10 \u043b\u0443\u0447\u0448\u0438\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u2014 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>Lookup.findSpecial()<\/code> (\u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 Java 8) \u0438\u043b\u0438 <code>MethodHandles.privateLookupIn()<\/code> (\u043c\u0435\u0442\u043e\u0434 \u043d\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u0435\u0442 \u0432 Java 8). \u041f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0439 \u043f\u043e\u0434\u0445\u043e\u0434 \u043d\u0443\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c, \u0435\u0441\u043b\u0438 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u0432 \u0434\u0440\u0443\u0433\u043e\u043c \u043c\u043e\u0434\u0443\u043b\u0435. \u042d\u0442\u043e\u0442 \u043c\u043e\u0434\u0443\u043b\u044c \u0434\u043e\u043b\u0436\u0435\u043d \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u0434\u043b\u044f \u0432\u044b\u0437\u043e\u0432\u0430 \u0438\u0437\u0432\u043d\u0435.<\/li>\n<\/ul>\n<p>  \u0427\u0435\u0441\u0442\u043d\u043e \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u044d\u0442\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0437\u0430\u043f\u0443\u0442\u0430\u043d\u043d\u043e. \u041f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0439 \u043c\u0435\u043c \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/dj\/jr\/vo\/djjrvow4vd510x1-4cypuadiqk0.jpeg\"><\/p>\n<p>  Rafael Winterhalter (\u0430\u0432\u0442\u043e\u0440 ByteBuddy) \u0441\u043a\u0430\u0437\u0430\u043b, \u0447\u0442\u043e, \u201c\u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0438\u0439\u201d \u0444\u0438\u043a\u0441 \u0431\u0443\u0434\u0435\u0442 \u0432 \u043f\u0435\u0440\u0435\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 Proxy API:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/_d\/vb\/bb\/_dvbbbwyqljgt4d2kx7golz9im0.png\"><\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041f\u0435\u0440\u0435\u0432\u043e\u0434<\/b><\/p>\n<div class=\"spoiler_text\"><b>Lukas Eder<\/b>: \u00ab\u0422\u044b \u043d\u0435 \u0437\u043d\u0430\u0435\u0448\u044c \u043f\u0440\u0438\u0447\u0438\u043d\u0443 \u0442\u043e\u0433\u043e, \u043f\u043e\u0447\u0435\u043c\u0443 \u0440\u0435\u0448\u0438\u043b\u0438 \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u0440\u0430\u0437\u0440\u0435\u0448\u0430\u0442\u044c \u0442\u0430\u043a \u0434\u0435\u043b\u0430\u0442\u044c? \u0418\u043b\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u043e\u043f\u0443\u0441\u0442\u0438\u043b\u0438 \u044d\u0442\u043e (\u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043d\u0435\u0442)?\u00bb<br \/>  <b>Rafael Winterhalter<\/b>:\u00ab\u041d\u0435\u0442 \u043f\u0440\u0438\u0447\u0438\u043d\u044b. \u042d\u0442\u043e \u043f\u043e\u0431\u043e\u0447\u043d\u044b\u0439 \u044d\u0444\u0444\u0435\u043a\u0442 \u043c\u043e\u0434\u0435\u043b\u0438 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u0438 Java \u0434\u043b\u044f \u043a\u043b\u0430\u0441\u0441\u0430 Lookup \u0438\u0437 MethodHandle. \u0412 \u0438\u0434\u0435\u0430\u043b\u0435, \u0432 \u043f\u0440\u043e\u043a\u0441\u0438 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430\u0445 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u0442\u0430\u043a\u043e\u0439 Lookup \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0439 \u0432 \u0432\u0438\u0434\u0435 \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u0430 (<i>\u043a\u043e\u043d\u0441\u0442\u0440\u0443\u043a\u0442\u043e\u0440\u0430 \u2014 \u043f\u0440\u0438\u043c. \u043f\u0435\u0440.<\/i>), \u043d\u043e \u044d\u0442\u043e \u043d\u0435 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043b\u0438. \u042f \u0431\u0435\u0437\u0443\u0441\u043f\u0435\u0448\u043d\u043e \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u043b \u043f\u043e\u0445\u043e\u0436\u0435\u0435 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435 \u0434\u043b\u044f API \u0442\u0440\u0430\u043d\u0441\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u0444\u0430\u0439\u043b\u043e\u0432 \u043a\u043b\u0430\u0441\u0441\u043e\u0432.\u00bb  <\/div>\n<\/div>\n<p>  \u042f \u043d\u0435 \u0443\u0432\u0435\u0440\u0435\u043d, \u0447\u0442\u043e \u044d\u0442\u043e \u0440\u0435\u0448\u0438\u0442 \u0432\u0441\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b, \u043d\u043e \u043d\u0443\u0436\u043d\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u043d\u0435 \u0431\u0435\u0441\u043f\u043e\u043a\u043e\u0438\u043b\u0441\u044f \u043e\u0431\u043e \u0432\u0441\u0435\u043c \u0432\u044b\u0448\u0435\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u043c.<br \/>  \u0418 \u044f\u0441\u043d\u043e, \u0447\u0442\u043e \u044d\u0442\u0430 \u0441\u0442\u0430\u0442\u044c\u044f \u043d\u0435 \u043f\u043e\u043b\u043d\u0430\u044f, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043d\u0435 \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043b\u043e\u0441\u044c, \u0431\u0443\u0434\u0443\u0442 \u043b\u0438 \u044d\u0442\u0438 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c, \u0435\u0441\u043b\u0438 Duck \u0438\u043c\u043f\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d \u0438\u0437 \u0434\u0440\u0443\u0433\u043e\u0433\u043e \u043c\u043e\u0434\u0443\u043b\u044f:<\/p>\n<p>  <img decoding=\"async\" src=\"https:\/\/habrastorage.org\/webt\/ys\/n4\/kr\/ysn4krs8zlvalejyonih-kzoq2i.png\"><\/p>\n<div class=\"spoiler\"><b class=\"spoiler_title\">\u041f\u0435\u0440\u0435\u0432\u043e\u0434<\/b><\/p>\n<div class=\"spoiler_text\"><b>JOOQ<\/b>:<i>\u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 \u0438 \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u0441\u0442\u0430\u0442\u044c\u044e<\/i><br \/>  <b>Rafael Winterhalter<\/b>:\u00ab\u0410 \u0442\u044b \u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b \u043f\u043e\u043c\u0435\u0441\u0442\u0438\u0442\u044c Duck \u0432 \u043c\u043e\u0434\u0443\u043b\u044c, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u044d\u043a\u0441\u043f\u043e\u0440\u0442\u0438\u0440\u0443\u0435\u0442, \u043d\u043e \u043d\u0435 \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u0442 \u043f\u0430\u043a\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u0430? \u0413\u043e\u0442\u043e\u0432 \u043f\u043e\u0441\u043f\u043e\u0440\u0438\u0442\u044c, \u0447\u0442\u043e \u0442\u0432\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0434\u043b\u044f Java 9+ \u043d\u0435 \u0437\u0430\u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u0435\u0441\u043b\u0438 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f module path.\u00bb  <\/div>\n<\/div>\n<p>  \u2026 \u0438 \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u0442\u0435\u043c\u0430 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0438.<\/p>\n<h2>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 jOOR<\/h2>\n<p>  \u0415\u0441\u043b\u0438 \u0432\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0435 jOOR (\u043d\u0430\u0448\u0443 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0434\u043b\u044f reflection API, \u043e\u043d\u0430 <a href=\"https:\/\/github.com\/jOOQ\/jOOR\">\u0442\u0443\u0442<\/a>), \u0442\u043e \u0432\u0435\u0440\u0441\u0438\u044f 0.9.8 \u0431\u0443\u0434\u0435\u0442 \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c \u0444\u0438\u043a\u0441 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e: <a href=\"https:\/\/github.com\/jOOQ\/jOOR\/issues\/49\">github.com\/jOOQ\/jOOR\/issues\/49<\/a><br \/>  \u0424\u0438\u043a\u0441 \u043f\u0440\u043e\u0441\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u043f\u043e\u0434\u0445\u043e\u0434 \u0441 \u0445\u0430\u043a\u043e\u043c Reflection API \u0432 Java 8 \u0438\u043b\u0438 MethodHandles.privateLookupIn() \u0434\u043b\u044f Java 9+. \u041c\u043e\u0436\u043d\u043e \u043f\u0438\u0441\u0430\u0442\u044c:  <\/p>\n<pre><code class=\"java\">Reflect.on(new Object()).as(PrivateAccessible.class).quack(); Reflect.on(new Object()).as(PrivateInaccessible.class).quack(); <\/code><\/pre>\n<\/div>\n<p>        <script class=\"js-mediator-script\">!function(e){function t(t,n){if(!(n in e)){for(var r,a=e.document,i=a.scripts,o=i.length;o--;)if(-1!==i[o].src.indexOf(t)){r=i[o];break}if(!r){r=a.createElement(\"script\"),r.type=\"text\/javascript\",r.async=!0,r.defer=!0,r.src=t,r.charset=\"UTF-8\";var d=function(){var e=a.getElementsByTagName(\"script\")[0];e.parentNode.insertBefore(r,e)};\"[object Opera]\"==e.opera?a.addEventListener?a.addEventListener(\"DOMContentLoaded\",d,!1):e.attachEvent(\"onload\",d):d()}}}t(\"\/\/mediator.mail.ru\/script\/2820404\/\",\"_mediator\")}(window);<\/script>     <br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/post\/421413\/\"> https:\/\/habr.com\/post\/421413\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div data-io-article-url=\"https:\/\/habr.com\/company\/haulmont\/blog\/421413\/\" class=\"post__text post__text-html js-mediator-article\"><i>\u041f\u0440\u0438\u043c\u0435\u0447\u0430\u043d\u0438\u0435 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0447\u0438\u043a\u0430: \u0440\u0430\u0437\u0432\u0438\u0442\u0438\u0435 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0430 CUBA \u043f\u043e\u0440\u043e\u0436\u0434\u0430\u0435\u0442 \u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e R&amp;D \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432. \u0412 \u0445\u043e\u0434\u0435 \u043e\u0434\u043d\u043e\u0433\u043e \u0442\u0430\u043a\u043e\u0433\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0432\u044b\u044f\u0441\u043d\u0438\u043b\u043e\u0441\u044c, \u0447\u0442\u043e \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0437\u044b\u0432\u0430\u0442\u044c default \u043c\u0435\u0442\u043e\u0434\u044b \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0438\u0437 \u043f\u0440\u043e\u043a\u0441\u0438 \u043a\u043b\u0430\u0441\u0441\u043e\u0432. \u041d\u0430\u0442\u043a\u043d\u0443\u043b\u0438\u0441\u044c \u043d\u0430 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043b\u0435\u0437\u043d\u0443\u044e \u0441\u0442\u0430\u0442\u044c\u044e, \u043c\u043d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u043e\u043f\u044b\u0442, \u0438\u0437\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439 \u0432 \u043d\u0435\u0439, \u0431\u0443\u0434\u0435\u0442, \u043a\u0430\u043a \u043c\u0438\u043d\u0438\u043c\u0443\u043c \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u0435\u043d, \u043a\u0430\u043a \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u2014 \u043f\u043e\u043b\u0435\u0437\u0435\u043d \u0448\u0438\u0440\u043e\u043a\u043e\u043c\u0443 \u043a\u0440\u0443\u0433\u0443 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432. <\/i><\/p>\n<p>  \u041a\u043e\u0433\u0434\u0430 \u0434\u0435\u043b\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u043a default \u043c\u0435\u0442\u043e\u0434\u0430\u043c \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0432 Java \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e, \u0433\u0443\u0433\u043b\u0435\u043d\u0438\u0435 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, <a href=\"https:\/\/stackoverflow.com\/a\/37816247\/521799\">\u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043d\u0430 StackOverflow<\/a> \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u044b\u0445 \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f\u0445 \u0438 \u043d\u0435 \u043d\u0430 \u0432\u0441\u0435\u0445 \u0432\u0435\u0440\u0441\u0438\u044f\u0445 Java.<\/p>\n<p>  \u0412 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0441\u0441\u043c\u043e\u0442\u0440\u0435\u043d\u044b \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u043f\u043e\u0434\u0445\u043e\u0434\u044b \u043a \u0432\u044b\u0437\u043e\u0432\u0430\u043c default \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441\u043e\u0432 \u0447\u0435\u0440\u0435\u0437 \u0440\u0435\u0444\u043b\u0435\u043a\u0441\u0438\u044e, \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043d\u0443\u0436\u043d\u043e, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043f\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 \u043f\u0440\u043e\u043a\u0441\u0438-\u043a\u043b\u0430\u0441\u0441\u043e\u0432.<br \/>  <b>TL;DR<\/b> \u0415\u0441\u043b\u0438 \u0432\u0430\u043c \u043d\u0435 \u0442\u0435\u0440\u043f\u0438\u0442\u0441\u044f, \u0442\u043e \u0432\u0441\u0435 \u0441\u043f\u043e\u0441\u043e\u0431\u044b \u0432\u044b\u0437\u043e\u0432\u0430 default \u043c\u0435\u0442\u043e\u0434\u043e\u0432, \u043e\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0435 \u0432 \u044d\u0442\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435, \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b <a href=\"https:\/\/gist.github.com\/lukaseder\/f47f5a0d156bf7b80b67da9d14422d4a\">\u043f\u043e \u044d\u0442\u043e\u0439 \u0441\u0441\u044b\u043b\u043a\u0435<\/a>, \u0430 \u0442\u0430\u043a\u0436\u0435 \u044d\u0442\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0443\u0436\u0435 \u0440\u0435\u0448\u0435\u043d\u0430 \u0432 \u043d\u0430\u0448\u0435\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0435 <a href=\"https:\/\/github.com\/jOOQ\/jOOR\">jOOR<\/a>.   <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-288582","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/288582","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=288582"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/288582\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=288582"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=288582"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=288582"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}