Factory Pattern এবং Proxy Pattern এ Reflection এর ভূমিকা

Practical Use Cases এবং Design Patterns - জাভা রিফ্লেক্ট প্যাকেজ (Java.reflect Package) - Java Technologies

302

Java Reflection প্যাকেজটি ডিজাইন প্যাটার্নগুলির সাথে কাজ করার সময় বিশেষ ভূমিকা পালন করতে পারে, বিশেষ করে Factory Pattern এবং Proxy Pattern-এ। Reflection এর সাহায্যে আপনি runtime-এ ক্লাস, মেথড, এবং ফিল্ডগুলি দেখতে এবং পরিচালনা করতে পারেন, যা এই ডিজাইন প্যাটার্নগুলির বাস্তবায়নকে আরও ডাইনামিক এবং ফ্লেক্সিবল করে তোলে।

1. Factory Pattern এবং Reflection

Factory Pattern এমন একটি ডিজাইন প্যাটার্ন যা অবজেক্ট তৈরি করার জন্য একটি ফ্যাক্টরি মেথড ব্যবহার করে। এতে ক্লাসের কনস্ট্রাক্টর এবং ইনস্ট্যান্স ক্রিয়েশন কোড ক্লাসের বাইরে রাখা হয়, যাতে কোডের পরিবর্তন না করে নতুন অবজেক্ট তৈরি করা যায়।

Factory Pattern-এ Reflection এর ভূমিকা:

Reflection এর সাহায্যে আপনি runtime-এ ডাইনামিকভাবে ক্লাসের ইনস্ট্যান্স তৈরি করতে পারেন, যা Factory Pattern-এর কাজকে আরও শক্তিশালী এবং লچকযুক্ত করে তোলে। আপনি জানেন না যে কনক্রিট কোন ক্লাস তৈরি করতে হবে, তবে Reflection এর মাধ্যমে কনস্ট্রাক্টর কল করা যায় এবং অবজেক্ট তৈরি করা যায়।

উদাহরণ: Factory Pattern with Reflection

import java.lang.reflect.*;

interface Product {
    void create();
}

class ProductA implements Product {
    @Override
    public void create() {
        System.out.println("ProductA created!");
    }
}

class ProductB implements Product {
    @Override
    public void create() {
        System.out.println("ProductB created!");
    }
}

class ProductFactory {
    public Product createProduct(String productType) throws Exception {
        // Reflection: Dynamically create object based on class name
        Class<?> clazz = Class.forName(productType);
        return (Product) clazz.getDeclaredConstructor().newInstance();
    }
}

