个人知识管理系统Version1.0开发记录(12)
最近碰到个问题,在五个工作日内阅读一个百万行左右代码量的新项目集合,如何解决呢?
第一个工作日,环境观察。待在那个项目组,看项目成员们在做些什么事情,开发,测试,聊天,或多或少可以收集到一些项目相关的零散信息,这是看和听了。适当向项目成员咨询一下平时项目的一些基本情况,这就是问了。第一个工作日对项目开发环境有一定了解就好,比如开发的方式,是一步步的瀑布法,还是一个个功能的敏捷法;比如数据权限,是有测试环境和生产环境之分的;比如项目组成员情况,每个人的做事风格是有区别的,如果留心观察和思考,会发现他们写的代码往往带有一些个人习惯,或缜密,或条件繁琐,或简单快速,或者套路化,或者千篇一律一个样,这就是个人,团队和项目三者的大致关系了,他们是如何在一个环境中存在的。代码是人写的,是团队合作出来的,是在一种生产环境运行的,最开始了解代码产生的环境,在脑子里面有个大概思维形状是个好的开始。
第二个工作日,文档收集。每个项目或多或少都有一些相关文档,比如项目是用什么框架实现的,各个项目是通过什么协议传输数据的,包名类名规范,基础类继承要求等。最开始因为不熟悉项目,文档看着是有点头疼的,因为感觉多散乱,从简单的自己熟悉的方面开始看就好。可以按照自己喜欢的类型,将文档进行分类,方便形成结构化的文档集。就象数据库建模,最开始收集到数据是没有数据库表和对象的,把一类物质归纳到一起,抽取他们共同的属性和方法,可以反复调用他们,就产生了数据库表和对象了。文档分类类似,习惯把文档按照什么类型分类,然后归纳为一类,一类文档解答一类问题,把没有关系的信息因为可以解答一类问题这个关系而归纳为一类有关系的信息。阿拉伯数字和中文汉字是一个非常好的组合,01+几个简明扼要的中文汉字,就可以明白阐述一类文档了。OK,有特例怎么办,可以看用途,有的特例有使用条件,有的特例可以多处使用,有的特例就是例外,我们可以写个带参方法(条件即参数),可以写个工具类(可以反复调用),可以写个异常和日志记录(触发例外则按异常处理)。
第三个工作日,结构整理。理清技术相关信息,了解基本运行原理。人们往往毫无头绪或者思绪混乱,是因为未知,理解未知的常用方法是用已知的知识结构去解析。
1,jdk1.6,jdk1.6中文API文档。
2,运行java的网络服务器,tomcat7。
3,IDE,Eclipse。
4,数据库,Oracle;数据库操作,PlsqlDeveloper。
5,数据访问框架,Mybatis,数据访问层dao。
6,业务逻辑和控制框架,SpringMVC,基于方法复用service。
7,界面,jQuery EasyUI。
8,系统间数据交互,spring HttpInvoke。
9,分布式缓存框架,EhCache。
10,sql优化方案...
第四个工作日,业务逻辑。一个常用的方法,就是把自己当成用户,操作用户界面,看看实现了哪些功能模块,然后结合代码看看这些功能模块是如何实现的。从哪里收集的数据,如何加工数据到界面上的,用户需要这些数据有什么价值,系统额外做了什么,与其他系统产生了什么交互。然后用笔纸大致画画业务逻辑图。可以对照数据库表,想想这些表是如何抽象出来的,如何让一些没有关系的数据建立起数据模型的。可以从核心功能,常用功能看起。
第五个工作日,方法抽象。整合前面收集的信息,对方法和步骤进行一定的结构化归纳。
1,细节。日志记录要清晰,sql语句效率要高,数据流通清晰明白,等。
2,流程。需求分析,设计文档,业务逻辑,结构清晰,沟通顺畅,等。
3,复用。某个功能模块,类,方法适用于大量业务场景,抽取这些逻辑组织复用性高的代码。
4,合作。涉及到多系统交互,数据访问调用接口这些必然存在问题,事先考虑时效等相关问题,运用一些数学统筹方法,调整事务顺序,是有好处的。
5,学习。若没有网络,我们如何解决未知问题?尝试,排除,类比都是可以的。学习基础知识快速开发的同时,学习一些反复使用的经典方法是有益的。
我们没有思路,是因为我们还没有看懂,还没有想明白,多看,多听,多写,多画,多想,多动手。求快就快点写,写好了实现功能出现问题再改;求稳就按照步骤做,边做边检查边测试,按部就班即可;求复用,就要多动脑子模拟场景,把东西挖出来形成一个功能齐全的独立整体就好了;求收益好,就多想想实用性,逆向思考就好...年轻的我们一天天成长,每天都有进步就好了;图书馆和运动场多去逛逛,是有好处的,这是一件重要不紧急的事情。
个人知识管理系统Version1.0开发记录(12)的更多相关文章
- 个人知识管理系统Version1.0开发记录(09)
MyBatis初试 MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索. 运用Mybatis框 ...
- 个人知识管理系统Version1.0开发记录(01)
架 构 描 述 01.数据层,数据源,有形资源入库,无形资源整理,对外搜索引擎,对内平台搜索,数据类型(文字.图片.声音.视频.组合),数据时空优化,数据安全方案(数据进站关卡,数据出战关卡),数据并 ...
- 个人知识管理系统Version1.0开发记录(02)
第 一 步 做 什 么 我们该如何入手呢?先来看看目前常用的三个方法. 1.从事物产生的源头出发,层层推进,步步验证,最后开花结果.这种方法经常用于科研项目,或者三期以后的工程,国家政府项目用的较多. ...
- 个人知识管理系统Version1.0开发记录(11)
(1)匹配单个属性的关键字:(2)匹配单个对象的关键字:(3)匹配对象集合的关键字:(4)基于事件驱动的:(5)实时搜索,参考win7的搜索功能. 1.备份,java代码,数据库数据. 2.oracl ...
- 个人知识管理系统Version1.0开发记录(10)
物理分页 这次我们运用Mybatis拦截器来实现物理分页,后面会运用动态sql来实现,或者运用Map/CollectionUtils/StringUtils编写工具类来实现.oracle是运用的row ...
- 个人知识管理系统Version1.0开发记录(07)
模 块 复 用 原本还要测试一会的,突然出现一连串诡异的问题,比如,编译少加载个类啊,输入地址少个字母啊,改几行代码一改就是半小时啊.这是在提醒我们大脑疲倦了,所以果断小结,下次继续.这一次简单完成了 ...
- 个人知识管理系统Version1.0开发记录(08)
切入点 前面,我们已经搭建好了web端的一种基本结构,需要进一步定位的主要问题有三点: 1.界面的选择和确定,用extjs做的初步样式,进一步改动为jqueryUI/html,再进一步改变为HTML5 ...
- 个人知识管理系统Version1.0开发记录(05)
demo controller我们从前面的实现过程可以得出三种普遍使用的信息处理方式:1.操作数据库,对数据进行增删改查,比如运用sqldevloper查看数据信息.2.运用计算机程序语言,对数据进行 ...
- 个人知识管理系统Version1.0开发记录(06)
demo view 夜已深,我们先简单演示一下,完成一个小段落了.涉及工具及技术知识:图形处理软件photoshop cs6,js类库ext. 思路如下: 1.下载ps6,有破解版本的,dll文件覆盖 ...
随机推荐
- checkbox的name与JavaBean的交互时发现的一个现象
一个页面: <form action="reg.jsp" method="post"> <ul> <li>算法选择</ ...
- java 常见几种发送http请求案例
import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java ...
- Nginx高级玩法
1. Nginx获取自定义消息头 .nginx是支持读取非nginx标准的用户自定义header的,但是需要在http或者server下开启header的下划线支持: underscores_in_h ...
- 修改nginx的http响应头server字段
信息泄露类型:HTTP服务器响应头Server字段信息泄露 示例: 解决: 需要重新对nginx编译安装: [root@localhost ~]# tar zxvf nginx-1.8.1.tar.g ...
- 【查看】mysql 常规书写注意事项(那些坑)
mysql 常规书写注意事项,mysql注意事项 1. 注释: -- 后面一定要加一个空格,否则会报错 2.注释:/*! content */ 在mysql中是会执行的,但是其他数据库不会. 例 ...
- 整合最优雅SSM框架:SpringMVC + Spring + MyBatis 基础
在写代码之前我们先了解一下这三个框架分别是干什么的? 相信大以前也看过不少这些概念,我这就用大白话来讲,如果之前有了解过可以跳过这一大段,直接看代码! SpringMVC:它用于web层,相当于con ...
- MySql创建函数与过程,触发器, shell脚本与sql的相互调用。
一:函数 1:创建数据库和表deptartment, mysql> use DBSC; Database changed mysql), ), )); Query OK, rows affect ...
- 基于Kafka+Spark Streaming+HBase实时点击流案例
背景 Kafka实时记录从数据采集工具Flume或业务系统实时接口收集数据,并作为消息缓冲组件为上游实时计算框架提供可靠数据支撑,Spark 1.3版本后支持两种整合Kafka机制(Receiver- ...
- 4.9 Routing -- Query Parameters
一.概述 1. 在URL中查询参数是可选的key-value对,出现在?的右边.例如,下面的URL有两个查询参数,sort和page,对应的值分别是ASC和2. example:http://exam ...
- vim tab设置为4个空格
为了vim更好的支持python写代码,修改tab默认4个空格有两种设置方法: 1. vim /etc/vimrc 1 set ts=4 2 set sw=4 2. vim /etc/vimrc 1 ...