J'ai une classe appelée EventConsumer qui définit un événement EventConsumed et une méthode OnEventConsumed comme suit:Quel est le MSIL pour appeler le gestionnaire d'événement d'une classe de base?
public event EventHandler EventConsumed;
public virtual void OnEventConsumed(object sender, EventArgs e)
{
if (EventConsumed != null)
EventConsumed(this, e);
}
je besoin d'ajouter des attributs au moment de l'exécution OnEventConsumed, donc je suis générer une sous-classe en utilisant System.Reflection. Émettre. Ce que je veux est l'équivalent MSIL de ceci:
public override void OnEventConsumed(object sender, EventArgs e)
{
base.OnEventConsumed(sender, e);
}
Ce que j'est jusqu'à présent ceci:
...
MethodInfo baseMethod = typeof(EventConsumer).GetMethod("OnEventConsumed");
MethodBuilder methodBuilder = typeBuilder.DefineMethod("OnEventConsumed",
baseMethod.Attributes,
baseMethod.CallingConvention,
typeof(void),
new Type[] {typeof(object),
typeof(EventArgs)});
ILGenerator ilGenerator = methodBuilder.GetILGenerator();
// load the first two args onto the stack
ilGenerator.Emit(OpCodes.Ldarg_1);
ilGenerator.Emit(OpCodes.Ldarg_2);
// call the base method
ilGenerator.EmitCall(OpCodes.Callvirt, baseMethod, new Type[0]);
// return
ilGenerator.Emit(OpCodes.Ret);
...
Je crée le type, créez une instance du type, et appeler sa fonction OnEventConsumed, et j'obtiens:
Common Language Runtime detected an invalid program.
... ce qui n'est pas vraiment utile. Qu'est-ce que je fais mal? Quel est le MSIL correct pour appeler le gestionnaire d'événements de la classe de base?
pourquoi la deuxième forme? La première fonctionne aussi bien. – Simon
C'est la cause du multithreading. Si vous cochez "EventConsumed! = Null", un autre thread peut être activé, supprimer le délégué de l'événement, le premier thread sera activé, le "EventConsumed" sera null, et le "EventConsumed (this, e)" sera Échec sur NullReferenceException. – TcKs