在wiki上,software framework的解释是In computer programming, a software framework is an abstraction in which common code providing generic functionality can be selectively overridden or specialized by user code, thus providing specific functionality. Frameworks are a special case of software libraries in that they are reusable abstractions of code wrapped in a well-defined Application programming interface (API), yet they contain some key distinguishing features that separate them from normal libraries.
上文对软件框架的解释中,比较重要的概念是抽象,封装,继承和重写,同面向对象语言的特征很接近,那么,如何才能确定或者积累一套框架呢?一个高质量的框架的标准是什么呢?为了解答上述两个问题,先分析一下框架的目的是什么?
当公司接到第一个项目时,可以没有框架,某个程序员直接用SSH搭建起来,然后实现合同中的系统功能,达到用户要求,便可以交差了,实现系统功能的时间一般很短,大概占项目时间的三分之一到四分之一,而大量时间却浪费在了完善阶段,为什么一个项目时间会浪费在完善上,举一个例子,当项目系统功能开发完成时,用户提了一个小要求,某几个功能的名称需要修改一下,这种看似简单的小问题,如果当初程序员为了偷懒,把这些名称硬写到页面中的话,而恰恰这个名称涉及30个页面,程序员杯具了,他需要一两天的时间修改,如果用户不客气,一下子提出十几个类似这样的小问题,项目经理杯具了,项目可能需要延期一个月完善并测试。
我想,很多起初做项目的朋友,都会遇到类似这样的问题,用户反复的提出一些让你没法拒绝的意见,全部都是该名称、换位置、调颜色、换图片等搬砖工作,程序员一遍一遍的修改一些技术含量为零的需求,测试人员需要不厌其烦的一遍一遍测试,项目成本也在悄无声息的增加。最后,老板一拍桌子,大喊一声“XXX,当初说项目两个月完工,为什么做了四个月?”程序员大喊一声:“XXX,爷不干了,天天变来变去的,有完没完啊?”项目经理最后只能以离职收场。
解决上述问题很简单,就是利用框架中的第二个概念——封装,所有的重复代码、变量,包括java、javascript、html,全部封装起来,如果是个性化变量及配置,可以考虑配置文件,即使是批量改,也要集中到一个地方修改,这就是配置文件的重要作用之一。
框架的第一个目的,简单来说,就是方便控制项目时间。对于用户来说,小的意见总是会有的,而且这些意见也是让你无法拒绝的。对于项目经理来说,项目需要修改时,大的漏洞并不可怕,因为他直观,并且单一,例如性能问题,安全问题,这些是硬伤,解决一次就能完成任务,而且有理由延期或者签订补充合同。而如何能简单快速修改项目中没有技术含量的小问题,才是成本控制的关键,因为用户需求是不可控制的,只能控制修改问题的时间。
(未完待续)
分享到:
相关推荐
WEB 框架是指一种基于 WEB 的应用程序框架,提供了一整套的解决方案,帮助开发者快速地开发出功能强大、美观的 WEB 应用程序。WEB 框架通常包括了各种组件,如服务器端语言、数据库、缓存机制等,并提供了丰富的工具...
SSM框架,全称Spring、SpringMVC和MyBatis,是Java开发中常用的一种Web应用框架组合。这个框架集合了Spring的IOC(Inversion of Control,控制反转)和AOP(Aspect Oriented Programming,面向切面编程)功能,...
【标题】"一种开源业务系统框架winform源码"揭示了这是一个基于Windows Forms(Winform)的开源软件开发框架,专用于构建业务系统。Winform是.NET Framework中的一个UI库,用于创建桌面应用程序,它提供了丰富的用户...
首先,我们需要回答几个问题,以确定我们为什么要写一个框架,什么是我们的框架,谁是我们的用户对象,如何维护和发展我们的框架等等。这一步骤被称为定位。只有在明确了我们的目标和方向后,我们才能开始设计和开发...
J4ME-开源的 UI Logger 项目是一个 J2ME 应用程序开发包,它包括一个 UI 框架、一个日记框架用于帮助调试因不同品牌手机的差异而产生的问题。 5. OpenBaseMovil OpenBaseMovil 是一个 J2ME 应用程序开发框架,包括...
flex框架之Cairngorm框架,包括Cairngorm框架
AT指令解析框架是一种用于处理和解析AT(Attention)指令的软件工具,广泛应用于通信设备,如GSM/GPRS模块、蓝牙模块、Wi-Fi模块等。AT指令是串行通信中的控制命令,允许用户通过简单的文本命令与硬件进行交互,设置...
“blue_ganjing”可能是这个框架的主题名称或者是压缩包内的一个目录,暗示了该框架可能包含一种蓝色调的精美设计,或者“甘镜”可能是设计风格的一种代称,寓意清晰、高雅。 在使用此类HTML后台界面框架时,开发者...
可通信状态机(CSM)是一个基于JKI状态机(JKISM)的LabVIEW应用框架。它遵循 JKISM 的模式,扩展了关键词以描述模块之间的消息通信,包括同步消息、异步消息、状态订阅/取消订阅等概念! 可通信状态机(CSM)是一个...
gdi+游戏框架这是一个用vc6.0写的Win32游戏框架.当然,这算不上引擎.该源码付带了一个简单的粒子系统,用来模拟雪花测试.因为用了png图片绘制雪花,所以得到平均每秒也只有32帧.对于2D游戏来讲够了.如果用透明渐变的话...
【标题】: "一个初级入门的框架,简洁实用" 这个标题揭示了我们正在讨论的是一款专为初学者设计的框架,它的主要特点是简洁且实用。对于刚接触编程或框架技术的人来说,这样的框架提供了易于理解的基础,使他们能够...
一款轻量级的Delphi通用系统UI框架,基于MlSkin皮肤组件构建 功能特性(Feature): 框架UI界面设计简洁、轻量、时尚和风格统一,代码一看就懂,容易上手和维护 框架代码部分采用模块化设计,代码之间的耦合度低,旧...
框架结构一榀框架手算计算书.doc
本篇将深入探讨一个基于Java的简单校验框架的实现,该框架充分利用了注解和反射技术,旨在提供一种优雅且可扩展的解决方案。 首先,我们来理解注解(Annotation)在Java中的作用。注解是一种元数据,它提供了在源...
【标题】:“一个框架(带图片和好多东东)” 【描述】:“嘿嘿,这个资源是给自己用的,不嫌贵的下载吧” 这个资源很可能包含一个完整的开发框架,其中包括了图片和其他各种组件,可能是为了方便开发者快速构建应用...
这里提到的"框架包.zip"是一个包含多种常用框架的集合,方便开发者快速搭建项目环境,节省时间。主要涉及到的框架有Struts和Spring,这两个都是Java Web开发中的核心框架,特别适合MVC(Model-View-Controller)设计...
SSH2框架,全称为Spring、Struts2和Hibernate2的集成框架,是Java Web开发中的一个常见组合。这个实例源码使用的是Spring 3.2、Struts2 2.3.4和Hibernate 4.2这三个框架的较新版本,提供了一个基础的用户登录和用户...
为什么说“零信任”将成为网络安全流行框架之一【鹏越.pdf零信任是什么?为什么说“零信任”将成为网络安全流行框架之一【鹏越.pdf零信任是什么?为什么说“零信任”将成为网络安全流行框架之一【鹏越.pdf零信任是...
为什么说“零信任”将成为网络安全流行框架之一【鹏越.docx零信任是什么?为什么说“零信任”将成为网络安全流行框架之一【鹏越.docx零信任是什么?为什么说“零信任”将成为网络安全流行框架之一【鹏越.docx零信任...
风度框架是一款针对Android系统的框架修改工具,专为Android 12版本设计。在深入了解这款软件之前,我们先来理解一下“框架”在Android系统中的含义。在Android中,框架是操作系统的核心组成部分,包含了系统服务、...