【动态编译】Roslyn中 SyntaxKind 枚举类型

news2025/3/31 8:50:54

在 Roslyn(.NET 的编译器平台)中,SyntaxKind 是一个枚举类型,定义了 C# 语言中所有可能的语法节点类型。它是 Roslyn 抽象语法树(AST)的基础,用于标识每个 SyntaxNode 的具体种类。SyntaxKind 的值直接对应于 C# 的语法结构,例如关键字、运算符、声明、语句和表达式等。

以下是对 SyntaxKind 枚举的详细说明,包括其分类、常见值及其用途。我会尽量全面且清晰地列出主要类别和示例,并避免过于冗长。如果你需要某个具体部分的深入解释,可以进一步告诉我!


1. SyntaxKind 概述

  • 命名空间Microsoft.CodeAnalysis.CSharp
  • 用途:通过 SyntaxNode.Kind() 方法返回节点的类型,帮助开发者识别和处理特定的语法结构。
  • 数量SyntaxKind 包含数百个值,覆盖 C# 的所有语法元素(截至 C# 12,大约有 800+ 个值)。
  • 分类:可以分为关键字、运算符、声明、语句、表达式等。

2. 主要分类与常见值

以下是 SyntaxKind 的主要分类及其代表性枚举值:

2.1 关键字(Keywords)

这些值对应 C# 的关键字,通常用于标识特定的语法结构。

  • ClassKeywordclass 关键字,用于类声明。
  • NamespaceKeywordnamespace 关键字,用于命名空间声明。
  • PublicKeywordpublic 访问修饰符。
  • VoidKeywordvoid 返回类型。
  • IfKeywordif 关键字,用于条件语句。
  • ReturnKeywordreturn 关键字,用于返回语句。
  • 示例
    public class MyClass { }
    // PublicKeyword, ClassKeyword
    
2.2 运算符(Operators)

这些值表示运算符,通常出现在表达式中。

  • PlusToken+ 加法运算符。
  • MinusToken- 减法运算符。
  • AsteriskToken* 乘法运算符。
  • SlashToken/ 除法运算符。
  • EqualsEqualsToken== 相等运算符。
  • GreaterThanToken> 大于运算符。
  • 示例
    int x = 1 + 2;
    // PlusToken
    
2.3 声明(Declarations)

这些值表示代码中的声明结构。

  • CompilationUnit:整个源文件的根节点。
  • NamespaceDeclaration:命名空间声明。
  • ClassDeclaration:类声明。
  • MethodDeclaration:方法声明。
  • FieldDeclaration:字段声明。
  • VariableDeclaration:变量声明。
  • Parameter:方法参数。
  • 示例
    class MyClass
    {
        int x;
        void MyMethod(int p) { }
    }
    // ClassDeclaration, FieldDeclaration, MethodDeclaration, Parameter
    
2.4 语句(Statements)

这些值表示执行语句。

  • Block:代码块({})。
  • ExpressionStatement:表达式语句。
  • IfStatement:if 语句。
  • ElseClause:else 子句。
  • ReturnStatement:return 语句。
  • LocalDeclarationStatement:局部变量声明语句。
  • ForStatement:for 循环。
  • WhileStatement:while 循环。
  • 示例
    if (x > 0) { return x; }
    // IfStatement, Block, ReturnStatement
    
2.5 表达式(Expressions)

这些值表示计算或值的表达式。

  • LiteralExpression:字面量表达式(如数字、字符串)。
  • BinaryExpression:二元表达式(如 x + y)。
  • InvocationExpression:方法调用表达式。
  • ObjectCreationExpression:对象创建表达式(new)。
  • AssignmentExpression:赋值表达式(如 x = 5)。
  • IdentifierName:标识符名称(如变量名、类名)。
  • MemberAccessExpression:成员访问表达式(如 Console.WriteLine)。
  • 示例
    Console.WriteLine(1 + 2);
    // InvocationExpression, BinaryExpression, LiteralExpression
    
2.6 其他结构
  • UsingDirective:using 指令。
  • Argument:方法调用的参数。
  • Attribute:特性(如 [Obsolete])。
  • PredefinedType:预定义类型(如 intstring)。
  • Trivia:语法琐碎内容(如空格、注释,不是严格的节点,但与 SyntaxToken 相关)。
  • 示例
    using System;
    // UsingDirective
    

