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

在 .NET 中,匿名对象本身是编译时生成的内部类,无法直接通过类型转换赋值给自定义的强类型对象。但可以通过反射、序列化或辅助方法实现属性级别的映射。
使用反射进行属性复制
通过反射读取匿名对象的属性,并将其值设置到目标强类型实例中:
public static T ToStrongType
{
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
使用 JSON 序列化(推荐简单场景)
借助 System.Text.Json 或 Newtonsoft.Json 将匿名对象序列化再反序列化为目标类型:
// 使用 System.Text.Json
using System.Text.Json;
public static T ToStrongTypeJson
{
var json = JsonSerializer.Serialize(anonymousObject);
return JsonSerializer.Deserialize
}
注意:该方式要求属性名称和类型兼容,且目标类型有公共无参构造函数。
使用表达式树或第三方库提升性能
如果频繁转换,反射性能较低。可考虑:
- AutoMapper:配置好映射规则后高效转换
- ExpressMapper / Mapster:支持匿名对象到强类型的自动映射
- 手写表达式树缓存赋值逻辑,避免重复反射
直接强制类型转换(如 (Person)anon)会编译失败或抛异常,因为匿名类型是密封的且不可见。
基本上就这些方法,JSON 反序列化最简洁,反射最通用,高性能场景建议用缓存映射。










