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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:

 没想到写了个前言就受到很多朋友的支持,大家的推荐就是我最大的动力(推荐得我热血沸腾,大家就用推荐来猛砸我吧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 博客园博客,原文链接:http://www.cnblogs.com/EmptyFS/p/3626080.html,如需转载请自行联系原作者




相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
16天前
|
测试技术 C# 数据库
C# 单元测试框架 NUnit 一分钟浅谈
【10月更文挑战第17天】单元测试是软件开发中重要的质量保证手段,NUnit 是一个广泛使用的 .NET 单元测试框架。本文从基础到进阶介绍了 NUnit 的使用方法,包括安装、基本用法、参数化测试、异步测试等,并探讨了常见问题和易错点,旨在帮助开发者有效利用单元测试提高代码质量和开发效率。
120 64
|
8天前
|
测试技术 Go C#
C#一分钟浅谈:ReSharper 插件增强开发效率
【10月更文挑战第25天】ReSharper 是 JetBrains 开发的一款 Visual Studio 插件,旨在提高 .NET 开发者的生产力。它通过代码分析、重构、导航等功能,帮助开发者避免常见错误,提升代码质量和开发效率。本文将通过具体代码案例,详细介绍 ReSharper 的常见功能及其应用。
23 1
|
13天前
|
C# Python
使用wxpython开发跨平台桌面应用,对wxpython控件实现类似C#扩展函数处理的探究
【10月更文挑战第30天】使用 `wxPython` 开发跨平台桌面应用时,可以通过创建辅助类来模拟 C# 扩展函数的功能。具体步骤包括:1. 创建辅助类 `WxWidgetHelpers`;2. 在该类中定义静态方法,如 `set_button_color`;3. 在应用中调用这些方法。这种方法提高了代码的可读性和可维护性,无需修改 `wxPython` 库即可为控件添加自定义功能。但需要注意显式调用方法和避免命名冲突。
|
21天前
|
JSON C# 开发者
C#语言新特性深度剖析:提升你的.NET开发效率
【10月更文挑战第15天】C#语言凭借其强大的功能和易用性深受开发者喜爱。随着.NET平台的演进,C#不断引入新特性,如C# 7.0的模式匹配和C# 8.0的异步流,显著提升了开发效率和代码可维护性。本文将深入探讨这些新特性,助力开发者在.NET开发中更高效地利用它们。
30 1
|
27天前
|
开发框架 前端开发 API
C#/.NET/.NET Core优秀项目和框架2024年9月简报
C#/.NET/.NET Core优秀项目和框架2024年9月简报
|
27天前
|
开发框架 NoSQL MongoDB
C#/.NET/.NET Core开发实战教程集合
C#/.NET/.NET Core开发实战教程集合
|
2月前
|
编译器 C# Android开发
Uno Platform 是一个用于构建跨平台应用程序的强大框架,它允许开发者使用 C# 和 XAML 来创建适用于多个平台的应用
Uno Platform 是一个用于构建跨平台应用程序的强大框架,它允许开发者使用 C# 和 XAML 来创建适用于多个平台的应用
199 8
|
2月前
|
物联网 C# C语言
物联网开发中C、C++和C#哪个更好用
在物联网(IoT)开发中,C、C++和C#各有优缺点,适用场景不同。C语言性能高、资源占用低,适合内存和计算能力有限的嵌入式系统,但开发复杂度高,易出错。C++支持面向对象编程,性能优秀,适用于复杂应用,但学习曲线陡峭,编译时间长。C#易于学习,与.NET框架结合紧密,适合快速开发Windows应用,但性能略低,平台支持有限。选择语言需根据具体项目需求、复杂性和团队技术栈综合考虑。
|
27天前
|
边缘计算 开发框架 人工智能
C#/.NET/.NET Core优秀项目和框架2024年8月简报
C#/.NET/.NET Core优秀项目和框架2024年8月简报
|
1月前
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
47 0
下一篇
无影云桌面