译 | 使用Roslyn分析器高效编写更好的代码

原文:Mika Dumont

翻译:汪宇杰

Roslyn 是 .NET 编译器平台,即使在运行代码之前,它也能帮助您捕获 Bug。例如内置于 Visual Studio 中的Roslyn 拼写检查分析器。

假设您正在创建一个静态方法,并将 static 单词拼错为 statc。在运行代码之前,您将能够看到此拼写错误。因为 Roslyn 可以在键入代码时生成警告,甚至在您完成行之前。换句话说,您不必编译代码之后才发现您犯了一个错误。

640?wx_fmt=png

Roslyn 分析仪还可以通过 Visual Studio 灯泡图标显示自动代码修复,从而允许您立即修复代码。

640?wx_fmt=gif

但是,如果你能捕捉到更多的错误呢?

让我向您介绍 Roslyn 分析器包。这些分析器集合提供了更详细的分析,但随 Visual Studio 默认工具发布。要了解有关我们最喜欢的 Roslyn 分析仪的详细信息,请访问我们的 Roslyn 分析器 GitHub 仓库。此仓库包括仍然适用于现代软件开发的 FxCop,但现在以基于 Roslyn 的现代代码分析平台为目标。让我们继续,安装这个包,以提高工作效率,更快地编写更好的代码!

译者注:Roslyn 分析器 https://github.com/dotnet/roslyn-analyzers

将 FxCop 分析器作为 NuGet 包安装

假设您使用的是 Visual Studio 2017 15.8 或更高版本,请选择最新版本的 Microsoft.CodeAnalysis.FxCopAnalyzers。

使用包管理器 UI 在 Visual Studio 中安装包。

640?wx_fmt=png

安装包后,只需从解决方案资源管理器自定义分析器诊断。分析器节点将显示在解决方案资源管理器中的"引用"或"依赖项"节点下。如果展开分析器,然后展开其中一个分析器程序集,则可以在程序集中看到所有诊断。

640?wx_fmt=png

您可以在属性窗口中查看诊断的属性,包括其描述和默认严重性。要查看属性,请右键单击规则并选择"属性",或选择规则后按 Alt+Enter。

640?wx_fmt=png

解决方案资源管理器中每个诊断项旁边的图标对应于您在编辑器中打开规则集时看到的图标:

  • 圆圈中的"i"表示信息

  • 三角形中的"!" 表示警告

  • 圆圈中的"x"表示严重

  • 浅色背景上圆圈中的"i"表示隐藏的严重

  • 圆圈中的"*"表示忽略的诊断

640?wx_fmt=png

然后,可以从解决方案资源管理器设置规则集严重性。在解决方案资源管理器中,展开依赖项和分析器。展开包含要为其设置严重性的规则的程序集。右键单击规则并选择"设置规则集严重性",并在弹出的菜单中选择一个严重性选项。

640?wx_fmt=png

如果将规则严重性设置为警告,则会在代码中收到该特定规则集的警告。

640?wx_fmt=png

现在,您已经了解了分析器的工作原理,您可以提高工作效率,更快地编写更好的代码!

640?wx_fmt=gifQ&A

问:此警告显示在 Visual Studio 中:"运行代码分析已弃用为 FxCop 分析器,该分析器在生成期间运行。请参阅https://aka.ms/fxcopanalyzers迁移到 FxCop 分析仪"。这是什么意思?

答:FxCop 是比 Roslyn 早近十年的代码分析引擎。就像我们推进编译器(例如介绍 Roslyn)一样,我们也在将代码分析技术推进到 Roslyn 平台。由于它由 .NET 编译器平台提供支持,因此在键入代码时,它可以在代码中生成警告。换句话说,您不必并编译代码才能发现您犯了一个错误。

问:FxCop分析仪和旧版FxCop分析器有什么区别?

答:FxCop 分析器在编译过程中实时分析源代码,而旧版 FxCop 是静态代码分析,并在生成完成后分析二进制文件。有关详细信息,请参阅 Roslyn 分析器与静态代码分析(1)和 FxCop 分析器常见问题解答(2)。

问:我可以编写自定义分析器吗?

答:当然可以!有关如何编写分析器的文档,请参阅此处(3)。

问:我应该使用 Roslyn 分析器还是 .editorconfig 规范代码样式?

答:Roslyn 分析器和 .editorconfig 文件是齐头并进的。在 .editorconfig 文件或文本编辑器选项页上定义代码样式时,实际上正在配置内置于 Visual Studio 中的 Roslyn 分析器。

