Обеспечивают ли запечатанные интерфейсы в Java какую-либо конкретную оптимизацию JVM, или это просто функция полноты вреJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Обеспечивают ли запечатанные интерфейсы в Java какую-либо конкретную оптимизацию JVM, или это просто функция полноты вре

Сообщение Anonymous »

Я понимаю, что запечатанные интерфейсы (и запечатанные классы) позволяют компилятору выполнять исчерпывающие проверки на соответствие шаблону и выражения переключения, что является явным улучшением безопасности типов во время компиляции.
Однако я пытаюсь понять влияние время выполнения. В частности:
  • Применяет ли JVM (особенно HotSpot) какие-либо специальные оптимизации при обнаружении запечатанного интерфейса по сравнению с обычным незапечатанным интерфейсом?
  • Например, активно ли JIT-компилятор использует атрибут PerratedSubclasses для встраивания, девиртуализации или анализ иерархии классов (CHA) более агрессивен или более стабилен?
  • Или реальность такова, что запечатанные интерфейсы обеспечивают соблюдение контракта только во время компиляции, а во время выполнения они обрабатываются точно так же, как и любой другой интерфейс (с учетом того же стандартного CHA и стратегий деоптимизации)?
Другими словами, есть ли какой-либо измеримый прирост производительности потому что интерфейс запечатан, или это преимущество исключительно в гарантии полноты времени компиляции, предотвращающей ошибки?
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»