🧠Хитрая задача для Java-разработчиков: “Зеркальная фабрика”
📌Условие:
Реализуйте абстрактную фабрику MirrorFactory, которая: - При создании объекта класса T возвращает прокси, который повторяет все методы оригинального объекта - Но дополнительно логирует имя каждого вызванного метода и автоматически вызывает метод с тем же именем у другого объекта (его зеркала)
🎯 Иными словами:
MyService original = new MyService(); MyService mirror = new MyService();
- Классы могут быть любыми, но должны реализовывать интерфейсы - Использовать только стандартные средства Java (рефлексия, Proxy, `InvocationHandler`) - Методы с одинаковым именем и сигнатурой должны быть вызваны у обоих объектов
✅Решение: ```java import java.lang.reflect.*;
public class MirrorFactory { @SuppressWarnings("unchecked") public static <T> T create(T original, T mirror) { Class<?> clazz = original.getClass().getInterfaces()[0]; return (T) Proxy.newProxyInstance( clazz.getClassLoader(), new Class[]{clazz}, new InvocationHandler() { public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println(method.getName() + "() called"); Object result1 = method.invoke(original, args); Object result2 = method.invoke(mirror, args); return result1; // приоритет оригиналу } }); } } ```
Пример использования:
```java interface MyService { void doWork(); }
class MyServiceImpl implements MyService { public void doWork() { System.out.println("Working: " + this); } } ```
🔍 **Подвох:**
- Java `Proxy` работает **только с интерфейсами** - Метод вызывается **дважды** — нужно быть осторожным с побочными эффектами - Возврат значения только одного вызова (`original`) — важно, если метод что-то возвращает
🧠 **Чему учит задача:**
- Глубокому пониманию `java.lang.reflect.Proxy` - Поведению `InvocationHandler` и сигнатур - Умению комбинировать дизайн-паттерн **Proxy** и **Decorator** - Практике метапрограммирования и логирования без изменения кода класса
🧠Хитрая задача для Java-разработчиков: “Зеркальная фабрика”
📌Условие:
Реализуйте абстрактную фабрику MirrorFactory, которая: - При создании объекта класса T возвращает прокси, который повторяет все методы оригинального объекта - Но дополнительно логирует имя каждого вызванного метода и автоматически вызывает метод с тем же именем у другого объекта (его зеркала)
🎯 Иными словами:
MyService original = new MyService(); MyService mirror = new MyService();
- Классы могут быть любыми, но должны реализовывать интерфейсы - Использовать только стандартные средства Java (рефлексия, Proxy, `InvocationHandler`) - Методы с одинаковым именем и сигнатурой должны быть вызваны у обоих объектов
✅Решение: ```java import java.lang.reflect.*;
public class MirrorFactory { @SuppressWarnings("unchecked") public static <T> T create(T original, T mirror) { Class<?> clazz = original.getClass().getInterfaces()[0]; return (T) Proxy.newProxyInstance( clazz.getClassLoader(), new Class[]{clazz}, new InvocationHandler() { public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println(method.getName() + "() called"); Object result1 = method.invoke(original, args); Object result2 = method.invoke(mirror, args); return result1; // приоритет оригиналу } }); } } ```
Пример использования:
```java interface MyService { void doWork(); }
class MyServiceImpl implements MyService { public void doWork() { System.out.println("Working: " + this); } } ```
🔍 **Подвох:**
- Java `Proxy` работает **только с интерфейсами** - Метод вызывается **дважды** — нужно быть осторожным с побочными эффектами - Возврат значения только одного вызова (`original`) — важно, если метод что-то возвращает
🧠 **Чему учит задача:**
- Глубокому пониманию `java.lang.reflect.Proxy` - Поведению `InvocationHandler` и сигнатур - Умению комбинировать дизайн-паттерн **Proxy** и **Decorator** - Практике метапрограммирования и логирования без изменения кода класса
There are multiple ways you can search for Telegram channels. One of the methods is really logical and you should all know it by now. We’re talking about using Telegram’s native search option. Make sure to download Telegram from the official website or update it to the latest version, using this link. Once you’ve installed Telegram, you can simply open the app and use the search bar. Tap on the magnifier icon and search for a channel that might interest you (e.g. Marvel comics). Even though this is the easiest method for searching Telegram channels, it isn’t the best one. This method is limited because it shows you only a couple of results per search.
Export WhatsApp stickers to Telegram on Android
From the Files app, scroll down to Internal storage, and tap on WhatsApp. Once you’re there, go to Media and then WhatsApp Stickers. Don’t be surprised if you find a large number of files in that folder—it holds your personal collection of stickers and every one you’ve ever received. Even the bad ones.Tap the three dots in the top right corner of your screen to Select all. If you want to trim the fat and grab only the best of the best, this is the perfect time to do so: choose the ones you want to export by long-pressing one file to activate selection mode, and then tapping on the rest. Once you’re done, hit the Share button (that “less than”-like symbol at the top of your screen). If you have a big collection—more than 500 stickers, for example—it’s possible that nothing will happen when you tap the Share button. Be patient—your phone’s just struggling with a heavy load.On the menu that pops from the bottom of the screen, choose Telegram, and then select the chat named Saved messages. This is a chat only you can see, and it will serve as your sticker bank. Unlike WhatsApp, Telegram doesn’t store your favorite stickers in a quick-access reservoir right beside the typing field, but you’ll be able to snatch them out of your Saved messages chat and forward them to any of your Telegram contacts. This also means you won’t have a quick way to save incoming stickers like you did on WhatsApp, so you’ll have to forward them from one chat to the other.