Arhn - архитектура программирования

Каковы преимущества проксирования по классу по сравнению с проксированием по интерфейсу (Spring)?

Меня всегда очень раздражали некоторые приложения, которые мне теперь приходится поддерживать, которые настаивают на использовании проксирования по классам вместо проксирования по интерфейсу. В частности, у меня есть классы сервисного уровня, которые проксируются, но я не могу сделать их окончательными (хотя они должны быть), потому что по какой-то причине кто-то решил, что они должны быть проксированы фактическим классом, а не через интерфейс (хотя все из этих классов в любом случае есть интерфейсы).

Помимо отсутствия необходимости создавать интерфейс, есть ли реальная причина использовать прокси через целевой класс, а не прокси на основе целевого интерфейса в конфигурации Spring AOP?

16.07.2009

Ответы:


1

Только если вы действительно хотите, чтобы класс не менялся; проксирование по интерфейсу будет более мощным, потому что оно более гибкое, но если вы действительно хотите ограничить все одной реализацией, вам подойдет проксирование по классу. Я могу представить себе ситуацию, в которой можно было бы захотеть сохранить зависимость от проприетарного решения класса вместо того, чтобы позволить любому реализатору интерфейса быть проксируемым, но мне это кажется крайним случаем; Обычно я предполагаю использовать интерфейс.

16.07.2009
  • Вот что я не очень понимаю в вашем ответе. Если вы проксируете по целевому классу, класс, который вы проксируете, не может быть сделан окончательным. Если по какой-то причине вы написали свой код, полагаясь на внедрение фактической реализации, вы все равно могли бы расширить реализацию (при условии, что она была кандидатом на проксирование целевым классом), и поэтому она не обязательно была бы привязана к одной реализации, просто единое дерево наследования... 17.07.2009
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..