问:分析器在持续集成 (CI) 生成中工作吗?

答:是的,分析器作为NuGet包可以 CI 中约束编译。

问:在哪里可以请求更多分析器或报告错误?

答:您可以在 GitHub 上的 Roslyn 仓库上请求更多分析器并报告 Bug。

译者注:

(1)https://docs.microsoft.com/visualstudio/code-quality/roslyn-analyzers-overview?view=vs-2019#roslyn-analyzers-vs-static-code-analysis

(2) https://docs.microsoft.com/visualstudio/code-quality/fxcop-analyzers-faq?view=vs-2019

(3)https://docs.microsoft.com/dotnet/csharp/roslyn-sdk/tutorials/how-to-write-csharp-analyzer-code-fix

(4)https://github.com/dotnet/roslyn/issues

640?wx_fmt=gif

英文原文可点击“阅读原文”查看

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

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

相关文章

Codeforces Round #724 (Div. 2) F. Omkar and Akmar 组合数学 + 博弈

传送门 文章目录题意:思路:题意: 思路: 首先我们先来研究一下这个游戏,手画几个会惊奇的发现,后手这个b怎么怎么画都赢啊???对,没错,就是怎么画都…

Visual Studio 支持 Java?谣言止于智者

在去年的某一段时间内,我们经常会看到标题类似为“宇宙第一 IDE Visual Studio 支持 Java 了!”的文章。当时,韩老师看到这篇文章也是一脸懵逼。公司里做 Java 的开发童鞋们就坐在韩老师附近(嗯,不超过五米的距离&…

【SCOI2014】方伯伯的商场之旅【数位dp】【单峰函数】

题意:给定 l,r,kl,r,kl,r,k ,对于一个 kkk 进制数,将数码看成这个位置的石子个数,每将一个石子移动 111 的距离需要 111 的代价。求 [l,r][l,r][l,r] 中的所有数在 kkk 进制下将石子集中在一个位置的最小代价之和。 l≤r≤1015,k≤…

Codeforces Round #597 (Div. 2) D. Shichikuji and Power Grid 最小生成树 + 虚拟点

传送门 文章目录题意:思路:题意: 思路: 看错题导致误入歧途,如果能早点看见翻译也不至于一天多也没想出来。 求联通的最小代价,自然的想到了能不能建边跑最小生成树。 对于两点之间比较好弄,直…

【NOI2007】货币兑换【任意坐标斜率优化】【CDQ分治】

题意:有 A,B 两种金券,给出 nnn 天内分别的单位价格和可以购买的数量的比例。开始有 SSS 元,求 nnn 天后最多能有多少元。 提示:每次操作一定全买全卖 n≤105n\leq 10^5n≤105 设 fnf_nfn​ 表示第 nnn 天结束后手上…

小白开学Asp.Net Core 《八》

小白开学Asp.Net Core 《八》— — .Net Core 数据保护组件1、背景我在搞(https://github.com/AjuPrince/Aju.Carefree)这个开源项目的时候,想做一些防止恶意攻击的小功能(如果 我通过页面 /Dome/GetData?id123,那是不…

你必须知道的Docker镜像仓库的搭建

近期工作中发现用到的容器镜像越来越多(不多的时候没考虑过镜像仓库的问题),同一个容器镜像也存在多个版本,那么镜像仓库的搭建需求就涌现出来,本文就目前的几个常用镜像仓库的搭建进行介绍,我们可以根据需…

nowcoder 河 我 车 题 错 天 乐 赛 倍增处理

传送门 文章目录题意:思路:题意: 思路: 倍增经典题了,考虑维护一个前缀和sum[i]sum[i]sum[i],对于iii位置我们肯定是贪心的选能到的最远位置,即第一个>sum[i−1]k>sum[i-1]k>sum[i−1…

狄利克雷生成函数

一个没啥用的东西,权当加深对数论函数和狄利克雷卷积的理解。 定义 序列 {f1,f2,…}\{f_1,f_2,\dots\}{f1​,f2​,…} 的狄利克雷生成函数 DGF 定义为 f(s)∑n1∞fnnsf(s)\sum_{n1}^{\infin}\frac{f_n}{n^s}f(s)n1∑∞​nsfn​​ 这里不要求 fff 是积性函数。 显…

ASP.NET Core Web Api之JWT(一)

最近沉寂了一段,主要是上半年相当于休息和调整了一段时间,接下来我将开始陆续学习一些新的技能,比如Docker、Jenkins等,都会以生活实例从零开始讲解起,到时一并和大家分享和交流。接下来几节课的内容将会讲解JWT&#…

Codeforces Round #658 (Div. 2) D. Unmerge 思维 + 背包

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 我们可以假设有两个桶&#xff0c;让后向里面放数&#xff0c;可以发现&#xff0c;如果向其中放入了aia_iai​&#xff0c;那么紧跟在他后面的所有<ai<a_i<ai​的数都必须跟在ai…

【牛客NOIP模拟】牛半仙的魔塔(增强版)【贪心】【并查集】

题意&#xff1a;一个魔塔游戏的地图是一棵以 111 为根的树&#xff0c;起点为根&#xff0c;除根外每个结点有一个怪物&#xff0c;给定每个怪物血量、攻击、防御、奖励蓝宝石个数&#xff08;加防御&#xff09;&#xff0c;勇士的血量、攻击、防御&#xff0c;遇到怪物必须战…

撸过一万行代码,你看过这篇文章吗?

北上广深真的是技术的宝地吗&#xff1f;犹记得刚刚参加工作之后&#xff0c;有人邀请我去深圳&#xff0c;说沿海地区是IT行业从业人员的宝地&#xff0c;只有在那里才会学到真正的技术&#xff0c;而且能拿到更高的工资&#xff0c;不管从哪个层面来说&#xff0c;都值得你去…

Codeforces Round #727 (Div. 2) E. Game with Cards dp + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 初始有左右手&#xff0c;上面各有一个数字为000的卡牌&#xff0c;每次都有一个新卡kik_iki​&#xff0c;你可以将其放在左手或者右手&#xff0c;使两只手上的卡片范围在[ll,i,rl,i][l_{l,i},r_{l,i}][ll…

【CEOI2017】Building Bridges【任意坐标斜率优化】【李超线段树】

题意&#xff1a;有 nnn 个柱子&#xff0c;每个柱子有高度 hih_ihi​。你需要在柱子间修桥&#xff0c;在 i,ji,ji,j 间修桥代价为 (hi−hj)2(h_i-h_j)^2(hi​−hj​)2,桥梁只能在柱子处相交&#xff0c;未安装桥的柱子需要拆除&#xff0c;代价为 wiw_iwi​&#xff08;可能为…

【牛客NOIP模拟】路径难题【建图】【最短路证明】

题意&#xff1a;一张 nnn 个点 mmm 条边的无向图&#xff0c;边带距离&#xff0c;可以坐出租车&#xff0c;花费为距离除以常数 rrr 向上取整&#xff1b;也可以坐公交车&#xff0c;每路车行驶路线给定&#xff0c;无论坐多少站花费都为 cic_ici​ &#xff08;每路车可能不…

Codeforces Round #595 (Div. 3) F. Maximum Weight Subset 树形dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; n≤200n\le200n≤200 思路&#xff1a; 明显的树形dpdpdp&#xff0c;所以考虑一下dpdpdp状态。 这个题状态挺神的。。可能是因为我太菜了&#xff0c;看了半天才看懂。 算法111: 复杂度O(n3)O(n^3)O(n3) …

利用ICSharpCore搭建基于.NET Core的机器学习和深度学习的本地开发环境

每个人都习惯使用Python去完成机器学习和深度学习的工作&#xff0c;但是对于习惯于某种特定语言的人来说&#xff0c;转型不是那么容易的事。这两年我花了不少时间在Python&#xff0c;毕竟工作的重心也从移动开发转为机器学习和深度学习。感谢我的老板给我很大的空间去开拓新…

【牛客NOIP模拟】牛半仙的妹子序列【DP】【Segment Tree Beats】

题意&#xff1a;排列的极长上升子序列个数 n≤2105n\leq 2\times 10^5n≤2105 显然有个 dp fn∑i<n,pi<pn,∄i<j<ns.t. pi<pj<pnfif_n\sum_{i<n,p_i<p_n,\nexists i<j<n\text{ s.t. }p_i<p_j<p_n}f_ifn​i<n,pi​<pn​,∄i<j&l…

Acwing 252. 树 点分治

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 好久没写淀粉质了&#xff0c;心血来潮复习一下。 淀粉质通常用来统计路径个数&#xff0c;将路径分为子树内的和子树之间的。子树内的递归处理&#xff0c;子树间的存下信息来每次都处理即…