Kann jemand erklären oder zeigen, warum Laufzeit Typen überprüfen nicht in Beispiel unten auftritt - String-Eigenschaft kann auf einen beliebigen Wert gesetzt werden ...
Stuck mit diesem in sehr unerwarteten Ort und war wirklich überraschtDynamicMethod und Typprüfungen
using System;
using System.Reflection;
using System.Reflection.Emit;
namespace Dynamics
{
internal class Program
{
private static void Main(string[] args)
{
var a = new A();
a.Name = "Name";
Console.WriteLine(a.Name.GetType().Name);
PropertyInfo pi = a.GetType().GetProperty("Name");
DynamicMethod method = new DynamicMethod(
"DynamicSetValue", // NAME
null, // return type
new Type[]
{
typeof(object), // 0, objSource
typeof(object), // 1, value
}, // parameter types
typeof(Program), // owner
true); // skip visibility
ILGenerator gen = method.GetILGenerator();
gen.Emit(OpCodes.Ldarg_0);
gen.Emit(OpCodes.Ldarg_1);
gen.Emit(OpCodes.Call, pi.GetSetMethod(true));
gen.Emit(OpCodes.Ret);
SetValue setMethod = (SetValue)method.CreateDelegate(typeof(SetValue));
int val = 123;
setMethod(a, val);
Console.WriteLine(a.Name.GetType().Name);
A anotherA = new A();
anotherA.Name = "Another A";
setMethod(a, anotherA);
Console.WriteLine(a.Name.GetType().Name);
}
}
public class A
{
public string Name { get; set; }
}
public delegate void SetValue(object obj, object val);
}
Eigentlich war ich Typprüfung erwartet, wenn die Zuordnung eines gewissen Wert A.Name, nicht über die Eingabe Methodenparameter. pi.SetValue (a, 123) verursacht ArgumentException mit Text zum Objekttypkonvertierungsfehler, aber die SetValue-Methode akzeptiert auch Objekte als Parameter. –
Tatsächlich tritt Referenzwechsel ohne Typenprüfung auf ... –