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

在 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);}}
}
输出(简化版)
CompilationUnitUsingDirectiveQualifiedNameIdentifierNameClassDeclarationIdentifierNameMethodDeclarationPredefinedTypeIdentifierNameBlockLocalDeclarationStatementVariableDeclarationPredefinedTypeVariableDeclaratorBinaryExpressionLiteralExpressionLiteralExpressionExpressionStatementInvocationExpressionMemberAccessExpressionIdentifierNameIdentifierNameArgumentListArgumentIdentifierName

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.mzph.cn/pingmian/73718.shtml

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

相关文章

【SpringCloud】Eureka的使用

3. Eureka 3.1 Eureka 介绍 Eureka主要分为两个部分&#xff1a; EurekaServer: 作为注册中心Server端&#xff0c;向微服务应用程序提供服务注册&#xff0c;发现&#xff0c;健康检查等能力。 EurekaClient: 服务提供者&#xff0c;服务启动时&#xff0c;会向 EurekaS…

前端知识点---window.location.assign() 和 window.location.href 的区别(javascript)

window.location.assign() 和 window.location.href 的主要区别&#xff1a; 读取和设置 window.location.href&#xff1a;既可以读取当前 URL&#xff0c;也可以通过赋值更改 URL。 window.location.assign()&#xff1a;只能用于跳转到新的 URL&#xff0c;不能读取当前地…

OpenCV图像拼接(3)图像拼接类cv::detail::MultiBandBlender

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 cv::detail::MultiBandBlender 是 OpenCV 中用于图像拼接&#xff08;stitching&#xff09;模块的一个类&#xff0c;主要用于将多张重叠的图像…

王者荣耀服务器突然崩了

就在刚刚王者荣耀服务器突然崩了 #王者荣耀崩了#的话题毫无预兆地冲上热搜&#xff0c;许多玩家发现游戏登录界面反复弹出异常提示&#xff0c;匹配成功后卡在加载界面&#xff0c;甚至出现对局数据丢失的情况。根据官方公告&#xff0c;目前技术团队已在全力抢修服务器 #王者…

【JavaScript】JavaScript Promises实践指南

【JavaScript】JavaScript Promises实践指南 你了解JavaScript中的Promises吗&#xff1f;这是一个很多人一开始就放弃的主题&#xff0c;但我会尽量让它变得尽可能简单。 1. “Promise”到底是什么&#xff1f; “Promise”是异步编程中的一个基本概念&#xff0c;特别是在J…

计算机视觉总结

以下是针对上述问题的详细解答,并结合代码示例进行说明: 1. 改进YOLOv5人脸检测模块,复杂光照场景准确率从98.2%提升至99.5% 优化具体过程: 光照补偿:在数据预处理阶段,采用自适应光照补偿算法,对图像进行实时增强,以减少光照变化对人脸检测的影响。数据增强:在训练…

ExpTimerApcRoutine函数分析之作用是ActiveTimerListHead里面移除定时器_etimer

第一部分&#xff1a; VOID ExpTimerApcRoutine ( IN PKAPC Apc, IN PKNORMAL_ROUTINE *NormalRoutine, IN PVOID *NormalContext, IN PVOID *SystemArgument1, IN PVOID *SystemArgument2 ) /* Routine Description: This function is the special …

算法分析与设计 专题三

目录 一、实验目的 二、实验内容 三、问题分析与求解 四、AC源代码、截图 五、实验小结 一、实验目的 1、了解贪心算法的分析过程&#xff0c;学会用贪心算法解决一些具体的问题。 2、了解广度优先算法和深度优先算法。 二、实验内容 1992 当然&#xff0c;我们的收藏中…

1688商品详情接口:深度解析与应用实践

在电商领域&#xff0c;1688作为中国领先的B2B平台&#xff0c;拥有海量的商品信息。对于开发者、商家和数据分析师来说&#xff0c;获取1688商品的详细信息是实现数据分析、竞品研究、自动化管理和精准营销的重要手段。本文将详细介绍1688商品详情接口的使用方法、技术细节以及…

每日算法-250328

记录今天学习和解决的LeetCode算法题。 92. 反转链表 II 题目 思路 本题要求反转链表中从 left 到 right 位置的节点。我们可以采用 头插法 的思路来反转指定区间的链表。 具体来说&#xff0c;我们首先定位到 left 位置节点的前一个节点 prev。然后&#xff0c;从 left 位置…

