Noi*_*ves 1 .net c# reflection types
我正在尝试编写一个函数来为Type对象生成完整的C#声明.我当前的方法涉及在Type对象上执行非常手动和特定的逻辑.
是否有一些内置的.Net方式来生成此声明?
举个例子,拿这个类:
namespace My.Code.Here
{
public class Class1<>
{
public enum Enum1 { }
}
}
Run Code Online (Sandbox Code Playgroud)
当在typeof(Class1 <>.Enum1)上调用函数(让它调用它为getCSharpDec)时,它将返回"My.Code.Here.Class1 <>.Enum1".
这里有几个问题......
Type命名嵌套类型的方式不同Type命名泛型类型不同作为一个未成年人,Class1<>.Enum1不是一个封闭的类型,但这应该不是一个问题...
(编辑)
这非常接近 - 它仍然保留了类型的外部泛型:
static void Main()
{
Type t = typeof(My.Code.Here.Class1<>.Enum1);
string s = GetCSharpName(t); // My.Code.Here.Class1<T>.Enum1<T>
}
public static string GetCSharpName<T>()
{
return GetCSharpName(typeof(T));
}
public static string GetCSharpName(Type type)
{
StringBuilder sb = new StringBuilder();
sb.Insert(0, GetCSharpTypeName(type));
while (type.IsNested)
{
type = type.DeclaringType;
sb.Insert(0, GetCSharpTypeName(type) + ".");
}
if(!string.IsNullOrEmpty(type.Namespace)) {
sb.Insert(0, type.Namespace + ".");
}
return sb.ToString();
}
private static string GetCSharpTypeName(Type type)
{
if (type.IsGenericTypeDefinition || type.IsGenericType)
{
StringBuilder sb = new StringBuilder();
int cut = type.Name.IndexOf('`');
sb.Append(cut > 0 ? type.Name.Substring(0, cut) : type.Name);
Type[] genArgs = type.GetGenericArguments();
if (genArgs.Length > 0)
{
sb.Append('<');
for (int i = 0; i < genArgs.Length; i++)
{
sb.Append(GetCSharpTypeName(genArgs[i]));
if (i > 0) sb.Append(',');
}
sb.Append('>');
}
return sb.ToString();
}
else
{
return type.Name;
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1592 次 |
| 最近记录: |