当前位置: 首页 > news >正文

从零开始编写自己的C#框架(2)——开发前准备工作

  没想到写了个前言就受到很多朋友的支持,大家的推荐就是我最大的动力(推荐得我热血沸腾,大家就用推荐来猛砸我吧O^-^O),谢谢大家支持。

  其实框架开发大家都知道,不过要想写得通俗点,我个人觉得还是挺吃力的。在本系列中,我不会很深入的去讲述那些映射啊关系啊(绕得我头都晕了,这些请大家去查看相关的文档学习吧)......概念上的东西会少讲,直接上实例,讲实际应用。当然如果您觉得这样很不尊重面向对象什么的,那也没办法,只能说我们不在一个频道上。

  本人是个技术宅,第一次写长篇连载经验不足,有时候会词不达意,这也是很正常的事情。由于空闲时间不是非常多,发贴间隔时间可能有时会长点,希望大家谅解。

  也不再罗嗦太多,下面进入正题。

 

  俗话说工欲善其事必先利其器,在准备开发前,还需要做好各方面的准备工作,了解相关知识。

 

  怎么开始呢?

  要开发一个项目,有过开发经验的人都知道,按软件工程的话来讲,必须先做好需求分析,然后总体设计与详细设计,跟着编码,测试......

  而在进入开发之前,我觉得除了开发环境与工具的准备之外,思想上的准备还是非常有必要的,如果不了解将要开始的项目,那就会觉得很蒙,迷迷糊糊的,无从下手(碰过不少这样的朋友,呵呵......)。

  要接手开发一个项目,首先要问自己思想上准备好了没有?也就是说做为一个项目的主要执行人员,你清楚你在做什么吗?要实现什么功能?怎么实现?用什么平台、工具开发?涉及什么技术?和什么人一起开发?水平如何?可能会遇到什么样的困难?怎么解决?项目涉及什么业务?你了解这些业务流程吗?对性能与安全有怎样的要求?如何优化?你懂得代码安全与服务器安全吗?要写那些文档?怎么写?有没有开发计划?计划花多长时间?怎么控制进度?......

  很多朋友可能要说,我做这么多年开发,并没有考虑过上面的问题,还不一样能将项目做出来,而且做得很好。是的,对于有经验的朋友来说,其实一拿到需要文档,甚至客户(或老板)口中只要简单的描述出想要的功能,而我们就会立刻在大脑中描绘出这个功能实现的界面,以及要如何实现,在实现的过程中会碰到那些问题,而这些问题很多又会想到使用什么算法或解决方案来处理......其实这个过程不就是已经回答上面的问题了吗?就如下面那样(盗用了《为什么不能打断程序员?》的图片,嘿嘿)

  

  而对于还没有足够经验的朋友们来说,还是脚踏实地,在接到项目后认真思考一下上面的问题,练习练习这种思维模式比较好。这样才不会像不少开发人员那样,项目做着做着就烂尾了......或者是做出自己也不知道是什么的,无法进行二次开发的项目出来......因为这种的事情我自己也经历过,而接触过这类型的开发人员也不少(后面文章会举一些相关例子给大家参考一下)。

  当然如果不会回答上面的问题,没有做好准备也问题不大,但必须要有一颗坚持到底,迎难而上的心,因为大牛们都是从初学者来的,只要认真学习,当你经历了N个项目后,也就成为别人眼中的大神了。

  上面的问题并不要求全部都懂得,但在开发之前最好还是有所了解,最好将对它们的思考一一记录下来(无论是答案还是疑问),形成文档,这对你在实际的需求分析与相关设计时很有帮助,当然你试过了就知道其中的好处。

 

  那跟着下来,我们先做一做这个问答题,了解一下将要开发的框架一些问题。

  做为一个项目的主要执行人员,你清楚你在做什么吗?

  我准备使用C#语言,借用一些利器(插件)开发一个快速开发框架,框架的数据层代码与逻辑层代码直接使用插件生成,减轻开发人员重复工作,减轻开发工作量与出错率;框架的权限管理可以像QQ那些,控制帐号在同一时间只能一个人登陆使用,如果有人在其他电脑或新窗口登陆时,原登陆会给踢除下线,当然设置这个帐号为多人使用时,可以做到同时在线,有在线列表可以对登陆用户进行维护,查看这些用户当前位置以及登陆、操作日志;权限按部门、职位进行划分,为不同职位定义对每个页面以及页面上的按键赋予不同的操作权限;每个页面与按键在添加时需要在系统中进行注册,当用户未指派指定按键操作权限时,自动禁用该按键,页面里的所有链接使用指定算法进行加密,即用户只能通过页面生成的链接或按键点击进入下一个页面,直接复制修改Id等参数将被默认为非法访问;框架有自动记录用户操作日志功能,即用户进入了什么页面,做了什么操作都可以自动记录下来;列表页面的相关操作(比如修改状态、保存排序、自动保存排序、列表排序、列表翻页......)等各种常用功能将会使用相关插件或将代码进行封装起来,在开发时不用再重复复制或编辑代码操作,直接通过继承父类实现;对于数据量不大的表直接使用Redis缓存处理,减轻对数据库的访问量,提升框架性能;......总之整个框架既要保存开发的便捷性(手写的代码量少,开发效率高),又要保证其安全可靠,运行性能高效。

 

  用什么平台、工具开发?

  使用Windows7操作系统,应用VS2010、MsSql2005、Excel、Word、Visio等软件,以及ReSharper、SubSonic3.0、Redis、FineUI等插件来开发实现。

 

  涉及什么技术?

  本框架将会使用ASP.NET(C#)、MsSql、SubSonic3.0、FineUI、Linq、T4模板、IIS、Redis缓存等相关技术。(后面的对应章节会对其中一些技术做出相关说明)

 

  要实现什么功能?怎么实现?

  要实现的功能前面已进行简单的描述。

  实现的步骤:将会按照软件工程所描述的步骤,首先会制定开发规范要求、编写需求文档、开发文档(总体设计文档)、详细文档(细化相关技术难点与算法,绘制相关算法、流程图表)、设计数据库、然后编码、测试、部署上线等,整个过程将会涉及很多文档的编写与维护工作,在实施过程中不断完善相应文档,并做好版本控制以及项目进度控制工作,做到项目需求的修改与变动都有法可依(有文档可供查询与查看),执法必严(严格控制开发进度)。

 

  和什么人一起开发?水平如何?

  本框架将由我一人开发。本人有十多年开发经验,曾独立开发过一个J2ME开发框架(组件模式)、安卓开发框架,以及.NET平台4个大版本的开发框架等,曾负责或参与几十个大中小型项目,有丰富的开发经验。

 

  可能会遇到什么样的困难?怎么解决?

  为了避免与公司项目有版权纠纷,整个系统将重新设计,应用更新的设计理念与功能设计,所有代码将重新手打出来,架构代码全部重构,这可能会遇到很多新的技术难点。对权限管理也将使用更合适的架构,使它可自由扩展,权限管理更加灵活,以使它能支持全国性大公司下,各分公司能独立支持各自的人事与权限管理和业务管理(各分公司查看与管理权限互不影响)。由于是业余时间开发,并要编写开发教材、开发文档与说明,时间将会变得不可控。另外一直以来都在使用ExtJS,现在新框架将要使用FineUI,可能会存在未知的技术问题需要解决。

  以上问题我将会通过在设计阶段对功能与算法进行细化,绘制相应的流程图表,形成完善的开发文档来指导开发,以实现对项目的技术难点与进度把控。而对相关插件将作进一步研究,熟悉使用方法,减少可能出现的技术问题。

 

  项目涉及什么业务?你了解这些业务流程吗?

   本项目只是一个快速开发框架,只实现基本的基础开发架构,不涉及具体的业务。(以后如果有需要,再考虑增加一些OA常用的功能)

 

  对性能有怎样的要求?如何优化?

  对于ORM的优缺点,网上的讨论已经有很多了,这里就不再细说。一般来说ORM框架会有性能上的损耗,但带来的是开发效率的提升,从时间成本、人工成本等各方面来说,它都是我们的首先,当然某些特殊项目对性能要求非常苛刻的自然另当别论了。我们要寻找的是开发效率和性能中间找一个平衡点,而不是固执的要求整个框架使用一种技术。

  本框架将会使用到缓存技术(目前选择的是使用Redis缓存,不过对于使用虚拟空间的朋友可能并不合适,到时会提供别一种纯粹使用IIS缓存跨站解决方案),减少数据库交互次数,提升框架执行性能。另外在数据库结构设计上,也会应用一些设计模式,减少表关联的方法来提高查询效率。在编写代码的时候也会在适当的地方提出优化说明,提高性能。

  另外要说明一点,本框架不会完全使用面对象的思想来开发,而是以开发效率与性能等综合考虑,在合适的地方使用合适的方式来实现,特殊情况特殊处理。比如框架使用的是SubSonic3.0插件,但某些地方也会直接使用ADO.NET来执行相关语句,因为这样处理代码量会更少,性能更优。而在复合查询需要涉及多个表处理的地方,也会考虑使用存储过程来实现,而不是死板的使用面向对象思想,写了一大堆代码以牺牲性能与开发效率来实现目的。一切都以开发效率为原则优先考虑。

 

  你懂得代码安全与服务器安全吗?

   一直以来都很注重代码与服务器的安全问题,并关注这些方面的文章,努力提升自己。在公司技术部门中,做为资深的软件开发工程师,对将要上线前的代码都会经我手进行安全性检查,有丰富的经验。而对服务器方面,也有多年各种类型服务器的维护以及安全部署经验,将各种类型的入侵挡之门外。

 

  要写那些文档?怎么写?

   整个项目的实施将会涉及很多文档的编写,具体请留意后面的章节《从零开始编写自己的C#框架(4)——文档编写说明》。

 

  有没有开发计划?计划花多长时间?怎么控制进度?

   本框架将会利用晚上与周末时间来开发,平均每天两到三小时左右,具体的开发计划与进度甘特图将会在相关的设计文档与数据库结构设计好以后,根据功能与个人的时间安排来编写甘特图,来确定开发计划。具体花费时间将在甘特图出来以后能才确定。对于进度的控制,具体请看后面的章节《从零开始编写自己的C#框架(10)——项目实施计划与甘特图》。

 

  我没有经验怎么办?

  以上的准备工作,对于不同项目不同工作经验的人来说,要准备的内容也是有差别的,这个要根据具体情况而定,总的来说,主要目的就是通过一些手段或方法, 让自己对整个项目有个总体的认知和准备,以减少项目失败的机率。无论做什么项目都好,学习与沉淀是非常重要的。要在合适的时间做出合适的判断和处理,才能达到最优的效果。有多少知识的沉淀,就搭多大的框框。框架的功能不是越多越好,适合当前的环境所需要的,才是最合适的。

  有时候我们学习,并不一定要知其所以然。有朋友可能会说,你不了解得深入,怎么能做好它呢?其实所以然是在知其然的基础上研究出来的,我们必须先踏出第一步,就算做出一个丑陋的框架,那也无所谓,因为有了第一个才会有第二个第三个。只有做过一次,你才能了解框架的结构,只有将自己搭建好的框架应用到生产环境中进行检验,才知道其中的优劣,才能不断的找出问题,不停的学习,然后再进行升级,那么它也将越来越完善。而在完善的过程中,你就越来越了解所以然了。

 

  总结

  如果将要开发的是一个商业项目,要考虑的还不至上面这些,除了投入、产出、市场、风险外,还要考虑需求变更、团队协作、服务器负载、分发、部署、安全(服务器、代码等安全)、测试(指定整个的测试流程)、维护......

  当然这只是一个小小的、常用的快速开发框架而已,所以所要注意的只是技术相关的内容,只要你能坚持看完本系列文章,有一定的C#基础,就可以打造一个属于你自己的框架。

 

  由于本人理论水平有限,如果在某些地方使用的字词描述以及技术术语的使用不恰当,敬请谅解。

 

 

 版权声明:

  本文由AllEmpty原创并发布于博客园,欢迎转载,未经本人同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。如有问题,可以通过1654937@qq.com 联系我,非常感谢。

  发表本编内容,只要主为了和大家共同学习共同进步,有兴趣的朋友可以加加Q群:327360708 或Email给我(1654937@qq.com),大家一起探讨。

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

 

转载于:https://www.cnblogs.com/EmptyFS/p/3626080.html

相关文章:

  • 下列关于异常处理的描述中,错误的是()。
  • centos搭建svn 服务器 并同步到web 目录(总结)
  • windows phone 7 中怎样定义和使用资源(Resource)
  • Scrum丰田之道
  • 一步步学习微软InfoPath2010和SP2010--第十四章节--高级选项(9)--高级函数
  • vue+webpack 在引入图片以及在img引用变量名的本地图片报错
  • android选择图片或拍照图片上传到服务器(包括上传参数) (转)
  • 你应该了解的大数据10个新趋势
  • js编写倒计时-距离开始时间距离结束时间-结束
  • in, out, ref
  • 以太坊 ERC223 标准与 ERC20 的区别是什么?
  • 7、请求参数接收
  • iPhone的指纹识别与面部识别(FaceID)
  • 状态模式与外观模式的碰撞
  • 【hdoj】1358 Period【字符串--最小循环节 i/next[i]即为其长度】
  • [译]Python中的类属性与实例属性的区别
  • Android Volley源码解析
  • go语言学习初探(一)
  • happypack两次报错的问题
  • isset在php5.6-和php7.0+的一些差异
  • javascript 总结(常用工具类的封装)
  • k个最大的数及变种小结
  • Mocha测试初探
  • oldjun 检测网站的经验
  • React Native移动开发实战-3-实现页面间的数据传递
  • React系列之 Redux 架构模式
  • vue从创建到完整的饿了么(18)购物车详细信息的展示与删除
  • Wamp集成环境 添加PHP的新版本
  • XForms - 更强大的Form
  • 个人博客开发系列:评论功能之GitHub账号OAuth授权
  • 回顾 Swift 多平台移植进度 #2
  • 浏览器缓存机制分析
  • 前端学习笔记之观察者模式
  • 浅谈Golang中select的用法
  • 如何选择开源的机器学习框架?
  • 算法之不定期更新(一)(2018-04-12)
  • 我的面试准备过程--容器(更新中)
  • 这几个编码小技巧将令你 PHP 代码更加简洁
  • C# - 为值类型重定义相等性
  • ​MySQL主从复制一致性检测
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • # Swust 12th acm 邀请赛# [ E ] 01 String [题解]
  • #设计模式#4.6 Flyweight(享元) 对象结构型模式
  • (10)ATF MMU转换表
  • (16)UiBot:智能化软件机器人(以头歌抓取课程数据为例)
  • (5)STL算法之复制
  • (day6) 319. 灯泡开关
  • (MIT博士)林达华老师-概率模型与计算机视觉”
  • (板子)A* astar算法,AcWing第k短路+八数码 带注释
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • (附源码)基于SSM多源异构数据关联技术构建智能校园-计算机毕设 64366
  • (论文阅读31/100)Stacked hourglass networks for human pose estimation
  • (使用vite搭建vue3项目(vite + vue3 + vue router + pinia + element plus))
  • (学习日记)2024.02.29:UCOSIII第二节
  • (转载)CentOS查看系统信息|CentOS查看命令