3. SyntaxKind 的层级关系

SyntaxKind 的值与 SyntaxNode 的派生类一一对应。例如:

  • SyntaxKind.ClassDeclaration 对应 ClassDeclarationSyntax
  • SyntaxKind.BinaryExpression 对应 BinaryExpressionSyntax
  • SyntaxKind.IfStatement 对应 IfStatementSyntax

这种对应关系允许开发者通过 Kind() 判断节点类型,然后转换为具体的派生类以访问特定属性。


4. 示例:遍历并识别 SyntaxKind

以下代码展示如何解析 C# 代码并打印每个节点的 SyntaxKind

using Microsoft.CodeAnalysis;
using Microsoft.CodeAnalysis.CSharp;
using Microsoft.CodeAnalysis.CSharp.Syntax;
using System;

class Program
{
    static void Main()
    {
        string code = @"
            using System;
            class Program
            {
                static void Main()
                {
                    int x = 1 + 2;
                    Console.WriteLine(x);
                }
            }";

        SyntaxTree tree = CSharpSyntaxTree.ParseText(code);
        var root = tree.GetRoot();

        PrintSyntaxTree(root, 0);
    }

    static void PrintSyntaxTree(SyntaxNode node, int depth)
    {
        Console.WriteLine(new string(' ', depth * 2) + node.Kind());
        foreach (var child in node.ChildNodes())
        {
            PrintSyntaxTree(child, depth + 1);
        }
    }
}
输出(简化版)
CompilationUnit
  UsingDirective
    QualifiedName
      IdentifierName
  ClassDeclaration
    IdentifierName
    MethodDeclaration
      PredefinedType
      IdentifierName
      Block
        LocalDeclarationStatement
          VariableDeclaration
            PredefinedType
            VariableDeclarator
              BinaryExpression
                LiteralExpression
                LiteralExpression
        ExpressionStatement
          InvocationExpression
            MemberAccessExpression
              IdentifierName
              IdentifierName
            ArgumentList
              Argument
                IdentifierName

5. SyntaxKind 的具体值(部分列举)

以下是一些常见的 SyntaxKind 值及其含义:

关键字
  • ClassKeywordclass
  • PublicKeywordpublic
  • StaticKeywordstatic
  • IntKeywordint
