Refactor!™ for ASP.NET--ASP.NET代码重构插件

news/2024/9/20 18:38:47
Teaching Demo: http://www.devexpress.com/Products/NET/IDETools/CodeRush/Training.xml

有些功能在JBuilder2005中早就有了。大家了解一下吧,比较不错。
 Refactor! is freely available to all ASP.NET 2.0 developers and offers a comprehensive suite of tools that enable you and your team to simplify and shape complex code and HTML markup - making your web applications easier to read and less costly to maintain.

Note to customers who have Refactor! Pro installed: this product is incompatible with your existing Refactor! Pro install. Please do not install Refactor! for ASP.NET alongside your existing installation. Instead, existing Refactor! Pro customers who are still within their free one-year maintenance update period can download at no charge an update to Refactor! Pro that includes these new ASP.NET refactorings. Just visit the Client Center https://www.devexpress.com/ClientCenter/. Those customers who purchased/upgraded Refactor! Pro more than a year ago will need to purchase a new maintenance upgrade to get these new refactorings.

Download Your Copy Now 
 
Simplify and Restructure Your Code
Making it Easier to Read and Less Costly to Maintain

Refactor!™ by Developer Express fuses a language-independent state-of-the-art code shaping engine with a revolutionary and highly-optimized user experience. Unlike other refactoring solutions that target the system architect, Refactor! is designed to help all developers craft and sculpt their code with the speed and efficiency needed to meet their line of business demands.

What is Refactoring?

Refactoring describes the process of making many small changes to working code, improving the internal structure without altering the external behavior of that code.

As an analogy, consider the math statement 2*4*5*3*1, you can covert this to 1*2*3*4*5 without changing its meaning and from there into 5!. They all mean the same thing but are increasingly easier to read. Refactor! does the same thing but with working source code.

There was a time not too long ago when just for fun developers would actually engage in obfuscated code competitions to produce the most difficult to read code. Well unfortunately there is a lot of code out there that is not much more readable than that intentionally obfuscated code - which is where refactoring comes in. The goal of refactoring is to take working code that is harder to read than it needs to be, and tweak its structure to make it more readable and more easily maintained.

.NET languages have been designed to self-document and encourage the development of readable, maintainable code - but even these languages code can grow organically over time and become cluttered and overly complex. Refactor! has numerous industry-first features that can help you take this complex code and make it easier to read and less costly to maintain.

Why Refactor!™

Refactor! does something no other tool can claim to do: it brings the power of an entire suite of refactoring tools to bear with just one key ("One Key Refactoring") and it works directly on your code in your editor - so you'll never have to leave your code just to restructure it.

Figure 1. One Key Refactoring - press CTRL+~ at any point to see all available refactorings with a short description of each.

Refactor! is built upon a language neutral architecture that offers exactly the same functionality for Visual Basic .NET and C# developers (beta support of C++ is also available). Refactor! even includes extensibility features to allow developers to easily build language-independent refactorings that can be used internally or shared with a growing community of highly satisfied Refactor! Pro customers.

Before we describe to you just a few of the over 50 refactorings available within the product, let us assure you that everything you can do with Refactor! can be rolled back using the standard Visual Studio Undo/Redo mechanism. So you really have the freedom to explore with this tool - simply hit CTRL+Z (or whatever key Undo is bound to) if the refactoring is not what you expected.


Refactoring: Reorder Parameters

Change the order of parameters in a Method signature, while also updating all calls to this method. Great when you need to change the parameter declaration order so that the most important parameters appear first, which will improve the usability of the method.

"Reorder Parameters" is probably the best example of how Refactor! is different, because the entire process is extremely visual and happens right there in your code. Here is how you reorder your parameters. Simply move the text cursor into the declaration of a method with parameters and this refactoring will be available. You can see that it is available if you stay there for a moment, because the refactoring smart tag will show up with a list of all the refactorings available. But you don't need to wait for anything - just hit the "One Key Refactoring" key (CTRL+~) and now you can move all your parameters left and right simply using the left and right cursor keys.

Figure 2. Reordering parameters directly upon code in the Editor - no modal dialogs to slow you down.

Refactoring: Rename

This refactoring renames a local variable or a private field, property or method. This refactoring affects both the declaration and any references within the class.

Choosing meaningful identifier names is one of the simplest ways to improve the readability of your code - Refactor! makes this process trivial. You simply put the text cursor into the identifier, and hit the "One key refactoring" key (CTRL+~), and start changing your identifier. You will see all references to your identifier highlighted with a light green box. You can now cycle through each call using the TAB and SHIFT+TAB keys, and if you change any one - the others all reflect the change.

Refactoring: Extract Method

The most sophisticated of all class based refactorings is probably "Extract Method". This refactoring allows you to select a piece of code from inside a method and extract it outside into a method of its own - while leaving a call to that new method in the code the method came from.

You are probably already several steps ahead of us in how to activate this refactoring by now; You simply select some code, put the text cursor in the code, hit the "One Key Refactoring" key (CTRL+~), and now you have a new method containing your block of code, with a call where that code came from.

Consider this example code which calculates the volume of a cylinder. Suppose we decide to extract the code that calculates the area of a circle to a method of its own, for later reuse. To do this all we do is select the specific block of code and hit the "One key Refactoring" (CTRL+~), the code is cut from the source method, and we are prompted for a location for the target method.

Figure 6. You can place the extracted method precisely using the red Target Picker.

