《软件开发本质论》笔记——了解价值,然后从可能去做的所有事情中选择那些最重要的去做

news2025/6/11 8:07:57

目录

一、传统的软件项目分阶段进行

二、根据”挑战性的目标“制订计划,危害性很大

三、推荐随时发现缺陷随时修复

四、 价值是什么


一、传统的软件项目分阶段进行

 潜在风险:试图去计划并实现所有的功能特性,这使我们处于不利的境地。我们完全没有时间去改变,而且即使有时间,也不可能理清哪些事情不该做,哪些事情应该做。

作者建议:从一开始就计划多次发布版本。多次发版更容易管理,也能够更早交付价值。以这种方式构建软件更容易,同时所有人都能够共赢。

个人理解: 实际项目中,需要综合考虑需求大小、改动风险、人力资源、业务诉求紧急程度等等,来评估是否需要多次发布,每次发布的大小等等。 在某些情况下,本可以1次发布的项目,硬拆成分2次发布,反而增加了额外的成本。 

二、根据”挑战性的目标“制订计划,危害性很大

        在制订计划(特别是短期计划)时,人们往往会设定”挑战性目标“或者”鼓励“团队”再多完成一个功能特性“。

作者建议: 不要这样做。 因为团队真的会尝试这样做。由于急于讨好上司,他们会不自觉 赶工。为了多完成一个功能,会遗漏一些测试,并且写出的代码也不像以往那样清晰整洁。压力具有破坏性,请尽量避免向团队施压。

  • 赶工会给整个项目带来更多缺陷。修复缺陷往往花费更长的诗句。
  • 槽糕的代码同样影响进度。 如果代码清晰,下一个功能特性也会进展顺利;反之,如果代码很槽糕,所有功能特性可能都需要花费更长的时间。

三、推荐随时发现缺陷随时修复

缺陷引发的成本

  • 正如咨询师汤姆:狄马克(Tom DeMarco)所说,没有人会在看见餐厅地板上有一只蟑螂时说: ”瞧,有一只蟑螂“。 对于缺陷而言,情况也一样。 如果出现了一个缺陷,那就意味着可能会有很多缺陷。
  • 找出缺陷将花费很多时间,修复这些缺陷同样也要花费时间。

随时发现缺陷随时修复

  • 测试不但没有减慢开发速度,反而使其更快。 因为测试可以让我们犯更少的错误,同时使错误更快被发现。
  • 需要两个层面的测试: 

        ”业务“测试:验收测试驱动开发
        ”技术“测试:直接对代码测试,测试驱动开发。当进行开发人员层面测试时,测试用例在编写代码之前或者与代码一起完成的。 作为开发工作的一部分,测试可以阻止缺陷在程序中出现。 这笔直到我们认为编码已经完成时才进行测试要快得多。

 ps: 个人理解, ”技术“测试,在国外来说,主力是研发,写测试代码、与写业务代码同样重要。

四、 价值是什么

价值的用途: 基于价值决定要做什么,以及不做什么。我们会先做价值高的事情,将价值低的事情放到后面去做。

 

价值是什么: 简单来说,价值就是”我们想要的东西“、”我们看重的东西“

我们看重的东西(价值)举例:

  • 对商业上有用
  • 对客户有用
  • 信息。 我们可能为产品选择一个战略方向。我们认为需要了解用户都喜欢什么。因此构建了几个原型向潜在用户展示。
  • 我们的产品可能旨在挽救生命。 我们决定根据每个功能特性所能够挽救的生命数量,来确定接下来要开发哪些功能特性。
  • 我们的公司可能出现了资金周转困难。 因此我们决定找一些风险投资,并快速开发出样品,向潜在投资者展示。 这里我们看重资金,帮助公司继续经营下去。
  • 我们的产品运行速度比较慢,顾客因此选择其他产品。 我们决定推迟新的功能特性来提高软件的运行速度。 我们看重的是产品的运行速度
  • 我们的进度可能很慢, 完成全部功能特性需要花费的时间太长。所以我们决定推迟增加新的功能特性来精简软件,这样开发速度就能更快。 我们看重的是进度
  • 我们的产品可能展示一些很可爱的猫的照片。 这样做的目的是使人们露出笑脸,为他们的生活添加幸福。 我们看重的是人们的幸福

⭐️ 对所有人都适用的价值并不存在。 不论是公司还是个人,要想生存下去,就必须深入了解价值,然后从可能去做的所有事情中选择那些最重要的去做。 

选择价值,就是选择那些对我们重要的东西
所谓价值, 就是那些我们想要的东西。

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

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

相关文章

转行互联网,零基础应届生应该选择什么样的岗位作为切入点?

对于想要转行互联网的零基础小白,如果你耐心看完了这个答案,恭喜你已经找到了转行互联网的方法!我不说空的理论,也不讲心灵鸡汤,作为文艺青年,我只说经验,我是工作十三年的互联网老兵&#xff0…

整合第三方登录之微信扫码登录

📂文章目录🎓前言🏷️引入相关依赖🧱操作步骤📔生成微信登录二维码📔获取微信用户信息并实现微信注册登录💗总结🎓前言 前置条件:具备微信开发者资质。 通过微信开放平…

Contest2874 - 【在线编程平台】2022年计算机类数据结构作业14.20221215-1220

目录 问题 A: 大顶堆还是小顶堆? 问题 B: sort by age 问题 C: 统计字母个数 问题 D: 字母排序 问题 E: 算法10-6~10-8:快速排序 问题 A: 大顶堆还是小顶堆? 内存限制:128 MB时间限制:1.000 S标准输入输出 题目类…

数学建模国赛 2020B-穿越沙漠 第二关至第六关思路分享

