简短的回答:你不能。没有正确的方法可以从(Roslyn)获得System.Type
(reflection )。ISymbol
朝着您想要的方向前进的一种选择是构建您的类型的完全限定名称,然后通过反射(示例)查找它。
不过,您可能应该先问问自己这是否是您首先需要做的事情——反射和 Roslyn 并不是真的打算一起工作。
但是,您感兴趣的事情也可以通过 Roslyn 完成。这里的关键是使用为您提供所有这些信息的语义模型。所有声明(与用法相反)都有一个特定的重载可用,它允许您获取声明符号并以适当的类型返回它(例如INamedTypeSymbol
在这种情况下)。
举个例子:
const string source = @"
using System;
namespace MyNamespace
{
class MyClass : IDisposable
{
void Method()
{
MyClass nameOfVariable, another;
}
}
}
";
var tree = CSharpSyntaxTree.ParseText(source);
var compilation = CSharpCompilation.Create("MyCompilation", new[] { tree }, new[] { MetadataReference.CreateFromFile(typeof(object).Assembly.Location) });
var semanticModel = compilation.GetSemanticModel(tree);
var root = tree.GetRoot();
var classSymbol = semanticModel.GetDeclaredSymbol(root.DescendantNodes().OfType<ClassDeclarationSyntax>().First());
Console.WriteLine(string.Join(", ", classSymbol.AllInterfaces));
这将显示该类实现的所有接口。但是请记住,这只是指当前的定义——如果您也对基本类型感兴趣,则必须自己浏览层次结构。
在您的场景中,您应该能够将其转换为正确的类型(假设您正在检查声明节点):
var objectSymbol = (INamedTypeSymbol) model.GetDeclaredSymbol(obj.Node);