如果您传递两个字符串,我有一段代码可以正常工作。由于某些原因,如果您将GUID转换为字符串,则无法正常工作。
更详细地讲,如果我创建一个新的ExpandoObject并传递字符串值,它将起作用,但是如果我将GUID转换为字符串,则不会。
下面的代码应比较两个参数。在我的示例中,我传递了相同的两个字符串。使用Equal运算符,true
如果字符串相同,则应返回。如果第二个参数GUID转换为字符串,则返回的false
字符串也相同。dynamicObj.Add(memberName, Guid.Parse(value).ToString());
不知道我在想什么。这是我的代码。
string value = "642188c7-8e10-e111-961b-0ee1388ccc3b";
string memberName = "State";
string contactValue = value;
var dynamicObj = (IDictionary<string, object>)new ExpandoObject(); dynamicObj.Add(memberName, Guid.Parse(value).ToString());
var expression = Expression.Parameter(typeof(object), "arg");
var binder = Binder.GetMember(CSharpBinderFlags.None, memberName, null, new[] { CSharpArgumentInfo.Create(CSharpArgumentInfoFlags.None, null) });
var property = Expression.Dynamic(binder, typeof(object), expression);
var isValid = false;
var right = Expression.Constant(contactValue);
var result = Expression.MakeBinary(ExpressionType.Equal, property, right);
var func = typeof(Func<,>).MakeGenericType(dynamicObj.GetType(), typeof(bool));
var expr = Expression.Lambda(func, result, expression).Compile();
isValid = (bool)expr.DynamicInvoke(dynamicObj);
GUID解析将以与仅使用字符串文字相同的字符串(值)结束。
但是,区别在于它在字典中的存储方式:类型Dictionary<string, object>
。这意味着将使用Object
该类的==
运算符进行引用相等性检查。在String
类,但是,这样做的值相等检查重载这一点。
这就是为什么它返回true的原因:
Console.WriteLine(value == Guid.Parse(value).ToString());
虽然返回false:
Console.WriteLine((object) value == (object) Guid.Parse(value).ToString());
由于字符串是不可变的,因此Guid.Parse(value).ToString()
将创建一个新string
对象,并与进行比较contactValue
(与相同value
),以进行引用相等性检查。false
与从未使用过value
所有返回相比,这显然会返回,true
因为您从未创建新对象。
为了使它起作用,您可以将动态操作数转换为a,string
这样它将使用正确的重载:
var castDyn = Expression.Convert(property, typeof(string));
var result = Expression.MakeBinary(ExpressionType.Equal, castDyn, right);
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句