Once we have chosen the location for the new method, Refactor! calculates how many parameters need to be passed, creates some default names for the new method and any parameters, generates the code for the new method and calls it, and finally invokes the "Rename" refactoring in case we wish to override any of the default names chosen.

Figure 7. The fully extracted method - Refactor has determined parameters to pass and even come up with a meaningful name.

You know there is actually an even faster way to extract. Select the code - Cut the code - Paste it outside the Method but inside the class and Refactor! will extract the method for you automatically.

Notice that the method name and the call are both linked with green boxes - the "Extract Method" has automatically invoked the "Rename" refactoring for you. Also if there are any variables referenced outside as well as inside the block you selected, then Refactor! will automatically give your new method the appropriate parameters to pass in that data and if needed pass it back.

Over 50 Built-in Refactorings

When it comes to scope, breadth, and ease-of-use, no other product in the market even comes close to Refactor! It would be impossible to describe each of the 50+ refactorings in detail within this white paper and so we wont try – but to whet your appetite, here are a few others worth consideration.

Compress to ternary expression / Expand ternary expression
Converts an if/else conditional with assignments in each branch into a ternary expression, or expands a ternary expression into an if/else block.

Widen scope
Moves a variable declaration up and out in scope.

Flatten conditional
Unindents the If or Else statement for a conditional. This will apply one of the following refactorings: Replace Nested Conditional with Guard Clause, Remove Redundant Else, or Reverse Conditional followed by Remove Redundant Else. Flatten conditional is also smart enough to recognize "if (E) return true; else return false;" and convert that condition to simply "return E;".

Simplify expression
Resolves a complex expression to its simplest form.

Combine conditionals
Combines two or more neighboring conditionals with identical bodies into a single conditional statement where each conditional expression is logically OR'd.

Create method contract
Creates a contract for the current method, verifying that parameters are valid.

Inline result
Replaces final assignments to the temporary variable with a statement that immediately returns the value, removing the temporary variable if possible.

Move type to file
Creates a new file with the same name as the type at the caret, adds the file to the project, and then moves the type to that file, along with any leading comments, attributes, and XML doc comments. This refactoring is available when the caret is on a type declaration and the file contains two or more types.

Use String.Format
Converts a composed string expression into a single String.Format call.

Use StringBuilder
Replaces these string concatenation operations with method calls on a local StringBuilder instance to improve performance (working with a StringBuilder is faster than concatenating strings).

Optimize namespace references
Removes unused namespace references (using/imports statements in VB and C#, and unused #include files in C++).

转载于:https://www.cnblogs.com/RuiLei/archive/2007/02/15/651036.html

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

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

相关文章

电源系统优化设计,低压差稳压器(LDO)如何选型?

目录 1、压差 2、裕量电压 3、静态电流和接地电流 4、关断电流 5、效率 6、直流负载调整率 7、直流输入电压调整率 8、直流精度 9、负载瞬态响应 10、线路瞬态响应 11、电源抑制 12、PSRR 与频率的关系 13、PSRR 与负载电流的关系 14、PSRR与LDO裕量的关系 15、…

PCL:从法线计算到曲率计算并可视化

----------------法线求解原理-------------- 表面法线是几何体表面的重要属性,在很多领域都有大量应用,例如:在进行光照渲染时产生符合可视习惯的效果时需要表面法线信息才能正常进行,对于一个已知的几何体表面,根据…

LabVIEW纹理分析(基础篇—9)

纹理(Texture)是物体表面固有的特征之一。目前对于纹理尚无正式的定义,但一般认为它是由许多相互连接且常周期性重复的单元构成。与灰度特征不同,纹理不是基于单个像素点的特征,它通常与图像的尺度关系密切&#xff0c…

PCL:超详细的基于法向量和曲率的区域生长算法原理以及源码解读

---------原理介绍: (1)首先计算出来各点的曲率值,将曲率值按照从小到大的顺序进行排序。 (2)设置一空的种子点序列和一个空的聚类数组。 (3)选取曲率最小的点放入上述种子点序列…

万万没想到,低功耗也会烧毁元器件?

今天读到一篇ADI期刊中的故障解决,虽然这种问题在如今芯片设计时已经考虑到并解决,但也非常有意思,分享给各位朋友。 问题: 我更换了一个更新更好的稳压器,具有更低的电流损耗。结果发生故障,稳压器甚至烧…

和12岁小同志搞创客开发:有意思的激光切割技术

目录 1、选材标准 2、设计软件 3、设计流程 机缘巧合在网上认识一位12岁小同志,从零开始系统辅导其创客开发思维和技巧。 项目专栏:https://blog.csdn.net/m0_38106923/category_11097422.html 青少年创客在设计开发产品后难免要做外型工装&#xff…

AJAX ControlToolkit学习日志-ModalPopupExtender(16)

ModalPopupExtender控件用于设置网页上文本的样式。下面看一个示例&#xff1a;1)在Vs2005中新建一个ASP.NET AJAX-Enabeld Web Project项目工程&#xff0c;命名为ModalPopupExtender1。2)在Default.aspx中的<div/>标签中添加一段文字。再添加一个LinkButton控件&#x…

隐马尔可夫(HIdden Markov Model)1:隐马尔可夫模型(HMM)背景介绍

首先引入两个概念&#xff1a;1.频率派&#xff08;后来逐渐发展称为统计机器学习&#xff0c;其核心问题就是优化问题&#xff0c;把他的loss function定义出来&#xff0c;求解&#xff09; 2.贝叶斯派&#xff08;后来发展为概率图模型&#xff0c;最终是要做推断&#x…