翼度科技»论坛 编程开发 .net 查看内容

C#代码重构的几个典型案例

5

主题

5

帖子

15

积分

新手上路

Rank: 1

积分
15
前段时间小编检查同事代码,发现居然写的太复杂看不太懂,代码命名不规范,重复冗长代码一堆,这时候就可以通过重构来改进代码的质量。代码重构是提高代码质量和可维护性的关键过程,它旨在通过优化代码结构和设计来提高代码的可读性、可理解性和可扩展性。本文讲述在C#中重构代码的几个案例,供大家参考。
1、命名清晰明确规范
良好的命名是代码可读性和可维护性的关键。确保使用有意义和描述性的名称来表示变量、方法和类等元素。遵循一致的命名规范,例如使用驼峰命名法或帕斯卡命名法,并根据约定来命名不同类型的元素。比如如下案例:
  1. // 知道这是啥意义吗?
  2. int a = 10;
  3. // 从名字中可以看出是代表年龄
  4. int age = 10;
复制代码
2、减少重复代码
避免在代码中出现重复的逻辑和结构。重复代码不仅增加了代码量,还增加了维护的困难度。比如下列案例:
  1. //下面两个属性明显有重复
  2. public class Product
  3. {
  4.     public Bool IsDeleted{ get; set; }
  5.     public DateTime UpdateTime{ get; set; }
  6.     public DateTime CreateTime{ get; set; }
  7.     // 其他属性和方法...
  8. }
  9. public class Order
  10. {
  11.     public Bool IsDeleted{ get; set; }
  12.     public DateTime UpdateTime{ get; set; }
  13.     public DateTime CreateTime{ get; set; }
  14.     // 其他属性和方法...
  15. }
  16. //可以改造一下 ,定义一个基类继承
  17. //甚至可以把创建修改时间写一个公告方法
  18. public class BaseEntity
  19. {
  20.     public Bool IsDeleted{ get; set; }
  21.     public DateTime UpdateTime{ get; set; }
  22.     public DateTime CreateTime{ get; set; }
  23. }
  24. public class Product : BaseEntity
  25. {
  26.     // Product 特有的属性和方法...
  27. }
  28. public class Order : BaseEntity
  29. {
  30.     // Order 特有的属性和方法...
  31. }
复制代码
3、使用合适的数据结构和类型
使用合适的数据结构和类型可以提高代码的运行效率,可以减少开发过程中的错误率等。示例代码:
  1. // ArrayList涉及到装箱拆箱问题,不推荐使用
  2. ArrayList list = new ArrayList();
  3. list.Add("张山");
  4. list.Add("王五");
  5. list.Add("12");
  6. // List规避了这一问题,并且性能大增。
  7. List<string> list = new List<string>();
  8. list.Add("张山");
  9. list.Add("王五");
  10. list.Add("12")
复制代码
4、拆分复杂的条件语句
过于复杂的条件语句让后续开发者难以阅读代码,让代码出错的几率增大,并且增加了代码的维护难度。改进方法是拆分条件语句。案例如下:
  1. public bool CheckAccess(string role, List<string> permissions)
  2. {
  3.     if ((role == "Admin" && permissions.Contains("Create")) ||
  4.         (role == "Manager" && (permissions.Contains("Edit") || permissions.Contains("Delete"))) ||
  5.         (role == "User" && permissions.Contains("View")))
  6.     {
  7.         return true;
  8.     }
  9.     else
  10.     {
  11.         return false;
  12.     }
  13. }
  14. //改进
  15. public bool CheckAccess(string role, List<string> permissions)
  16. {
  17.     if (role == "Admin" && permissions.Contains("Create"))
  18.     {
  19.         return true;
  20.     }
  21.     if (role == "Manager" && (permissions.Contains("Edit") || permissions.Contains("Delete")))
  22.     {
  23.         return true;
  24.     }
  25.     if (role == "User" && permissions.Contains("View"))
  26.     {
  27.         return true;
  28.     }
  29.     return false;
  30. }
  31. //改进后每条代码更加清晰简单,提高了代码的可读性。
复制代码
5、拆分长方法
长的方法增加代码的难度,代码的可读性和维护性变差,并且不利于测试。改进方式是拆分长方法。案例如下:
  1. // 长方法
  2. public void ProcessData()
  3. {
  4.     // 长方法代码块
  5.     // 计算杨辉三角逻辑
  6.     // 查询当前IP地址逻辑
  7.     // 查询天气预报的逻辑
  8. }
  9. // 好的方式
  10. public void ProcessData()
  11. {
  12.     //计算杨辉三角方法
  13.     ProYangHuiTriangle();
  14.     //查询当前IP地址方法
  15.     GetHttpIp();
  16.     //查询天气预报的方法
  17.     GetWeather();
  18. }
  19. private void ProYangHuiTriangle()
  20. {
  21.     //计算杨辉三角逻辑
  22. }
  23. private void GetHttpIp()
  24. {
  25.     //查询当前IP地址逻辑
  26. }
  27. private void GetWeather3()
  28. {
  29.     //查询天气预报的逻辑
  30. }
  31. //经过这样拆分改造,让方法更加简单明了,可读性更强,并且易于维护测试
  32. //欢迎关注公众号:DOTNET开发跳槽,领取海量面试题。
  33. //加微信号xbhpnet入群交流技术和跳槽
复制代码
结语
本文讲述了几个代码重构的案例,希望对大家的代码重构有所帮助。那么到底需要代码重构吗?你有代码重构的案例吗?欢迎留言讨论或吐槽。
  1. 来源公众号:DotNet开发跳槽
复制代码
来源:https://www.cnblogs.com/xbhp/archive/2023/07/17/17559765.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具