当前位置:网站首页>Method of code refactoring -- Analysis of method refactoring
Method of code refactoring -- Analysis of method refactoring
2020-11-06 21:35:00 【Irving the procedural ape】
The method of code refactoring —— Method reconstruction analysis
Intro
Want to write better code , You need to be alert to bad smells in your code , Today I want to write an article about how to analyze whether your method needs to consider refactoring
A method usually consists of three parts , Input (Input), Output (Output), Method body (Method Body), We will analyze whether a method should consider refactoring from these three aspects
Input
Method input is the parameter of the method , Generally speaking, the parameters of a method can be basically controlled in 7 Within a ( For reference only , You can measure it by yourself ,SonarQube The default method has up to seven parameters ), If your method has too many parameters , You may need to consider refactoring a method parameter , The usual practice is to encapsulate a separate model, Parameters as model Properties of .
Take a common example , Like a news list API, It can be very simple at first , Just one lastId, One count Two parameters , But as business needs increase , Many other parameters may be added , For example, the front end provides a keyword Full text search , Provide a sortBy Sort , Match the news headlines , Author name matches , Classification matching , Filter according to the release time and so on , In the end, there may be many parameters for this method
Usually I add a new one XxxRequest Of model, Then replace the method parameter with this model, Then designate [FromQuery] That's all right. , You can compare the difference before and after a modification , Is the latter way more refreshing
Task<IActionResult> List(int lastId, int count, string title, string author, string keyword, int categoryId, string sortBy, DateTime? beginTime, DateTime? endTime)
Task<IActionResult> List([FromQuery]NewsListQueryRequest request)
Output
Output Is the return value of the method , Return as many specific types as possible , Try to avoid using Tuple Other types , The return value of the method should have a clear meaning
Use specific Model Instead of Tuple Return value , Especially some public Of , Methods to be accessed externally should return specific types , although C# 7.2 Started to support named tuple, It's going to be a lot more friendly than before , Support to tuple Specify a name , But it's just compiler level , Actually, it's still Item1,Item2 ..., It is recommended to use specific ones model, More clearly
Body
Usually a method is not too long , I saw a group of friends make complaints about more than 2000 ways in the group , This is a disaster to maintain , Don't make a method too long , Keep the cube simple , Some general logic goes through Filter Or combine AOP To achieve
Sonar There is a way to analyze the complexity of a method , Officially called Cognitive Complexity
A brief introduction , In code if/switch/for/foreach/try...catch/while Will increase the complexity of the method , If there is a layer of nesting, the complexity will be increased 1, Sonar The default complexity of a method cannot exceed 15
Here are a few simple examples :
The complexity of the following method is 3, There are three if(else) Branch
版权声明
本文为[Irving the procedural ape]所创,转载请带上原文链接,感谢
边栏推荐
- Will blockchain be the antidote to the global epidemic accelerating the transformation of Internet enterprises?
- (2) ASP.NET Core3.1 Ocelot routing
- 【涂鸦物联网足迹】涂鸦云平台全景介绍
- 上海巨微专用蓝牙广播芯片
- 2020-09-03:裸写算法:回形矩阵遍历。
- How to manage the authority of database account?
- Python basic variable type -- list analysis
- Summary of front-end performance optimization that every front-end engineer should understand:
- Zero basis to build a web search engine of its own
- Why is the LS command stuck when there are too many files?
猜你喜欢

Metersphere developer's Manual

How about small and medium-sized enterprises choose shared office?

Python basic variable type -- list analysis

Novice guidance and event management system in game development

Building a new generation cloud native data lake with iceberg on kubernetes

Zero basis to build a web search engine of its own

How much disk space does a new empty file take?
![What grammar is it? ]](/img/3b/00bc81122d330c9d59909994e61027.jpg)
What grammar is it? ]

Take you to learn the new methods in Es5

【涂鸦物联网足迹】涂鸦云平台全景介绍
随机推荐
The isolation level of transaction and its problems
In depth to uncover the bottom layer of garbage collection, this time let you understand her thoroughly
Multi robot market share solution
2020-08-30:裸写算法:二叉树两个节点的最近公共祖先。
Helping financial technology innovation and development, atfx is at the forefront of the industry
This project allows you to quickly learn about a programming language in a few minutes
What the hell is fastthreadlocal? The existence of ThreadLocal!!
【学习】接口测试用例编写和测试关注点
Those who have worked in China for six years and a million annual salary want to share these four points with you
Road to simple HTML + JS to achieve the most simple game Tetris
Swagger 3.0 brushes the screen every day. Does it really smell good?
Zero basis to build a web search engine of its own
Kubernetes and OAM to build a unified, standardized application management platform knowledge! (Internet disk link attached)
STM32F030F4P6兼容灵动微MM32F031F4P6
es创建新的索引库并拷贝旧的索引库 实践亲测有效!
行为型模式之备忘录模式
PHP application docking justswap special development kit【 JustSwap.PHP ]
GitHub: the foundation of the front end
Basic usage of Vue codemirror: search function, code folding function, get editor value and verify in time
Flink's datasource Trilogy: direct API