【IT168 技术文章】
一、提出问题
1.树状遍历式寻找问题
每个问题都不是单一存在的,它都有相关问题,犹如一棵树一样,主问题就是主树杆,主问题伴随的其他问题,就是支树杆,以次类推。首先不要怕麻烦,每当一个问题提出,必须提出尽量多的相关新问题。提出问题的方法:顺藤摸瓜。
比如:写一个通用编辑器程序,此程序为自己或别人开发其他专业编辑器打下可靠稳定的基础。
1)问题:什么是通用编辑器。编辑器面向的对象应该是不确定的。
2)如果数据类型不确定,我们如何确定程序编写的对象。可以举出一些可能的假设。假设我们将此通用编辑器用作程序源代码编辑,那么就应该有中断、单步执行等设置,这导致数据不能封装在编辑器内部,应该由后期开发指定数据结构。
3)如果是程序编辑器,关键字的特显必不可少,所以显示的属性应该给出接口。
4)诸如关键字此类的是否还有其他需要特显的,那么,应该注意到特显类不仅仅是一种,程序设计时,最好抽象出特显的方法与数据结构(不管以后有多少不可预知的特显内容)。可以深入考虑特显接口应该如何给出,才能支持任意特显方式,它还需要哪些信息。
5)抽象特显类时,应该举出尽量多的可能性,综合考虑。
6)问题:哪些内容需要特显。编辑器很难知道,数据类应该自己了解。所以,特显内容的定义必须有一个机制让后期开发时使用。
7)问题:源代码编辑器有自动缩排、词法、语法分析,这些操作如何在编辑器中体现。考虑语法类接口。是否有收缩与展开操作,接口又如何。
8)又假设:后期要扩展成字处理程序。数据有文本、图象、特殊公式编辑、段落概念、表格等。
9)送进编辑器的数据可能是一组含有控制字的数据,问题:如何获得让编辑器知道不同数据的不同显示操作。编辑器肯定无法全知,所以,干脆交给后期开发需求处理。
10)未知数据应该有:显示方法、光标定位处理等
11)光标定位需要当前坐标,所以,必须有接口让编辑器知道数据宽高。
12)综合结论:应该有一个接口机制。凡特殊操作的内容,交给后期处理,但通用编辑器应该做好数据管理和传送的工作,而这些工作,不管哪种编辑器都需要。
首先任其深入提问,虽然问题可能多得十分复杂或凌乱,但它对即将做的系统设计绝对有帮助,最好把每个问题都有一个清楚的了解,千万不要急于设计系统。通过这些提问和假设,就可清楚地分析我们所作的软件应该实现哪些内容,哪些内容实现有难度,实现这些内容的大体方法,通用编辑器能作什么。通过上列系列提问和解答,我们可以认为,通用编辑器仅仅是一个以行为基本编辑单位的编辑器摸板。编辑器不仅自己有编辑操作,同时允许外部提供特殊数据对象的编辑操作,最终实现文本编辑、图形编辑、表格编辑、公式编辑一体化。数据外部实现,将允许后期确定内容属性。
上述方法基本上确保了软件有好的可靠性、扩展能力、性能、重用性和系统化。想高效率生产系列软件,确实应该考虑的更多。