Gymterview
junior

Что такое паттерн Observer и как он лежит в основе реактивного программирования?

Паттерн Observer (Наблюдатель) — поведенческий шаблон проектирования, позволяющий объектам следить за изменениями в других объектах и автоматически реагировать на них.

Также известен как Publish/Subscribe или Event Listener. Паттерн обеспечивает слабую связность (loose coupling) между компонентами, что делает его основой реактивного программирования, где система должна реагировать на изменения внешних источников данных.

Ключевые компоненты

  • Subject — источник данных или событий, управляет подписками наблюдателей
  • Observer — получает уведомления при изменении состояния Subject

В реактивной конфигурации Subject публикует изменения, а Observers подписываются на них, что подчёркивает модель потока данных (datastream model).

Пример кода паттерна Observer
import java.util.ArrayList;
import java.util.List;

interface Observer {
    void update();
}

class Subject {
    private List<Observer> observers = new ArrayList<>();
    private int state;

    public int getState() {
        return state;
    }

    public void setState(int state) {
        this.state = state;
        notifyAllObservers();
    }

    public void attach(Observer observer) {
        observers.add(observer);
    }

    public void notifyAllObservers() {
        for (Observer observer : observers) {
            observer.update();
        }
    }
}

class ConcreteObserver implements Observer {
    private String name;
    private Subject subject;

    public ConcreteObserver(String name, Subject subject) {
        this.name = name;
        this.subject = subject;
    }

    @Override
    public void update() {
        System.out.println("Observer " + name + " updated. New state: " + subject.getState());
    }
}

public class Main {
    public static void main(String[] args) {
        Subject subject = new Subject();
        ConcreteObserver observer1 = new ConcreteObserver("One", subject);
        ConcreteObserver observer2 = new ConcreteObserver("Two", subject);

        subject.attach(observer1);
        subject.attach(observer2);

        subject.setState(5);
    }
}

В данном примере Subject ведет список подписавшихся Observers и уведомляет их при изменении его состояния.

Практическое применение

  • Обработка событий пользовательского интерфейса
  • Системы уведомлений
  • Отслеживание изменений состояния приложения

Важно помнить, что чрезмерное использование паттерна может привести к усложнению кода и затруднить отладку.

На собеседовании: интервьюер ожидает связку: Observer — это фундамент реактивного программирования, расширенный поддержкой backpressure, операторов и управления потоками. Частая ошибка — не упомянуть, чем реактивный Observer отличается от классического GoF-паттерна (добавлены backpressure и терминальные сигналы onComplete/onError).