运算符
  • PlusToken+
  • EqualsToken=
  • SemicolonToken;
  • OpenBraceToken{
声明
  • NamespaceDeclaration:命名空间声明
  • ClassDeclaration:类声明
  • MethodDeclaration:方法声明
语句
  • IfStatement:if 语句
  • ReturnStatement:return 语句
  • Block:代码块
表达式
  • LiteralExpression:字面量
  • BinaryExpression:二元表达式
  • InvocationExpression:方法调用
其他
  • UsingDirective:using 指令
  • EndOfFileToken:文件结束标记

完整列表可以在 Roslyn 源代码的 SyntaxKind.cs 文件中找到(位于 Microsoft.CodeAnalysis.CSharp 命名空间)。


6. 使用场景

  • 代码分析:通过 Kind() 判断节点类型,提取特定结构。
    var methods = root.DescendantNodes()
        .OfType<MethodDeclarationSyntax>()
        .Where(m => m.Modifiers.Any(SyntaxKind.PublicKeyword));
    
  • 代码生成:使用 SyntaxFactory 创建节点时指定 SyntaxKind
    var literal = SyntaxFactory.LiteralExpression(SyntaxKind.NumericLiteralExpression, SyntaxFactory.Literal(42));
    
  • 重构:替换或修改特定类型的节点。

7. 注意事项

  • 区分 Token 和 NodeSyntaxKind 既用于节点(如 ClassDeclaration),也用于标记(如 PlusToken)。标记通常是 SyntaxTokenKind,而非完整的 SyntaxNode
  • 版本差异:随着 C# 语言更新(如 C# 11、12),SyntaxKind 会新增值(如 RawStringLiteralToken)。
  • 性能:频繁使用 Kind() 检查时,考虑缓存或使用类型转换。

8. 总结

  • SyntaxKind 是 Roslyn 中标识语法节点类型的核心枚举。
  • 分类:包括关键字、运算符、声明、语句、表达式等。
  • 用途:用于解析、分析和生成 C# 代码。

如果你需要某个具体 SyntaxKind 值(如 SwitchExpression)的详细说明,或想结合具体场景使用,请告诉我,我会进一步展开!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2323913.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【211】线上教学系统

--基于SSM线上教学平添 主要实现的功能有&#xff1a; 管理员 : 首页、个人中心、学员管理、资料类型管理、学习资料管理、交流论坛、我的收藏管理、试卷管理、留言板管理、试题管理、系统管理、考试管理。 学员 : 首页、个人中心、我的收藏管理、留言板管理、考试管理。 前台…

从混乱思绪到清晰表达:记录想法如何改变你的学习人生

关键要点 • 记录想法似乎是发现自己想法并将其组织成可传播形式的最佳理由&#xff0c;研究表明写作和教学能增强学习和理解。 • 证据倾向于支持写作有助于澄清思想&#xff0c;而教学通过“教授效应”深化知识。 • 教学和分享被认为是最有效的学习方法&#xff0c;这与记录…

电机控制常见面试问题(二十)

文章目录 一.整流电路绕组接法二.电机为什么需要转速器三.电机转矩产生原理四.电机控制中载波频率大小的确定五.开关周期 Tpwm 一.整流电路绕组接法 为了引出直流的输出&#xff0c;一定要在整流变压器的二次侧引出零线&#xff0c;所以二次侧绕组必须接成星形 一次绕组必须要…

小爱控制via电视浏览器搜索图片-Homeassistant重制上一个自动化

制作自动化详情 为了完成图片搜&#xff0c;暂定指令找找{描述} 在执行脚本的adb地方输入以下指令&#xff0c;百度 因安全不让在图片地址直接搜转用bing >- >am start -n mark.via.gp/mark.via.Shell -a android.intent.action.VIEW -d https://cn.bing.com/images/…

unity一个图片的物体,会有透明的效果

如图 想要去掉这个透明效果 选择一个高层级的layer即可。

docker网桥问题导致ldap组件安装失败分析解决

使用pass_install_x86_64_0124版部署k8s底座、kem&#xff1b; 问题&#xff1a;一台kem节点部署ldap组件失败 解决&#xff1a;恢复问题主机的docker0网卡&#xff0c;重新部署kem相关组件 二、问题详情 现象描述 ansible部署kem组件 TASK [kem : start ldap] **********…

【Python】pillow库学习笔记1-Image类

《Python语言程序设计基础 》第3版&#xff0c;嵩天 黄天羽 杨雅婷著&#xff0c;P293 1.pillow库概述 Pillow 库是Python图像处理重要的第三方库。 Pillow库是PIL (Python image library) 库的一个扩展&#xff0c;需要通过pip工具安装。安装PIL库需要注意&#xff0c;安装…

智能网联交通加速落地,光路科技TSN技术助推车路云一体化发展

今日&#xff0c;为期两天的第二十七届高速公路信息化大会在青岛国际会展中心&#xff08;红岛馆&#xff09;圆满落幕。本次大会以“数智转型安全”为主题&#xff0c;聚焦高速公路数字化转型、车路云协同以及新一代信息技术的融合应用。会议汇聚了交通行业的专家学者、企业代…

boost.asio

as&#xff08;async&#xff09;:异步 同步io&#xff1a; reactor (非阻塞)&#xff08;需要注册一次&#xff0c;在等待消息时可以干别的事&#xff09; 阻塞io网络模型 接口&#xff1a;read\accept\connect\write 接口返回时&#xff0c;io完成 异步…

当贝AI知识库评测 AI如何让知识检索快人一步

近日,国内领先的人工智能服务商当贝AI正式推出“个人知识库”功能,这一创新性工具迅速引发行业关注。在信息爆炸的时代,如何高效管理个人知识资产、快速获取精准答案成为用户的核心需求。当贝AI通过将“闭卷考试”变为“开卷考试”的独特设计,为用户打造了一个高度个性化的智能…

深度解读:智能体2.0 AI Agent多推演进

AI Agent即AI 代理&#xff0c;长期以来&#xff0c;研究人员一直在追求更完美的AI&#xff0c;可以与人类相当、甚至是超越人类。在1950年代&#xff0c;AIan Turing就将“智能”的概念扩展到了人工实体&#xff0c;并提出了著名的图灵测试。这些人工智能实体就被称为——Agen…

Golang 的 GMP 调度机制常见问题及解答

文章目录 Golang GMP 调度模型详解常见问题基础概念1. GMP 各组件的作用是什么&#xff1f;2. 为什么 Go 需要自己的调度器&#xff1f;3. GOMAXPROCS 的作用是什么&#xff1f; 调度流程4. Goroutine 如何被调度到 M 上执行&#xff1f;5. 系统调用会阻塞整个线程吗&#xff1…

项目-苍穹外卖(十五) Apache ECharts+数据统计

一、介绍 二、营业额统计 需求分析和设计&#xff1a; Controller: Service: /*** 营业额统计* param begindate* param enddate* return* */Overridepublic TurnoverReportVO turnoverStatistics(LocalDate begindate, LocalDate enddate) {//创建时间集合List<LocalDate&…

Spring Data审计利器:@LastModifiedDate详解(依赖关系补充篇)!!!

&#x1f552; Spring Data审计利器&#xff1a;LastModifiedDate详解&#x1f525;&#xff08;依赖关系补充篇&#xff09; &#x1f50c; 核心依赖解析 使用LastModifiedDate必须知道的依赖关系 #mermaid-svg-qm1OUa9Era9ktbeK {font-family:"trebuchet ms",verd…

Tweak Power:全方位电脑系统优化的高效工具

Tweak Power&#xff08;系统&#xff09; Tweak Power是一款功能强大的系统优化工具&#xff0c;专为提升Windows电脑的性能和稳定性而设计。它提供了全面的清理、优化和调整选项&#xff0c;帮助用户轻松管理系统资源、提高运行速度、延长设备寿命。 快速扫描并清理系统垃圾…

CLion下载安装(Windows11)

目录 CLion工具下载安装其他 CLion CLion-2024.1.4.exe 工具 系统&#xff1a;Windows 11 下载 1.通过百度网盘分享的文件&#xff1a;CLion-2024.1.4.exe 链接&#xff1a;https://pan.baidu.com/s/1-zH0rZPCZtQ60IqdHA7Cew?pwdux5a 提取码&#xff1a;ux5a 安装 打开…

如何用 Postman 进行高效的 Mock 测试?

Postman 是一个强大的 API 开发和测试工具&#xff0c;它可以让你轻松地创建和发送各种 HTTP 请求&#xff0c;查看响应结果&#xff0c;并进行调试和优化。但是有时候&#xff0c;你可能还没有开发好后端服务&#xff0c;或者想要模拟不同的响应场景&#xff0c;这时候就可以使…

DeepSeek API集成开发指南——Flask示例实践

DeepSeek API集成开发指南——Flask示例实践 序言&#xff1a;智能化开发新范式 DeepSeek API提供了覆盖自然语言处理、代码生成等多领域的先进AI能力。本文将以一个功能完备的Flask示例系统为载体&#xff0c;详解API的集成方法与最佳实践。通过本案例&#xff0c;开发者可快…

【天梯赛】L2-004 这是二叉搜索树吗(经典问题C++)

解题反思 //镜像树满足&#xff1a;左子树>根节点>右子树 //特殊&#xff1a;独腿二叉树&#xff0c;如pre {2&#xff0c;3&#xff0c;4}&#xff0c;递归函数用if(root tail) return&#xff1b;无法识别这种二叉树 // 用ismirror来将一般二叉树和镜像二叉搜索树的…

Postman 全局 Header 如何设置?全局设置了解一下

在使用 Postman 设置全局请求头信息的关键步骤包括&#xff1a;在集合设置页面中添加所需的头部信息&#xff0c;并确保选择适当的类型和值&#xff1b;如果需要&#xff0c;可通过 JavaScript 脚本添加其他请求头&#xff1b;最后&#xff0c;验证设置是否成功生效。 Postman…