嵌入式开发框架之模块化编程思想

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/MINGTING1323/article/details/100173420
好久没更新播客了,最新想写些自己的编程方面想法。也就是些自己的想法,不一定准确,在这希望能和大家分享下。

相信大家在大学的时候都学过程序遵循的标准是“低内聚高耦合”。但到了实际工作中当中却往往容易放开手脚,代码写着写着就乱了。不经后续维护不方便,就是自己也不知道当初为啥这么写。低内聚高耦合的代码需要遵循以下原则:

降低耦合度的方法

1、 多使用模块化编程的思想,在编写之初,模块需要做什么功能、以后需要做哪些扩展,需要长时间的考虑。

2、模块的功能化分尽可能的明确。也可以参考生成动态库的原则,删除一个模块(在不调用的情况下)不影响到程序的正常运行。同时暴露出清晰的接口方便其他人调用。

3、尽量少使用全局变量。除了设备配置外,尽量不要使用其他全局变量。模块内可使用仅在模块内有效的变量,引出接口供其他地方使用。

4、同时遵循一个定义只在一个地方出现。

5、多用设计模式,比如采用MVC(模型-视图-控制)的设计模式就可以降低界面与业务逻辑的耦合度。

6、少使用类的继承,类属性和方法的声明少用public,多用private关键字。多用接口隐藏实现的细节。

 

增强内聚度方法

1、模块只对外暴露最小限度的接口,形成最低的依赖关系。

2、只要对外接口不变,模块内部的修改,就不得影响其他模块。

3、删除一个模块,应当只影响有依赖关系的其他模块,而不应该影响其他无关部分。

 

模块化的原则

我的原则是无论是做哪方面的程序设计,在前期规划之前,即便花很久的时间,也需要细化为几个方面。把复杂的问题分解为单独的模块后。个人认为模块化设计应该遵循以下几个主要原则:

1.模块的功能要尽可能独立,模块的对外接口要清晰明了。

模块的独立性原则表现在模块完成独立的功能,与其他模块的联系应该尽可能得简单,各个模块具有相对的独立性。

2.模块的规模要适当。

模块的规模不能太大,也不能太小。如果模块的功能太强,可读性就会较差,若模块的功能太弱,就会有很多的接口。太小的模块尽量做成工具类的接口,除了方便以后使用还能简化代码。如果模块功能太强,尽量做到模块的分解(见第三点)。模块功能尽量使用回调或是switch case的嵌套来实现。这样后续开发人员可以在不读懂全部代码的情况下,也能进行有效的维护或是扩展,同时又不对其他分支功能造成影响。

3.分解模块时要注意层次

在进行多层次任务分解时,要注意对问题进行抽象化。在分解初期,可以只考虑大的模块,在中期,再逐步进行细化,分解成较小的模块进行设计。 
————————————————
版权声明:本文为CSDN博主「mingting1323」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/MINGTING1323/article/details/100173420

你可能感兴趣的:(嵌入式)