java开发文档怎么写_程序员该不该写技术文档,怎么写文档,易懂又能提升自己...

最近公司项目的调用量突然涨了一大波,很多系统都纷纷扛不住了,于是需要对系统进行优化,系统优化的第一步,便是梳理业务!

在这个过程中,经常出现了这样一些情况,发现数据库的某些字段,没有注释,也没有一定的文档来诠释它做什么作用。而这个项目又是多达20,30人一起开发维护的,没有人能够从头到尾说得清这个项目的主要流程。

写文档,似乎在国内的程序员,最不屑的一件事情了。作为一个程序员,有没有必要写技术文档呢?

bdee386490bb5e28a907df0cd7d88a12.png

要不要写文档

我们常说,Talk is cheap,show me your code。但是在实际的工作开发中,绝大部分情况,code才是最便宜的。工作的大部分时间,都是在进行业务的梳理,接口的沟通,剩下的,才是代码的编写与测试交付。

有些人会说,写文档是让老板跟容易找人替代你,也许现实生活中存在这样的情况,但是一个人能否被替代,更多的是自己有没有核心竞争力,每一个互联网产品,都是有生命周期的,如果你的核心竞争力就是掌握了现有系统的坑,还不如提升自我,让自己到哪都有饭吃!

也有人会说,写文档是写给老板们看的,对提升技术并没有多大的作用。这句话知识说对了一般,最近,我们有一项重要的项目要对客户与上面的老板进行汇报,再一次感受到会说话的重要性,对一些不太懂技术的人说技术,是一门学问。写代码,终究只是人与机器交流,而写文档,是人与人之间的交流,大部分程序员,都不可一辈子在单打独斗地写代码,学会与人交流,决定了你的上限。

也有人说,只有大公司才写文档,小公司,做的都是一次性的项目,写了文档又有什么用。写文档,其实并不是完全是写给别人看,更多的是,让你去进一步了解业务,了解技术,对业务进行梳理,站在一个更高的角度去思考整个系统。我有一个朋友,一开始只是一个外包公司的开发,但他非常擅于进行业务梳理,很快,他也自己出来开了一个外包公司,也过上奔小康的生活。

4a281bd71cff32a5c466868775a8196a.png

那么,如何写文档才能避免写流水账呢?怎么样写文档才能让所有的人都看懂。个人觉得,写文档最少要写两方面,一是总体设计,二是详细的技术方案。

总体设计文档

首先是需求与功能,用自然语言来描述这个系统要实现什么功能,有什么作用。经常有程序员想找挣外快的机会,可是连自己做的东西有什么用都说不清的,真的很难去合作或者谈到更高的价钱。

其次是架构与系统模块。这个系统涉及到哪些功能模块,每个模块之间的调用关系是什么样,最好有一个简单的架构图。

最后是一些方案的对比,我们常常被教育着去寻找标准答案,但是这个世界更多的是合适的方案。多思考一下有没有其他的方案,为什么最终选择这个方案,下次做到类似的需求,相信你会受益匪浅。

详细设计

详细设计,最重要的就是数据结构。这个功能主要有哪些数据,数据在计算机内部是以什么形式进行存储,表如何设计,这些都是至关重要。多年的写代码经验告诉我,一个系统如果常出问题,无论是业务问题还是性能问题,绝大部分原因都是因为数据结构没搞好。所以,在一些大型的公司,架构师的首要职责,便是梳理好基础的数据结构。

系统调用时序图,也就是交互流程,一个请求从一个系统流转到另外一个系统,顺序是什么样,各个系统又完成怎么样的责任,建议用时序图进行表达。

性能指标与可拓展性,最后,如何跳出当前的业务去思考整个一个系统,当前的系统如何去应对将来的业务拓展,如果流量增加性能瓶颈又在哪里。好的设计不是一蹴而就的,而是不停地进行思考和迭代。

1435e9884078942e0e4bbf0978296709.png

总结

