近期研读一个开源代码,全部采用C语言编码,基本采用的是面向过程编程的思想。由于之前对于面向对象编程的思想已经有比较深刻的理解,这次在理解源代码的基础上,尝试着理解了下面向对象与面向过程的区别,见解肤浅,请指正。
个人认为,面向对象的思想侧重于数据与方法(函数)的内聚,优秀的面向对象架构下,类应该是高度内聚的,内聚不仅仅是方法,更重要的数据。而面向过程思想不关注数据是否内聚,只关注与过程本身。有人说,按模块来划分,各个模块也是内聚的啊。对,面向过程本身侧重于模块的内聚,但仅仅是方法(函数)功能的内聚。对于数据本身,更多的从整个过程来考虑的。
从数据流的角度,很容易理解两者的异同,对于同一个功能的编码,面向对象会将其分割为各个对象,将对象内聚化,对于全局的数据,在各个对象中由于面向对象的设计原则要求,无法传入无关数据,因此必然会有一个XXXManager类似main的一个类诞生,由它掌控整个数据流在各个对象之间的流转,拆分,组合等。当然现在有一些优秀的框架,可以把这个所谓的XXXManager隐藏起来。
而对于面向过程来说,由于程序更多的是考虑过程,将各个过程分割为各个模块,这样全局的数据流,就很清晰的在各个模块中流淌,直到最后完成此功能。
以上理解只是面向对象和面向过程编程的一个方面,无优劣区分,到底采用哪种编程方式,还是需要根据各个应用场景来选择。