面向过程程序设计(结构化程序设计)的不足
结构化程序设计也叫面向过程的程序设计,它和面向对象的程序设计是相对的。
结构化程序设计的基本思想是自顶向下、逐步求精,即将复杂的大问题层层分解为许多简单的小问题的组合。整个程序被划分成多个功能模块,不同的模块可以由不同的人员进行开发,只要合作者之间规定好模块之间相互通信和协作的接口即可。
例如,一个大型的网络游戏可以分成动画引擎、地图绘制、人工智能策略、游戏角色管理、用户账户管理、网络通信协议等诸多模块。不同模块可以分别由不同的小组开发,每个模块都要对外提供一个接口(一般就是函数和全局变量的集合),以便其他模块能够调用自己提供的功能。
例如,人工智能策略模块可能会提供在地图上寻找路径的功能,地图绘制模块需要提供查询道路和障碍物、建筑物位置的功能,这个功能会被人工智能策略模块中的寻找路径子模块调用,游戏人物需要前进时,就会调用人工智能策略模块提供的寻找路径的函数来决定下一步如何行走。
计算机界最高奖“图灵奖”得主、Pascal 语言发明人沃斯教授有一个著名的公式,就是:
数据结构 + 算法 = 程序
这精辟地概括了结构化程序设计的特点。数据结构和变量相对应,算法和函数相对应,算法是用来操作数据结构的。
在结构化程序设计中,算法和数据结构是分离的,没有直观的手段能够说明一个算法操作了哪些数据结构,一个数据结构又是由哪些算法来操作的。当数据结构的设计发生变化时,分散在整个程序各处的、所有操作该数据结构的算法都需要进行修改。
结构化程序设计也没有提供手段来限制数据结构可被操作的范围,任何算法都可以操作任何数据结构,这容易造成算法由于编写失误,对关键数据结构进行错误的操作而导致程序出现严重问题甚至崩溃。
结构化程序设计也称为面向过程的程序设计。过程是用函数实现的。因此,结构化程序设计归根到底要考虑的就是如何将整个程序分成一个个函数,哪些函数之间要互相调用,以及每个函数内部将如何实现。
此外,结构化程序设计难免要使用一些全局变量来存储数据,如一个网络游戏一般会以一些全局变量来记录当前战场上有多少个玩家,每个角色在地图上的位置等。这些全局变量往往会被很多函数访问或修改,如选择角色前进路径的函数可能就会需要知道当前地图上有哪些敌人以及敌人的位置。
在程序规模庞大的情况下,程序中可能有成千上万个函数、成百上千个全局变量,要搞清楚函数之间的调用关系,以及哪些函数会访问哪些全局变量,是很麻烦的事情。
下图所示为结构化程序的模式,Sub 代表一个个函数,箭头代表“访问”或“调用”。
发表评论