如何解决为什么要先创建一个委托?
在循环中,为什么创建一个动作然后调用它?它会获得更好的性能吗?直接运行代码怎么样?
foreach (FieldInfo TargetMember in targettype.GetFields(BindingFlags.Public | BindingFlags.Instance)) {
Action work = delegate {
for (int Ordinal = 0; Ordinal < RecordInstance.FieldCount; OrdinaL++) {
//Check if the RecordFieldName matches the TargetMember
if (MemberMatchesName(TargetMember,RecordInstance.GetName(Ordinal))) {
Expression TargetValueExpression = GetTargetValueExpression(
RecordInstance,Culture,recordInstanceExp,SchemaTable,Ordinal,TargetMember.FieldType);
//Create a binding to the target member
MemberAssignment BindExpression = Expression.Bind(TargetMember,TargetValueExpression);
Bindings.Add(Ordinal,BindExpression);
return;
}
}
};
work();
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。