穿越沙漠第二关至第六关思路 开始讲题之前唠嗑一下: 很感谢所有读者和粉丝对上一篇的第一关解题博文的喜欢,也收到很多人的称赞,我很高兴大家能喜欢我写的东西。 其实这道题的模型在建立之处就是对着六关通用的目标去写的,因为本…

现货黄金时间表怎么安排?

现货黄金交易时间表,最好每一个投资者打印一份出来,放在你的电脑旁边。为什么呢?以前我对现货黄金交易时间表也没有特别关心,为什么在二十四小时的全天候交易要花时间到这里面来呢? 黄金市场是一个全球性的市场&#x…

APP测试技术:ADB——安卓手机测试一座神奇的“桥”

前言: 近年移动互联网好比IT界的一条浩瀚银河,安卓手机测试可谓其中最璀璨的一颗明珠,这里有一座你不得不熟悉的桥--ADB 曾见过不少相关的文章或培训,不乏空谈多,实战少;期望大,效果差。也见过…

idea上传代码到GitHub,每一步附带注意事项(炒鸡炒鸡详细)

1. idea配置git 2. 在idea里面登录自己的GitHub账号 需要到GitHub生成token 点击后,翻到最底部,点击左侧导航栏的Developer settings,到达下面这张图 最后点击最底部的绿色按钮,然后复制token即可。 3. 在创建本地仓库&#xff0…

【强化学习基础】强化学习的基本概念:状态、动作、智能体、策略、奖励、状态转移

文章目录1.状态(State)2.动作(Action)3.智能体(Agent)4.策略(Policy)5.奖励(Reward)6.状态转移(State transition)7.智能体与环境交互…

生成模型6-重参数技巧

Stochastic Back Propagation (Reparametrization Trick) 本章主要介绍的是,神经网络用函数逼近器,那么我们将想想神经网络和概率图模型之间有什么关系呢?能不能用NN去逼近一个概率分布呢?把他们两结合到一…

如今的测试行业都怎么了?面试题有必要出这么难吗?

在测试行业摸爬滚打了十年左右的我,时不时会被公司要求去做面试官面试别人。在这段期间我也收到了不少的简历,面试了各种技术不一的人。许多候选人的工作年限都不少,基本都是在3~5年左右,但他们做的都是一些非常传统的项目&#x…

VB知识点-学业水平考试

目录 一、VB中常用的几个基本控件 二、VB工程常识 三、VB常用的基本数据类型​编辑 四、VB常用的标准函数 五、VB的基本运算 六、VB语句 (1)符号常量定义语句 (2)变量定义语句 (3)赋值语句 &…

BAT大厂Python面试题精选,看完后离拿到offer只有一步之遥(含答案)

Python是目前编程领域最受欢迎的语言。在本文中,我将总结华为、阿里巴巴等互联网公司Python面试中最常见的30个问题。每道题都提供参考答案,希望能够帮助你在求职面试中脱颖而出,找到一份高薪工作。这些面试题涉及Python基础知识、Python编程…

AOP注解方式进行增强接口

📚目录📚简介:💨进阶版🗺️未实现AOP效果🎢创建注解:💭创建注解切面🚀使用方式:🎉结束:📚简介: 需要对AOP有一…

【电商】电商系统---供应商管理

本文以电商系统中的供应商管理为讨论对象,分析了其中的管理、属性、流程等内容,希望能给你带来启发与思考。 前言 前天写了一篇“以商品流转了解系统模块”介绍,里面啰里啰唆的说了很多模块,每个都是系统的组成部分,都…

数字化程度持续推进,元宇宙逐步走向成熟

元宇宙是人类数字化生存的最高形态 根据观研报告网发布的《2022年中国元宇宙行业分析报告-行业现状与发展趋势分析》显示,元宇宙是一个平行于现实世界,又独立于现实世界的虚拟空间,是映射现实世界的在线虚拟世界,是越来越真实的数…

美国访问学者签证材料清单

美国访问学者签证材料清单: 1、有效护照:如果您的护照将在距您预计抵美日期的六个月内过期、或已损坏、或护照上已无空白的签证签发页, 请在前来面谈之前先申请一本新护照。 2、一张照片:于6个月内拍摄的5 X5厘米正方形白色背景的彩色正面照。请将照片用…

【多聚焦图像:GAN:无监督】

MFF-GAN: An unsupervised generative adversarial network with adaptive and gradient joint constraints for multi-focus image fusion (MFF-GAN: 具有自适应和梯度联合约束的无监督生成对抗网络,用于多焦点图像融合) 从梯度的角度来进行…

【蓝桥杯】第12届Scratch国赛中级组第7题 -- 博士汪出题

[导读]:蓝桥杯大赛是工业和信息化部人才交流中心举办的全国性专业信息技术赛事。蓝桥杯大赛首席专家倪光南院士说:“蓝桥杯以考促学,塑造了领跑全国的人才培养选拨模式,并获得了行业的深度认可。” 春雷课堂计划推出Scratch蓝桥杯…

业务中台的架构案例

业务中台目标 目标: 整体目标:高内聚、低耦合,便于开发和维护。五个方向:性能、可用性、扩展性、伸缩性、安全性。 原因: 单体架构的大泥球会导致业务迭代困难、无法针对性伸缩、故障没有隔离等问题,需要向…

Python核心编程三大神兽——迭代器、生成器 、以及装饰器

装饰器 装饰器概述 装饰器本质:函数闭包的语法糖,一个函数,该函数用来处理其他函数,在不改变源函数的情况下添加功能,装饰器的返回值可以是一个函数对象 使用场景:插入日志,事务处理&#xf…