我正在重构opur代码以使用泛型.我们确实使用(出于必要,此处不可能更改)自己的代码来附加/分离/迭代/调用委托.在有X,Y,Z类宣布自己的类之前:
public delegate void Event_x_Delegate(ref ComParam pVal, out bool result);
目前我正在将此委托传递给泛型类:
public sealed class Event_X_Handling : BasicEvent
随着BasicEvent的发展
public abstract class BasicEvent: Loggable where DELEGATE: class { ...
这工作正常,所以我有附加/分离功能一般化.
但是现在我想概括迭代/调用.由于X,Y,Z仅在"ref ComParam pVal"中有所不同,这样的效果很好:
public abstract class BasicEventListener: BasicEvent .BasicDelegate > { #region TYPES public delegate void BasicDelegate (ref EVENTPARAM1 pVal, out bool result); #endregion
X,Y,Z变为:
public sealed class Event_X_Handling : BasicEventListener
但是这里出现了潜伏在拐角处的问题:附加/分离现在可以使用BasicEventListener.BasicDelegate.但是很多代码.引用Event_X_Handling.Event_x_Delegate,因为它们不幸地使用NET1.1语法来创建委托(使用类型化的事件+ =新的Delegate_X(_listen)).
简而言之:有没有办法将Event_x_Delegate别名为BasicDelegate?我真的看不到任何其他可能性.
PS:当然我看到,在迭代/调用中将基类分解为动态调用我可以在不引入BasicDelegate的情况下实现它.但这不是很优雅恕我直言.
Perahps using
别名会为你工作吗?
using System; using IntFunc = System.Func; namespace DelegateAlias { class Program { static int foo() { return 314; } static void Main(string[] args) { IntFunc f = foo; } } }