हालाँकि, फ़ंक्शन हस्ताक्षर हमेशा समान नहीं होते हैं, इस प्रकार विभिन्न तर्क होते हैं।
इस तरह परिभाषित कुछ कार्यों के साथ शुरू करते हैं:
private object Function1() { return null; }
private object Function2(object arg1) { return null; }
private object Function3(object arg1, object arg3) { return null; }
आपके पास अपने निपटान में वास्तव में 2 व्यवहार्य विकल्प हैं:
1) ग्राहकों को अपने फ़ंक्शन को सीधे कॉल करके प्रकार-सुरक्षा बनाए रखें।
यह शायद सबसे अच्छा समाधान है, जब तक कि आपके पास इस मॉडल से टूटने के बहुत अच्छे कारण नहीं हैं।
जब आप फ़ंक्शन कॉल को इंटरसेप्ट करना चाहते हैं, तो यह मुझे लगता है कि आप वर्चुअल फ़ंक्शंस का पुनः आविष्कार करने की कोशिश कर रहे हैं। इस तरह की कार्यक्षमता को बॉक्स से बाहर निकालने के तरीकों का एक नाव लोड है, जैसे कि बेस क्लास से विरासत में मिली अपने कार्यों को ओवरराइड करना।
यह मुझे ऐसा लगता है जैसे आप एक वर्ग चाहते हैं जो एक आधार वर्ग के व्युत्पन्न उदाहरण से अधिक आवरण है, इसलिए ऐसा कुछ करें:
public interface IMyObject
{
object Function1();
object Function2(object arg1);
object Function3(object arg1, object arg2);
}
class MyObject : IMyObject
{
public object Function1() { return null; }
public object Function2(object arg1) { return null; }
public object Function3(object arg1, object arg2) { return null; }
}
class MyObjectInterceptor : IMyObject
{
readonly IMyObject MyObject;
public MyObjectInterceptor()
: this(new MyObject())
{
}
public MyObjectInterceptor(IMyObject myObject)
{
MyObject = myObject;
}
public object Function1()
{
Console.WriteLine("Intercepted Function1");
return MyObject.Function1();
}
public object Function2(object arg1)
{
Console.WriteLine("Intercepted Function2");
return MyObject.Function2(arg1);
}
public object Function3(object arg1, object arg2)
{
Console.WriteLine("Intercepted Function3");
return MyObject.Function3(arg1, arg2);
}
}
2) या अपने कार्यों के इनपुट को एक सामान्य इंटरफ़ेस में मैप करें।
यदि आपके सभी कार्य संबंधित हैं तो यह काम कर सकता है। उदाहरण के लिए, यदि आप एक खेल लिख रहे हैं, और सभी फ़ंक्शन खिलाड़ी या खिलाड़ी की इन्वेंट्री के कुछ हिस्से के लिए कुछ करते हैं। आप कुछ इस तरह से समाप्त करेंगे:
class Interceptor
{
private object function1() { return null; }
private object function2(object arg1) { return null; }
private object function3(object arg1, object arg3) { return null; }
Dictionary<string, Func<State, object>> functions;
public Interceptor()
{
functions = new Dictionary<string, Func<State, object>>();
functions.Add("function1", state => function1());
functions.Add("function2", state => function2(state.arg1, state.arg2));
functions.Add("function3", state => function3(state.arg1, state.are2, state.arg3));
}
public object Invoke(string key, object state)
{
Func<object, object> func = functions[key];
return func(state);
}
}