答案:匿名对象无法直接转换为强类型,但可通过反射、序列化或第三方库实现属性映射。使用反射可遍历属性并复制值,适用于通用场景;JSON序列化通过序列化再反序列化实现,代码简洁但需类型兼容;高性能需求可选AutoMapper或表达式树缓存优化性能。

在 .NET 中,匿名对象本身是编译时生成的内部类,无法直接通过类型转换赋值给自定义的强类型对象。但可以通过反射、序列化或辅助方法实现属性级别的映射。
使用反射进行属性复制
通过反射读取匿名对象的属性,并将其值设置到目标强类型实例中:
public static T ToStrongType(object anonymousObject) where T : new()
{
var result = new T();
var sourceProps = anonymousObject.GetType().GetProperties();
var targetProps = typeof(T).GetProperties();
foreach (var sourceProp in sourceProps)
{
var targetProp = targetProps.FirstOrDefault(p => p.Name == sourceProp.Name && p.PropertyType == sourceProp.PropertyType);
if (targetProp != null && targetProp.CanWrite)
{
targetProp.SetValue(result, sourceProp.GetValue(anonymousObject));
}
}
return result;
}
示例用法:
var anon = new { Name = “Alice”, Age = 30 };
var person = ToStrongType(anon); // 假设 Person 类有同名同类型的属性
使用 JSON 序列化(推荐简单场景)
借助 System.Text.Json 或 Newtonsoft.Json 将匿名对象序列化再反序列化为目标类型:
// 使用 System.Text.Json
using System.Text.Json;
public static T ToStrongTypeJson(object anonymousObject)
{
var json = JsonSerializer.Serialize(anonymousObject);
return JsonSerializer.Deserialize(json);
}
注意:该方式要求属性名称和类型兼容,且目标类型有公共无参构造函数。
使用表达式树或第三方库提升性能
如果频繁转换,反射性能较低。可考虑:
AutoMapper:配置好映射规则后高效转换ExpressMapper / Mapster:支持匿名对象到强类型的自动映射手写表达式树缓存赋值逻辑,避免重复反射
直接强制类型转换(如 (Person)anon)会编译失败或抛异常,因为匿名类型是密封的且不可见。
基本上就这些方法,JSON 反序列化最简洁,反射最通用,高性能场景建议用缓存映射。
以上就是.NET怎么将一个匿名对象转换为强类型对象的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1441308.html
微信扫一扫
支付宝扫一扫