public class FactoryPatternExample {
    public static void main(String[] args) {
        try {
            ProductFactory factory = new ProductFactory();
            
            // Create ProductA dynamically
            Product productA = factory.createProduct("ProductA");
            productA.create();
            
            // Create ProductB dynamically
            Product productB = factory.createProduct("ProductB");
            productB.create();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

Output:

ProductA created!
ProductB created!

ব্যাখ্যা:

  • Class.forName(productType): এখানে Reflection ব্যবহার করা হয়েছে যাতে ডাইনামিকভাবে ক্লাস লোড করা যায় এবং অবজেক্ট তৈরি করা যায়। productType হলো স্ট্রিং এর মাধ্যমে ক্লাসের নাম যা runtime-এ নির্ধারণ করা হবে।
  • clazz.getDeclaredConstructor().newInstance(): newInstance() ব্যবহার করে ক্লাসের কনস্ট্রাক্টর ডাইনামিকভাবে কল করা হয়েছে এবং অবজেক্ট তৈরি করা হয়েছে।

Reflection এর মাধ্যমে এই ফ্যাক্টরি প্যাটার্নটি ক্লাসের তৈরি প্রক্রিয়াকে আরও লচকযুক্ত এবং ডাইনামিক করেছে, যেখানে নতুন পণ্য যোগ করার জন্য কোড পরিবর্তন করতে হয় না।


2. Proxy Pattern এবং Reflection

Proxy Pattern এমন একটি ডিজাইন প্যাটার্ন যা একটি অবজেক্টের জন্য প্রতিনিধিত্বকারী অবজেক্ট তৈরি করে, যা মূল অবজেক্টের সমস্ত মেথড কলকে ক্যাপচার এবং কনট্রোল করতে পারে। Java-এর java.lang.reflect.Proxy ক্লাসটি স্বয়ংক্রিয়ভাবে Proxy Pattern বাস্তবায়ন করতে সাহায্য করে, এবং Reflection এর মাধ্যমে এটি কাজ করে।

Proxy Pattern-এ Reflection এর ভূমিকা:

Proxy Pattern-এ Reflection মূল ভূমিকা পালন করে, কারণ Proxy ক্লাসটি runtime-এ নতুন ক্লাস তৈরি করে এবং তার মেথডগুলিকে ইন্টারসেপ্ট করে। এটি dynamic proxy তৈরি করতে Reflection ব্যবহার করে, যেখানে কোনও ইন্টারফেসের মেথডগুলির জন্য এক্সিকিউশন আচরণ ডাইনামিকভাবে নির্ধারণ করা হয়।

উদাহরণ: Proxy Pattern with Reflection

import java.lang.reflect.*;

interface Service {
    void performAction();
}

class RealService implements Service {
    @Override
    public void performAction() {
        System.out.println("Performing real service action!");
    }
}

class LoggingHandler implements InvocationHandler {
    private Object target;

    public LoggingHandler(Object target) {
        this.target = target;
    }

    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("Logging: Method " + method.getName() + " is called.");
        return method.invoke(target, args);
    }
}

public class ProxyPatternExample {
    public static void main(String[] args) {
        // Create a real service
        Service realService = new RealService();

        // Create a proxy for the real service using reflection
        Service proxyService = (Service) Proxy.newProxyInstance(
            Service.class.getClassLoader(),
            new Class<?>[] { Service.class },
            new LoggingHandler(realService)
        );

        // Call methods on the proxy service
        proxyService.performAction();
    }
}

Output:

Logging: Method performAction is called.
Performing real service action!

ব্যাখ্যা:

  • Proxy.newProxyInstance(): Reflection ব্যবহার করে একটি নতুন Proxy অবজেক্ট তৈরি করা হয়েছে, যেখানে LoggingHandler নামক InvocationHandler ক্লাসটি performAction() মেথডকে ইন্টারসেপ্ট করে লগিং কার্যক্রম সম্পাদন করেছে।
  • InvocationHandler.invoke(): এটি Proxy অবজেক্টের মেথডে কল করে মূল অবজেক্টের performAction() মেথডটি বাস্তবায়ন করছে, যেখানে Reflection ব্যবহার করা হয়েছে মূল অবজেক্টের মেথড কল করার জন্য।

Reflection এবং Proxy Pattern:

Proxy Pattern বাস্তবায়নে Reflection খুব গুরুত্বপূর্ণ, কারণ Proxy.newProxyInstance() মেথডের মাধ্যমে একটি নতুন ডাইনামিক Proxy অবজেক্ট তৈরি করা হয়। এটি ক্লাস এবং মেথড অ্যাক্সেস কন্ট্রোলের জন্য Reflection ব্যবহার করে।


  1. Factory Pattern: Reflection এর মাধ্যমে Factory Pattern বাস্তবায়নে আপনি runtime-এ ডাইনামিকভাবে অবজেক্ট তৈরি করতে পারেন। এটি ক্লাসের নাম এবং ইনস্ট্যান্স তৈরির পদ্ধতিতে পরিবর্তন আনতে সহায়তা করে, যা একটি ফ্লেক্সিবল এবং লচকযুক্ত ফ্যাক্টরি প্যাটার্ন তৈরি করে।
  2. Proxy Pattern: Reflection Proxy Pattern-এর বাস্তবায়নে খুবই কার্যকরী, কারণ Proxy.newProxyInstance() মেথডের মাধ্যমে আপনি runtime-এ ডাইনামিক Proxy অবজেক্ট তৈরি করতে পারেন, যা মেথড ইন্টারসেপ্ট এবং পরিবর্তন করার সুযোগ দেয়।

Reflection এই ডিজাইন প্যাটার্নগুলোকে আরও ডাইনামিক, ফ্লেক্সিবল এবং শক্তিশালী করে তোলে, কারণ আপনি runtime-এ ক্লাস এবং মেথডকে পরিবর্তন করতে এবং পরিচালনা করতে পারেন।

Content added By
Promotion

Are you sure to start over?

Loading...