程序员到底该不该写技术文档,相信你已经有答案。就好比盖房子,即使不用设计图,你也可以一边搬砖一边盖楼,但是,如果你想盖一个地标,一个摩天大楼,只有先有图纸,才能预估好整个大楼的空间、承重、稳定性。另一方面来说,当你拥有了图纸,拥有了画图的能力,盖房子不就是找一群建筑工的事情么?写代码亦是如此。

好了,今天我们就介绍道这里,欢迎大家关注我,整理后会和大家继续分享。大家的支持是我继续唠嗑的动力。同名公众号(沙茶敏碎碎念)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/503651.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java矩阵类_java矩阵类,矩阵的乘法

问题如下我采用的是3重循环,先计算的列的结果,应该还可以先计算行的结果,然后求出矩阵的乘法。没有过多的技巧,就是循环的使用。相关的codepackage day20180728;import java.util.Scanner;class Matrix{private int m,n;private i…

python个人网站系统_利用基于Python的Pelican打造一个自己的个人纯静态网站

其实呢这么多年以来我一直建议每个有技术追求的开发者都要有写技术博客记笔记的良好习惯,一来可以积累知识,二来可以帮助别人,三来可以把开发中遇到的问题记录用来自省,第四可以通过交换友链来结识更多的技术领域的同仁。之前我曾…

java 编译宏_java – 制作一个“宏”命令来运行程序

(编辑:根据您的评论,让我展开以添加更多情况)如果您的目标是让其他人运行您没有安装Java的程序,并且您不希望让他们在运行您的应用程序之前安装Java运行时环境,那么您需要的是一个转换.class或.jar的程序将文件转换为您正在使用的平台的本机可执行文件.其他问题涉及…

python在工厂中的运用_在python中使用元类实现工厂设计模式

我很乐意听到人们对此的评论,但我认为这是你想做什么的一个例子class FactoryMetaclassObject(type):def __init__(cls, name, bases, attrs):"""__init__ will happen when the metaclass is constructed:the class object itself (not the instanc…

java多线程教程_java 基础教程之多线程详解及简单实例

java 多线程详解在这篇文章里,我们关注多线程。多线程是一个复杂的话题,包含了很多内容,这篇文章主要关注线程的基本属性、如何创建线程、线程的状态切换以及线程通信。线程是操作系统运行的基本单位,它被封装在进程中&#xff0c…

多个for语句嵌套执行顺序_阿里真实面试题解析之实现多个线程顺序执行的几种方式...

前几天有一位同事在阿里一面的时候被问到这么一个多线程问题:如何保证多个线程的顺序执行。当时他没有回答上来,所以为了避免大家以后遇到同样的面试题还是回答不上来,今天我们就来分析解答下这个问题。问题缘由由于线程执行是靠CPU分时间片来…

java filter过滤器 网站访问量_Servlet过滤器实现网站访问计数器功能

实现网站在线访问计数器功能,网站的初始值设置为1000(1)创建CountFilter的类,实现javax。servlet.Filter接口,是一个过滤器对象,通过过滤器实现统计网站人数功能:package com.lixiyu;import java.io.IOException;impor…

js立即执行函数_《JS 函数的执行时机》

1 、为什么如下代码会打印 6 个 6let i 0 for(i 0; i<6; i){setTimeout(()>{console.log(i)},0) }那是因为setTiout函数的意义是‘做完当前的事情&#xff0c;再去执行’0代表时间&#xff0c;表示做完循环立刻打印i的值&#xff0c;所以 i的值经过for循环已经循环到6&…

java微信demo_微信登陆 , 简单的demo , java

这几天简单的做了一下微信登陆的demo&#xff0c;希望对大家有帮助不多说&#xff0c;直接上代码&#xff1a;/**** author TY**/ControllerRequestMapping("/wechatlogin")public class WechatLoginController {/*** 请求CODE** param response* throws Exception*/…

windows的python切换环境_Windows下的python虚拟环境设置

Windows下的python虚拟环境设置&#xff1a;virtualenv在python开发中&#xff0c;我们可能会遇到一种情况&#xff1a;就是当前的项目依赖的是某一个版本&#xff0c;但是另一个项目依赖的是另一个版本&#xff0c;这样就会造成依赖冲突。在这种情况之下&#xff0c;我们就需要…

python怎么理解_讨论 - 廖雪峰的官方网站

我的电脑是win7x64的系统安装的是Python3.4.3这是hello.py模块!/usr/bin/env python3-- coding: utf-8 --just a testauthor HZFimport sysdef test():args sys.argvif len(args)1:print(Hello world!)elif len(args)2:print(Hello %s! % args[1])else:print(Too many argume…

java visitor_java11教程--接口FileVisitor用法

文件的访问者。该接口的实现被提供给Files.walkFileTree方法以访问文件树中的每个文件。用法示例&#xff1a;假设我们要删除文件树。 在这种情况下&#xff0c;删除目录中的条目后&#xff0c;应删除每个目录。Path start ...Files.walkFileTree(start, new SimpleFileVisito…

postscript怎么打开_怎么把在学习中用的Adobe PDF文件转换成Microsoft office Word

现在我们普遍用的都是Adobe PDF格式的文件&#xff0c;可是Microsoft office Word&#xff08;.doc,.docx&#xff09;文档也是我们经常要用的&#xff0c;所以就需要将Adobe PDF转换Microsoft office Word&#xff08;.doc,.docx&#xff09;文档了&#xff0c;怎么将Adobe PD…

python类实例覆盖_避免类实例覆盖默认值

我正在处理初始化类的问题。下面是一个复制的例子&#xff0c;突出了潜在的问题(我没有设法使它小得多)&#xff1a;课程我们有两个类A,B。等级制度A&#xff1a;第一类实例有两个属性link;name^{cd2>的一个属性是这个类的。在为了更快地声明B的实例&#xff0c;我考虑了以下…

vector父类类型可以存放子类吗_拼夕夕三轮面经:被问到反射和泛型的bug,你踏空了吗?...

点击上方“JavaEdge”&#xff0c;关注公众号设为“星标”&#xff0c;好文章不错过&#xff01;1 当反射遇见方法重载重载grade方法&#xff0c;入参分别为int、Integer。若不通过反射这种高级编程方式&#xff0c;选用哪个重载方法自然很清晰&#xff0c;比如传666走int参数重…

雨林木风系统封装工具封装xp_如何用小丸工具大幅度压缩视频且画质损失较小?...

如何大幅度把视频体积压下去&#xff0c;并保持清晰度&#xff0c;就只有用比视频原本低的码率&#xff0c;降低分辨率和压缩音频这三种方法。降低码率可以使用CRF来控制&#xff0c;值越大码率越小&#xff0c;成反比。一些录屏和直播的视频产生的码率都很高&#xff0c;文件体…

tinkerpop mysql_图论数据库未来的发展方向?

Zete 提到了agens graph&#xff0c;个人关注这个项目也有一段时间了&#xff0c;确实非常不错&#xff0c;基于pg良好的可扩展性和近一年来逐渐成熟的open cypher。这其实反应了图数据库多个分支的一个&#xff0c;即基于关系型数据库构建图数据库。微软的GraphView也是这一派…

java list能作为入参吗_springmvc 不支持 List 对象作为 方法的参数

springmvc 不支持 复杂对象的 list 或者 数据对象作为参数的。 只能是 写一个 VO了 这样是不可以的 RequestMapping("/add") public void add(Model model,List sysRole){但是如果是基本的类型是可以的 说了那么多基础类型和引用类型区别&#xff0c;最主要的一点就…

python win32ui_Python创建普通菜单示例【基于win32ui模块】

本文实例讲述了Python创建普通菜单的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;一、代码# -*- coding:utf-8 -*-#! python3import win32uiimport win32apifrom win32con import *from pywin.mfc import windowclass MyWnd(window.Wnd):def __init__ (self):w…

java 变量作用域 c语言_C语言深入理解 - 常量与变量

《C语言深入理解系列 - 常量与变量》查看其它博文请关注原创作者。本文系本站原创,欢迎转载! 转载请注明出处:常量与变量正所谓静中有动&#xff0c;动中有静&#xff0c;常量与变量亦是如此&#xff0c;它们之前相互依赖&#xff0c;相互影响。关于常量与变量&#xff0c;很多…