当前位置:网站首页>Sonar:Cognitive Complexity认知复杂度
Sonar:Cognitive Complexity认知复杂度
2022-07-07 10:01:00 【沛沛老爹】
背景
在进行代码扫描的时候,发现使用sonar,会提示“Refactor this method to reduce its Cognitive Complexity from 31 to 15 allowed等类似的提示。
翻译成为中文就是:重构方法,以将代码认知复杂度从31降到15。
简单点来理解,就是当前代码的点认知复杂度有点高,对阅读不友好,建议将其代码进行重构。
Cognitive Complexity
Cognitive Complexity翻译成中文就是认知复杂度。
简单来讲就是代码被阅读和理解的复杂程度的一个度量方法,讲代码按照固定的 方式转化成复杂程度的数值。
认知复杂度数值越高,说明这段代码越复杂!
记分示例
这里给出一个很有用的例子,可以指出圈复杂度的问题。以下两段方法有着相同的圈复杂度,但是在理解难度上差非常多:

认知复杂度简单规则
- 代码中用到一些语法糖,把多句话缩为一句,但是代码不会变得更复杂
- 出现"break"中止了线性的代码阅读理解,如出现循环、条件、try-catch、switch-case、一串的and or操作符、递归,以及goto类跳转,因此代码因此更复杂
- 多层嵌套结构使得代码因此更复杂
认知复杂度评分规则
忽略简写:把多句代码缩写为一句可读的代码,不改变理解难度;
在认知复杂度的制定想法中,一个指导性的原则是:激励使用者写出好的编码规范。也就是说,需要无视或低估让代码更可读的feature(不计算进复杂度)。
“方法”本身就是一个朴素的例子,把一段代码拆的把几句抽离成一个方法,用一句方法调用代替掉,“简写”它,认知复杂度不会因为这这一次方法调用增加。
同样的,认知复杂度也会忽略掉null-coalescing操作符,x?.myObject这样的操作符不增加复杂度,因为这些操作同样是把多段代码缩写为一项了
对线性的代码逻辑中,出现一个打断逻辑的东西,难度+1;
在认知复杂度的制定想法中,另一项指导原则是:结构控制会打断一条线性的流从头到尾走完,使代码的维护者需要花更大功夫来理解代码。在认定了这会导致额外负担的前提下,认知复杂度评估了以下几种会增加Structural类复杂度:
循环: for, while, do while, ...
条件: 三元运算符, if, #if, #ifdef...
另外,以下这种会计处Hybrid类复杂度:
else if, elif, else, ...
但不计入Nesting类复杂度,因为这个量在计算之前的if语句时已经计过了。
这些增加复杂度,其实和圈复杂度的计算方式非常像,但是额外的,认知复杂度还会计算
当打断逻辑的是一个嵌套时,难度+1;
与连续嵌套的五个结构比,线性连续的五个if\for结构要好理解得多。因为这样的嵌套会增加理解代码的成本,所以认知复杂度在计算时会将其视为一个Nesting类复杂度增加。
特别地,每一次有一个导致了Structural类或Hybrid类复杂的结构体,嵌套了另一个结构时,每一层嵌套都要再加一次Nesting类复杂度。
进一步说,复杂度得分是来源于以下几种不同的类型:
A. Nesting:把一段代码逻辑嵌套在另一段逻辑中;
B. Structural:被嵌套的控制流结构;
C. Fundamental:不受嵌套影响的语句;
D. Hybrid:一些控制流结构,但不包含在嵌套中;
然而不同类型在数学上没有区别,都只是对复杂度加一。在要计算的不同类别之间进行区分,可以更轻松地了解某一处是否适用嵌套的逻辑。以下各节将进一步详细说明这些规则及其背后的原理。
如果你对它有更好的兴趣,你可以看下官方的介绍文档:https://www.sonarsource.com/docs/CognitiveComplexity.pdf
边栏推荐
- Cmu15445 (fall 2019) project 2 - hash table details
- 问下flinkcdc2.2.0的版本,支持并发,这个并发是指多并行度吗,现在发现,mysqlcdc全
- Ask about the version of flinkcdc2.2.0, which supports concurrency. Does this concurrency mean Multiple Parallelism? Now I find that mysqlcdc is full
- 【数据聚类】基于多元宇宙优化DBSCAN实现数据聚类分析附matlab代码
- Flet教程之 17 Card卡片组件 基础入门(教程含源码)
- STM32入门开发 NEC红外线协议解码(超低成本无线传输方案)
- C#中在路径前加@的作用
- Use references
- Common SQL statement collation: MySQL
- MATLAB實現Huffman編碼譯碼含GUI界面
猜你喜欢

SwiftUI Swift 内功之如何在 Swift 中进行自动三角函数计算

Fleet tutorial 14 basic introduction to listtile (tutorial includes source code)

About how to install mysql8.0 on the cloud server (Tencent cloud here) and enable local remote connection

5V串口接3.3V单片机串口怎么搞?

What development models did you know during the interview? Just read this one

核舟记(一):当“男妈妈”走进现实,生物科技革命能解放女性吗?

【数据聚类】基于多元宇宙优化DBSCAN实现数据聚类分析附matlab代码

Camera calibration (1): basic principles of monocular camera calibration and Zhang Zhengyou calibration
![[data clustering] realize data clustering analysis based on multiverse optimization DBSCAN with matlab code](/img/83/0652e3138b87a4741dd8261a24d1e8.png)
[data clustering] realize data clustering analysis based on multiverse optimization DBSCAN with matlab code

【滤波跟踪】基于matlab捷联惯导仿真【含Matlab源码 1935期】
随机推荐
《通信软件开发与应用》课程结业报告
112.网络安全渗透测试—[权限提升篇10]—[Windows 2003 LPK.DDL劫持提权&msf本地提权]
【滤波跟踪】捷联惯导纯惯导解算matlab实现
Visual Studio 2019 (LocalDB)\MSSQLLocalDB SQL Server 2014 数据库版本为852无法打开,此服务器支持782版及更低版本
About how to install mysql8.0 on the cloud server (Tencent cloud here) and enable local remote connection
[full stack plan - programming language C] basic introductory knowledge
[encapsulation of time format tool functions]
大佬们有没有人遇到过 flink oracle cdc,读取一个没有更新操作的表,隔十几秒就重复读取
从工具升级为解决方案,有赞的新站位指向新价值
Superscalar processor design yaoyongbin Chapter 8 instruction emission excerpt
Rationaldmis2022 advanced programming macro program
Internet Protocol
人大金仓受邀参加《航天七〇六“我与航天电脑有约”全国合作伙伴大会》
Technology sharing | packet capturing analysis TCP protocol
sql里,我想设置外键,为什么出现这个问题
《论文阅读》Neural Approaches to Conversational AI(1)
HCIA复习整理
SwiftUI Swift 内功之 Swift 中使用不透明类型的 5 个技巧
How to write test cases for test coupons?
.NET MAUI 性能提升