C语言中的位域:节省内存的标志位管理技术

位域&#xff08;Bit-field&#xff09; 是 C 语言中的一种特性&#xff0c;允许在结构体&#xff08;struct&#xff09;中定义占用特定位数的成员变量。通过位域&#xff0c;可以更精细地控制内存的使用&#xff0c;尤其是在需要存储多个布尔值或小范围整数时&#xff0c;可以…

【AI编程学习之Python】第一天:Python的介绍

Python介绍 简介 Python是一种解释型、面向对象的语言。由吉多范罗苏姆(Guido van Rossum)于1989年发明,1991年正式公布。官网:www.python.org Python单词是"大蟒蛇”的意思。但是龟叔不是喜欢蟒蛇才起这个名字,而是正在追剧:英国电视喜剧片《蒙提派森的飞行马戏团》(Mo…

【openstack系列】虚拟化技术

OpenStack 是一个开源的云计算管理平台,它本身并不直接提供虚拟化技术,而是通过集成不同的虚拟化解决方案来管理和编排计算、存储和网络资源。OpenStack 的核心优势在于其灵活性和可扩展性,支持多种虚拟化技术(Hypervisor),使企业可以根据需求选择合适的底层虚拟化方案。…

保姆级教程:Vue3 + Django + MySQL 前后端联调(PyCharm+VSCode版)

一、环境准备与验证 这里为减少篇幅&#xff0c;默认大家都安装好了这些软件。不会下载安装的&#xff0c;教程也很多&#xff0c;这里不再做赘述。话不多说&#xff0c;咱们开始&#xff1a; 1. 安装验证 确保已安装以下软件并验证版本&#xff1a; # 验证Node.js node -v…

Spring Data审计利器:@LastModifiedDate详解!!!

&#x1f552; Spring Data审计利器&#xff1a;LastModifiedDate详解&#x1f525; &#x1f31f; 简介 在数据驱动的应用中&#xff0c;记录数据的最后修改时间是常见需求。Spring Data的LastModifiedDate注解让这一过程自动化成为可能&#xff01;本篇带你掌握它的核心用法…

洛谷题单1-P1001 A+B Problem-python-流程图重构

题目描述 输入两个整数 a,b&#xff0c;输出它们的和&#xff08;∣a∣,∣b∣≤109&#xff09;。 输入格式 两个以空格分开的整数。 输出格式 一个整数。 输入输出样例 输入 20 30输出 50方式-print class Solution:staticmethoddef oi_input():"""从…

CCF CSP 第33次(2024.03)(2_相似度计算_C++)(字符串中字母大小写转换+哈希集合)

CCF CSP 第33次&#xff08;2024.03&#xff09;&#xff08;2_相似度计算_C&#xff09; 题目背景&#xff1a;题目描述&#xff1a;输入格式&#xff1a;输出格式&#xff1a;样例1输入&#xff1a;样例1输出&#xff1a;样例1解释&#xff1a;样例2输入&#xff1a;样例2输出…

Windows .gitignore文件不生效的情况排查

概述 今天下班在家里捣腾自己的代码&#xff0c;在配置.gitignore文件忽略部分文件的时候&#xff0c;发现死活不生效 问题根源 经过一通分析和排查才发现&#xff0c;是.gitignore文件的编码错了&#xff0c;刚开始还没注意到&#xff0c;因为是在Windows下开发&#xff0c…

Uniapp自定义TabBar组件全封装实践与疑难问题解决方案

前言 在当前公司小程序项目中&#xff0c;我们遇到了一个具有挑战性的需求&#xff1a;根据不同用户身份动态展示差异化的底部导航栏&#xff08;TabBar&#xff09; 。这种多角色场景下的UI适配需求&#xff0c;在提升用户体验和实现精细化运营方面具有重要意义。 在技术调研…

四川省汽车加气站操作工备考题库及答案分享

1.按压力容器的设计压力分为&#xff08; &#xff09;个压力等级。 A. 三 B. 四 C. 五 D. 六 答案&#xff1a;B。解析&#xff1a;按压力容器的设计压力分为低压、中压、高压、超高压四个压力等级。 2.缓冲罐的安装位置在天然气压缩机&#xff08; &#xff09;。 A. 出口处 …