什么是开发框架

来源:https://www.cnblogs.com/EmptyFS/p/4105713.htmlhtml

前言程序员

  作为一个程序员,在开发的过程当中会发现,有框架同无框架,作起事来是彻底不一样的概念,关系到开发的效率、程序的健壮、性能、团队协做、后续功能维护、扩展......等方方面面的事情。不少朋友在学习搭建本身的框架,不少公司也在建立或使用本身的框架,网上开源的框架多如牛毛,每一年新上线的各类框架也不知多少。而不停的重复造轮子,也让更多的朋友鸟枪换炮,越跑越快,工做效率愈来愈高。那么什么是框架呢?编程

 

  什么是框架设计模式

  度娘上说:框架(Framework)是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法; 另外一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面然后者是从目的方面给出的定义。架构

  能够说,一个框架是一个可复用的设计构件,它规定了应用的体系结构,阐明了整个设计、协做构件之间的依赖关系、责任分配和控制流程,表现为一组抽象类以及其实例之间协做的方法,它为构件复用提供了上下文(Context)关系。所以构件库的大规模重用也须要框架。并发

  应用框架指的是实现了某应用领域通用完备功能(除去特殊应用的部分)的底层服务。使用这种框架的编程人员能够在一个通用功能已经实现的基础上开始具体的系统开发。框架提供了全部应用指望的默认行为的类集合。具体的应用经过重写子类(该子类属于框架的默认行为)或组装对象来支持应用专用的行为。框架

  应用框架强调的是软件的设计重用性和系统的可扩充性,以缩短大型应用软件系统的开发周期,提升开发质量。与传统的基于类库的面向对象重用技术比较,应用框架更注重于面向专业领域的软件重用。应用框架具备领域相关性,构件根据框架进行复合而生成可运行的系统。框架的粒度越大,其中包含的领域知识就更加完整。分布式

  框架,即framework。其实就是某种应用的半成品,就是一组组件,供你选用完成你本身的系统。简单说就是使用别人搭好的舞台,你来作表演。并且,框架通常是成熟的,不断升级的软件。函数

  上面是度娘百科——框架里讲的内容,讲得挺理论挺全面的,直接复制了一些过来。工具

 

  简单来说,软件开发框架能够理解为咱们起楼房时,用梁+柱子+承重墙作起来的钢筋混凝土结构框架。而实现的软件功能,也就像在这个框架结构中所要实现的不一样类型、功能的房子,好比停车场、商场、酒店、饭店、商住房......

  功能强大,结构扎实的框架,可承载的类型就更多,适用性就更强。

  不管是什么开发框架,都是为现实不一样的业务功能而建立的。好的开发框架能提升企业的竞争能力,包括下降开发成本、提升产品质量、改善客户满意程度、控制开发进度等。同时,开发框架也是某一领域为实现某种业务的知识积累,它是一种持续性的活动,随着特定业务功能实现而建立,且跳出软件开发周期而存活。一个成熟的框架,不仅仅只是代码而已,它除了将某一领域业务的基础功能以代码的方式实现外,还必须编写对应的文档、模型、流程图、数据字典、开发使用说明.....等一系列的文档来支撑,这样的框架才更加成熟和健壮。

 

  为何要使用框架

  软件系统随着业务的发展,变得愈来愈复杂,不一样领域的业务所涉及到的知识、内容、问题很是很是多。若是每次都从头开发,那都是一个很漫长的事情,且并不必定能将它作好。团队协做开发时,没有了统一标准,你们各写各的,一样的重复的功能处处都是。因为没有统一调用规范,很难看懂别人写的代码,出现Bug或二次开发维护时,根本无从下手。(无框架不堪回首的黑暗日子请看前面章节的讲述)

  而一个成熟的框架,它是模板化的代码,它会帮咱们实现不少基础性的功能,咱们只须要专心的实现所须要的业务逻辑就能够了。而不少底层功能操做,就能够完彻底全不用作太多的考虑,框架已帮咱们实现了。这样的话,整个团队的开发效率可想而知。另外对于团队成员的变更,也不用太过担忧,框架的代码规范让咱们能轻松的看懂其余开发人员所写的代码。

 

  搭建框架时,咱们要如何定位

  是否是框架的扩展性、可移值性、功能越强大就越好呢?

  好的框架是相对的,它都有本身特定的应用领域,合适才是最好。

  我的以为在实际开发中要根据具体状况来看的,由于功能越全面它的复杂度就越大,所须要的开发人员能力和技能就会要求更高,付出的成本也就最大。好比作一个还未发展起来的电商网就想 将系统作成像京东那样,直接用京东分模块分布式的框架来开发,那得怎么来组建这个团队?更不用说开发成本了。就算团队有能力作到,也没有那个必要这么去作,由于从成本预算和开发周期等方面来看,得不尝失,更多的可能项目还未完成公司就给拖垮了。

   通常来讲,一个中小型项目,1到5人左右的开发团队,使用通常的三层结构就能够了,不用去细想框架要分三层仍是五层,每一个层之间要怎么实现解耦,要用什么设计模式.....由于当今飞速发展的互联网时代,快才是王道,作一个中小型项目能用一周完成的,毫不能拖了一个月还未作完。人工与时间成本才是重点中 的重点,惟有快才能更好的生存下来并壮大。至于扩展功能、接口、分布式、并发、大数据......等等问题,实际上过早考虑太多并非好事情,有经验的程序员在写这个框架时早已留下扩展方案或思路,而没到这一层次的开发人员你想再多也可能想不明白,还不如先作出来积累必定经验后再慢慢学习,慢慢升级框架。

  固然也不是说设计框架时不用考虑高内聚低耦合,而是要根据本身的能力与经验来设计出本身能把控的框架出来。由于框架不是开发出来后就再也不变更,它也须要不停的进行升级,将你所学到的新知识新技术融合到框架中,使它的功能更增强大,更加健壮。而对于本身不能把控的框架,在团队协做开发和上生产环境后,你就发现有一大堆的坑等着你去填埋,这种框架只能拿来先练练手,有空再慢慢完善。

  框架经过小步快跑,不断的迭代升级来慢慢扩展的,当项目上生产环境后,根据新的需求和所碰到的问题,去不停的调整,最终愈来愈强大。全部框架都是从1.0版本到2.0、3.0......发展而来,而不是直接跳过最第一版本到最终成熟版本。

   因此说咱们在建立一个框架时,必须根据咱们当前我的的技术能力、团队成功技术水平、时间、投入成本、项目现状(规模与需求复杂程度)、之后的发展前景来决定所要开发的框架的最终设计方案。固然也不是说不能一步到位,心有多大世界就有多大,只要我的能力和团队能力配得上,老板资金成本雄厚,时间充足,直接上大项目使用超级框架也彻底没有问题。

 

  框架和设计模式
  度娘上说:框架、设计模式这两个概念总容易被混淆,其实它们之间仍是有区别的。构件一般是代码重用,而设计模式是设计重用,框架则介于二者之间,部分代码重用,部分设计重用,有时分析也可重用。在软件生产中有三种级别的重用:内部重用,即在同一应用中能公共使用的抽象块;代码重用,即将通用模块组合成库或工具集,以便 在多个应用和领域都能使用;应用框架的重用,即为专用领域提供通用的或现成的基础结构,以得到最高级别的重用性。
  框架与设计模式虽然类似,但却有着根本的不一样。设计模式是对在某种环境中反复出现的问题以及解决该问题的方案的描述,它比框架更抽象;框架能够用代码表示,也能直接执行或复用,而对模式而言只有实例才能用代码表示;设计模式是比框架更小的元素,一个框架中每每含有一个或多个设计模式,框架老是针对某一特定应 用领域,但同一模式却可适用于各类应用。能够说,框架是软件,而设计模式是软件的知识。

 

  框架的主要特色和要求

  一、代码模板化

  框架通常都有统一的代码风格,同一分层的不一样类代码,都是大同小异的模板化结构,方便使用模板工具统一辈子成,减小大量重复代码的编写。在学习时一般只要理解某一层有表明性的一个类,就等于了解了同一层的其余大部分类结构和功能,容易上手。团队中不一样的人员采用类同的调用风格进行编码,很大程度提升了代码的可读性,方便维护与管理。

 

  二、重用

  开发框架通常层次清晰,不一样开发人员开发时都会根据具体功能放到相同的位置,加上配合相应的开发文档,代码重用会很是高,想要调用什么功能直接进对应的位置去查找相关函数,而不是每一个开发人员各自编写一套相同的方法。

  三、高内聚(封装)

  框架中的功能会实现高内聚,开发人员将各类须要的功能封装在不一样的层中,给你们调用,而你们在调用时不须要清楚这些方法里面是若是实现的,只须要关注输出的结果是不是本身想要的就能够了。

  四、规范

  框架开发时,必须根据严格执行代码开发规范要求,作好命名、注释、架构分层、编码、文档编写等规范要求。由于你开发出来的框架并不必定只有你本身在用,要让别人更加容易理解与掌握,这些内容是很是重要的。

  五、可扩展

   开发框架时必需要考虑可扩展性,当业务逻辑更加复杂、数量记录量爆增、并发量增大时,可否经过一些小的调整就能适应?仍是须要将整个框架推倒从新开发?固然对于中小型项目框架,也没必要考虑太多这些内容,当我的能力和经验足够时水到渠成,天然就会注意到不少开发细节。

  七、可维护

  成熟的框架,对于二次开发或现有功能的维护来讲,操做上应该都是很是方便的。好比项目要添加、修改或删除一个字段或相关功能,只须要简单的操做,十来分钟或不用花太多的工夫就能够搞定。新增一个数据表和对应的功能,也能够快速的完成。功能的变更修改,不会对系统产生不利的影响。代码不存在硬编码等等,保证软件开发的生产效率和质量。

  八、协做开发

  有了开发框架,咱们才能组织大大小小的团队更好的进行协做开发,成熟的框架将大大减轻项目开发的难度,加快开发速度,下降开发费用,减轻维护难度。

  九、通用性

  同一行业或领域的框架,功能都是大同小异的,不用作太大的改动就能够应用到相似的项目中。在框架中,咱们通常都会实现一些同质化的基础功能,好比权限管理、角色管理、菜单管理、日志管理、异常处理......或该行业中所要使用到的通用功能,使框架能应用到某一行业或领域中,而不是只针对某公司某业务而设定(固然也确定存在那些特定功能的应用框架,这只是很是少的特殊状况,不在咱们的考虑范围)。

 

  至于框架怎么一步步设计与开发,请看后续章节

 

 

  以上就是我对开发框架的一些理解,若是您以为有不对的地方,欢迎拍墙

 

 

 

 版权声明:

  本文由AllEmpty原创并发布于博客园,欢迎转载,未经本人赞成必须保留此段声明,且在文章页面明显位置给出原文连接,不然保留追究法律责任的权利。若有问题,能够经过1654937@qq.com 联系我,很是感谢。

 

  发表本编内容,是为了和你们共同窗习共同进步,有兴趣的朋友能够加加Q群:327360708 ,你们一块儿探讨。

  在佛山工做的朋友也能够加入:佛山IT朋友群 263767221,你们能够共享资源共同进步,有空你们能够约出来认识一下,交流一下技术,哈哈

 

  更多内容,敬请观注博客:http://www.cnblogs.com/EmptyFS/

相关文章
相关标签/搜索