程序员的工作方法

开发流程与思考

DoD 验收标准列表
  1. DoD的每一个检查项都是可验收的
  2. 在开始着手于一件事上时,就需要确定好细节项
  3. 尽快消除不确定项,达成共识
精益创业
  1. 面向不确定性创建新事物
  2. 方式论:创建(build )-测量(measure)-认知(learn),三者循环迭代
  3. 用最少的成本,干有价值的事
  4. 作为一个开发人员。在平时,产品提出的需求虽然可行,但在当下有限的人力,物力,时间的,及该需求的重要度低的情况下可延后处理。
  5. 开发人员遵循开发原则是 当需求来临时,你需要知道它为什么要做,有什么意义与好处(可通过用户故事体现),才能去做。而不应该逆来顺受,来什么,做什么。

开发方式

从未来考虑问题
  1. 进行一次沙盘模拟
  2. 从结果入手,如果需要开发一个产品。待入上线后的情况,从未来考虑,比如上线时需要什么配置,上线后系统崩溃怎么办,线上数据如何准备?
分解任务
  1. 不同层级的人,任务分解程度不同,比如作为一个刚了解开发的人,将任务,分为 获取链接,分析,上传三步。
  2. 当任务得到合理的分解,执行起来也就按部就班,有条不紊。
  3. 分解成各个微操之后,也会让任务执行得以拥抱变化。当被打断时候,能很容易开启下一个流程的开发。
  4. 做好微任务的安排
测试先行
  1. 测试 - 开发 - 重构 环环相扣
  2. 测试先行可以更好理清当前开发的需求,完成特定需要的功能

代码防腐

代码的不断交接,不断腐化
  1. 当需要维护一段代码时,每个人只是完成了当时一部分的工作,代码中的异味会越来越重
  2. 开发人员每当维护别人的代码时,总是觉得别人的代码很乱。给这段代码添加新功能时,不免产生 “代码都这样了,我不能乱改,我只能按照它原来的风格,就给它添加功能就好了” 的想法。
  3. 解决方法:设计原则,SOLID。
设计模式,设计原则?
  1. 在编程时,总想着去套用一系列设计模式,当有时却适得其反。
  2. 无法正确使用设计模式,或感觉其无用,往往是因为没有形成自己的知识体系。
  3. 设计模式只是战略上的建议,要想形成体系,灵活运用就得领悟设计原则。
  4. 在遵循SOLID原则的前提下,进行编码,在不经意间就能使用到设计模式,尽管你不知道模式的名称
  5. 比如,单一职责:
    1. Robert Martin的架构整洁之道中,描述单一职责为 “一个模块仅仅对一类 角色 负责”
    2. 有一个Employee类,有三个方法 :
      1. calculatePay() 是财务部门关心的
      2. reportHours() 是人力资源部门关心的
      3. save() 是系统业务部门关心的
      4. 因为calculatePay与reportHours都有 正常工作时间的计算,为了避免重复将它抽为 regularHours方法
    3. 现 财务部门修改正常工作时间的方式,人力资源部不需要修改。你只看到了calculatePay调用了regularHours,所以修改了regularHours,然而却导致人力资源部查询的错误,从而导致公司受损
    4. 此处的regularHours 在为不同的 角色 服务,所以一旦需求变化,它就是修改的重灾区
    5. 这个时候,就应该将上述三个方法分拆为三个面向不同角色的类
  • 小到开发中的每个方法,对象。大到对大型系统架构的微服务拆分,转型。 都需要 识别不同actor,正确理清限界的上下文,划分能够独自演进的功能模块

维护他人代码时

当接手一项新工作,新环境时

1.业务
  1. 第一步先理解工作业务(做什么,解决了什么,流程是什么)
2.技术
  1. 了解技术栈
  2. 系统的业务架构是什么(有哪些模块,与哪些外部系统有交互)
  3. 外部接口方式,承接的协议是什么
  4. 内部各个模块如何划分,模块职责是什么,分层抽象的东西是什么
  5. 系统构建的脚本,代码的结构怎么样的
3.团队运作
  1. 外部:需求来源是那儿,产品和面向的用户是谁
  2. 内部:定期的和日常活动有什么,企业文化

当接手一个你认为很烂的系统时

1. 创建测试防护网
2. 逐步拆分,逐步整改,逐步替换 - 小步快跑
3. 构建好独特的领域模型,利于划定不同角色,限定运作上下文
4. 在构建时,参考行业内对于系统构建比较成熟的理解。比如构建电商领域时,可供参考的领域模型非常成熟
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,273评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,349评论 3 398
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,709评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,520评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,515评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,158评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,755评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,660评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,203评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,287评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,427评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,122评论 5 349
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,801评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,272评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,393评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,808评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,440评论 2 359

推荐阅读更多精彩内容

  • 中国有很多年轻人,他们18,9岁或21,2岁,通过自学也写了不少代码,他们有的代码写的很漂亮,一些技术细节相当出众...
    java成功之路阅读 2,796评论 1 7
  • 你好,我是郑晔,《10x 程序员工作法》专栏作者,火币网首席架构师。 程序员是一个忙碌的职业,与这个职业联系在一起...
    言射手阅读 792评论 0 3
  • WDW说:“愿今年所有的遗憾是明年惊喜的铺垫。” 走饭呢,发了一张和几个俄罗斯美女的自拍合影,说:“超想发的照片,...
    鲁长安阅读 164评论 0 0
  • 一、把事项分为A、B、C三类 二、在每类事项中按紧急+重要排序 A类:1.监考 2.批卷 3.交听课笔记 4.时间...
    蔷薇水灵阅读 120评论 0 0
  • 生而为人,体验为的快乐,这个快乐不是物质奢华,精神的奢靡,而是能做些自己的快乐是建立在别人快乐基础上的快乐!内心有...
    小邱520阅读 58评论 0 0