软件需求规格说明书通用模版_通用需求挑战和机遇

软件需求规格说明书通用模版

When developing applications there will be requirements that are needed on more than one application. Examples of such common requirements are non-functional, cookie consent and design patterns. How can we work with these types of requirements in a smart way across several applications and teams, without adding bureaucracy and increased lead time?

开发应用程序时,将需要多个应用程序的需求。 此类常见要求的示例包括非功能性,Cookie同意和设计模式。 在不增加官僚主义和增加交货时间的情况下,我们如何在多个应用程序和团队中以明智的方式满足这些类型的需求?

It is a common challenge, that we work in silos, developing “our own” application within one organization. Each application has their stakeholders, product owner, scrum master, user experience, business analyst, architect, developers… In the beginning it’s fine if you only have a few applications running, however what happens when you have 10 applications running? Consider each product team spending 8 hours analyzing a requirement, that means the organization is potentially wasting 72 hours on each requirement. And not only is it a waste during the initial development, consider the amount of waste during the full life-cycle from that one requirement.

一个普遍的挑战是,我们在孤岛上工作,在一个组织内开发“我们自己的”应用程序。 每个应用程序都有其利益相关者,产品所有者,Scrum管理员,用户体验,业务分析师,架构师,开发人员...刚开始时,如果只运行几个应用程序就可以了,但是当您运行10个应用程序时会发生什么呢? 考虑每个产品团队花费8个小时来分析需求,这意味着组织可能在每个需求上浪费72个小时。 不仅在最初的开发过程中浪费了资源,还考虑了该需求在整个生命周期中的浪费量。

So why do we implement solutions in silos? The answer is that it’s often quicker. We want to deliver with speed to the market, and it’s often easier and faster to do the solution within the team rather than having to rely on other teams, their priorities and time available. Autonomy in all its glory, but sometimes it makes more sense to work across product teams to ensure we work smart and deliver sustainable solutions. And does it really have to take longer just because we work across several product teams?

那么为什么我们要在孤岛中实施解决方案呢? 答案是它通常更快。 我们希望将产品快速推向市场,通常在团队内完成解决方案变得越来越容易,而不必依赖其他团队,他们的优先级和可用时间。 自治具有其所有的荣耀,但有时跨产品团队工作更有意义,以确保我们明智地工作并提供可持续的解决方案。 是否真的因为我们跨多个产品团队工作而需要花费更长的时间?

我们如何才能聪明地应对跨团队的需求? (How can we work smart with cross-team requirements?)

How can we in practice work to implement these requirements in a smart way to all relevant applications? There is, of course, the Spotify model, but if it’s too big a change or not the route you want to go down, this could be something to try out.

在实践中,我们如何才能以明智的方式对所有相关应用程序实现这些要求? 当然,有Spotify模型,但是如果变化太大或您不想沿途走的路线,可以尝试一下。

Image for post
  1. Someone has an idea or are working on a requirement when they realize that this is a requirement that would bring value to other applications within the organization as well.

    当某人意识到这是一个需求,并且会为组织内的其他应用程序带来价值时,他们就有想法或正在研究需求。
  2. All product owners meet to discuss the requirement, perform a quick analysis to determine if it brings value, if it’s achievable and if it’s a priority right now within the organization. They collaboratively make a decision on how to best move forward, they set a course of action. The course of action might be that it should be developed by two teams that will work together on further analyzing and developing the solution.

    所有产品负责人开会讨论需求,进行快速分析,以确定它是否带来了价值,是否可以实现以及当前是否已成为组织内的优先事项。 他们共同决定如何最好地前进,并制定了行动方案。 行动过程可能是由两个团队共同开发,这两个团队将共同努力进一步分析和开发解决方案。
  3. The two product teams collaborate and do a more thorough analysis to determine the smartest and most sustainable solution for the organization as a whole. Once implemented on one application (possibly as a shared component), the other product teams use the created solution for a “quick” implementation on their applications.

    这两个产品团队合作并进行更彻底的分析,以确定整个组织最明智,最可持续的解决方案。 一旦在一个应用程序(可能作为共享组件)上实现,其他产品团队便使用创建的解决方案在其应用程序上实现“快速”实施。
  4. The product owners update all product owners on status and inform about the chosen solution that are being implemented so that they can prepare their teams for what’s coming. Once all applications has implemented the requirement the requirement is set to done. The team does a quick retrospective to learn and adapt.

    产品负责人向所有产品负责人更新状态,并告知他们正在实施的所选解决方案,以便他们为即将发生的事情做好准备。 一旦所有应用程序都实现了需求,就将需求设置为完成。 团队进行快速回顾以学习和适应。

Benefits from working this way

这样工作的好处

  • Transparency and cross-team collaboration

    透明度和跨团队合作
  • Smart and cost-effective

    精巧且具有成本效益
  • Speed in delivering critical changes on all applications

    加快在所有应用程序上交付关键变更的速度
  • Align tech solutions and user experience

    调整技术解决方案和用户体验

顺利过渡到这种工作方式的先决条件是什么? (What are the prerequisites for a smooth transition to this way of working?)

Stakeholder alignmentWhen delivering software, we deliver something the customer needs, that is technically feasible and sustainable and that works for the business. So why is there still so much politics involved? Most commonly due to team or product bonuses which leads to misalignment, endless discussions and incorrect priorities. Bonuses should only be based on total company success. This makes the decisions easier and everyone working towards one common, unified goal.

与利益相关者保持一致在交付软件时,我们交付客户需要的,技术上可行且可持续且对企业有效的东西。 那么为什么还涉及这么多的政治? 最常见的是由于团队或产品的奖金而导致的偏差,无休止的讨论和不正确的优先级。 奖金仅应基于公司的整体成功。 这使决策更加容易,每个人都朝着一个共同的统一目标努力。

We are in this togetherCompany culture must be about the best for the company in totality. You get rewarded when you work for the best sustainable solution for the whole organization. There are, of course, times where speed is more important than quality, for example when performing proof-of-concept, to allow for early feedback, but then once you know you are building the right thing we need to take a step back and look at the best solution for the company.

我们在一起,公司文化必须对公司整体而言是最好的。 当您为整个组织寻求最佳的可持续解决方案时,您将获得奖励。 当然,在某些时候,速度比质量更重要,例如在进行概念验证时,可以及早反馈,但是一旦您知道要构建正确的东西,我们就需要退后一步,为公司寻找最佳解决方案。

Team missionTeams want to know they are working on creating value, they want to be proud of what they are developing, they want to work smart and rest assured that they are contributing to the overall organization in the best way possible. Contribution to the bigger picture has to be part of the culture and be part of each teams mission statement, cross-team collaboration should be noticed and rewarded.

团队使命团队希望知道他们正在努力创造价值,他们为自己的发展感到自豪,他们想要聪明地工作,并放心他们以最佳方式为整个组织做出了贡献。 对大局的贡献必须是文化的一部分,也是每个团队使命宣言的一部分,跨团队的合作应引起注意和奖励。

Let data and learning lead the decisionsThe challenge with working across teams is that more people are involved which leads to more opinions and ultimately to longer lead times. But with an agile mindset, basing the decisions on data and learning, it shouldn’t have to end up with endless discussions. The requirement that brings highest value is the one we work on first and the team that will tackle the initial solution is the team that is most fit to do so at that moment in time.

让数据和学习来领导决策跨团队工作所面临的挑战是,需要更多的人参与,这将导致更多的意见并最终导致更长的交付时间。 但是,基于敏捷的思维方式,将决策基于数据和学习,就不必结束无休止的讨论了。 带来最高价值的要求是我们首先致力于的,而解决初始解决方案的团队是当时最适合这样做的团队。

It’s important to clarify, that not everything is a common requirement. Your organization needs to decide what is and what is not; it should only be treated as a common requirement if it brings value by analyzing and delivering them in a cross-team collaborative way.

需要澄清的是,并不是所有的东西都是一个共同的要求。 您的组织需要决定什么是什么,什么不是。 只有通过以跨团队协作的方式分析和交付价值来带来价值时,才应将其视为一项共同需求。

我很想听听你的故事 (I would love to hear your story)

If you have faced or are facing a similar challenge, I would love to hear your story.

如果您面临或正面临类似的挑战,我很想听听您的故事。

翻译自: https://medium.com/@wiveka.goransson/generic-requirements-challenges-and-opportunities-9ec8c712840a

软件需求规格说明书通用模版

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

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

相关文章

python版PCA(主成分分析)

python版PCA(主成分分析) 在用统计分析方法研究这个多变量的课题时,变量个数太多就会增加课题的复杂性。人们自然希望变量个数较少而得到的信息较多。在很多情形,变量之间是有一定的相关关系的,当两个变量之间有一定…

干货|Spring Cloud Bus 消息总线介绍

2019独角兽企业重金招聘Python工程师标准>>> 继上一篇 干货|Spring Cloud Stream 体系及原理介绍 之后,本期我们来了解下 Spring Cloud 体系中的另外一个组件 Spring Cloud Bus (建议先熟悉 Spring Cloud Stream,不然无法理解 Spr…

一类动词二类动词三类动词_基于http动词的完全无效授权技术

一类动词二类动词三类动词Authorization is a basic feature of modern web applications. It’s a mechanism of specifying access rights or privileges to resources according to user roles. In case of CMS like applications, it needs to be equipped with advanced l…

主成份分析(PCA)详解

主成分分析法(Principal Component Analysis)大多在数据维度比较高的时候,用来减少数据维度,因而加快模型训练速度。另外也有些用途,比如图片压缩(主要是用SVD,也可以用PCA来做)、因…

thinkphp5记录

ThinkPHP5 隐藏index.php问题 thinkphp模板输出cookie,session中… 转载于:https://www.cnblogs.com/niuben/p/10056049.html

portainer容器可视化管理部署简要笔记

参考链接:https://www.portainer.io/installation/ 1、单个宿主机部署in Linux:$ docker volume create portainer_data$ docker run -d -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer 2、单…

证明您履历表经验的防弹五步法

How many times have you gotten the question “Tell me more about your work experience at …” or “Describe an experience when you had to overcome a technical challenge”? Is your answer solid and bullet-proof every single time you have to respond? If no…

2018-2019-1 20165231 实验四 外设驱动程序设计

博客链接:https://www.cnblogs.com/heyanda/p/10054680.html 转载于:https://www.cnblogs.com/Yhooyon/p/10056173.html

如何安装pylab:python如何导入matplotlib模块

pylab是python下挺不错的一个画图模块,使用也非常简单,记得Mit的计算机科学及编程导论有节课也是用到了这个工具,但这个工具安装不象用起来那么方便,小编就图文全程直播下吧 工具/原料 python2.7.10win10 32位方法/步骤 1缺省状态…

微信扫描二维码和浏览器扫描二维码 ios和Android 分别进入不用的提示页面

实现微信扫描二维码和浏览器扫描二维码 ios和Android 分别进入不用的提示页面 而进入商城下载该项目 详情地址:gitee.com/DuJiaHui123… 1.创建完之后 替换文件里面的ios项目地址和Android地址 2.网页上线 3.百度搜索 二维码生成 把上线后的地址生成二维码 4.可以把…

详解getchar()函数与缓冲区

1、首先,我们看一下这段代码: 它的简单意思就是从键盘读入一个字符,然后输出到屏幕。理所当然,我们输入1,输出就是1,输入2,输出就是2。 那么我们如果输出的是12呢? 它的输出是1。 这…

windows下python安装Numpy、Scipy、matplotlib模块

python 2.7 针对2.7的软件。numpy :http://sourceforge.net/projects/numpy/files/NumPy/1.8.1/ 下载下面的numpy-1.8.2-win32-superpack-python2.7 scipy: http://sourceforge.net/projects/scipy/files/matplotlib:matplotlib-1.1.0.win32-py2.7 以上都是exe文件&#xff0…

restTemplate使用和踩坑总结

日常工作中肯定会遇到服务之间的调用,尤其是现在都是微服务的架构,所以总结一下restTemplate的最常用的用法以及自己踩过的坑。 restTemplate的使用 restTemplate底层调用的是Execute方法,而Execute底层调用的是doExecute,它是基于…

常见编码总结

本文总结自:https://blog.csdn.net/zmx729618/article/details/51821024 1. ISO 8859-1 字节数:1 范围:0-255(编码范围是0x00-0xFF),其中0x00-0x7F之间完全和ASCII一致(ASCII是7位编码&#xff…

启动一个Java进程

windows版本 startup.bat -------------------------------------------------------- rem --------------------------------------------------------------------------- rem Start SMS Server by zhangjin rem --------------------------------------------------------…

Flask框架从入门到精通之参数配置(二)

知识点: 1、参数配置 一、概况 上一篇我们已经把Flask第一个程序运行起来了,那么这一篇主要讲一下Flask参数的配置。 二、配置参数 Flask参数配置方式有很多种,每一种都可以达到结果,在合适的场景选择合适的配置方式。 配置文件 在…

BP神经网络python简单实现

BP神经网络的原理在网上有很详细的说明,这里就不打算细说,这篇文章主要简单的方式设计及实现BP神经网络,并简单测试下在恒等计算(编码)作测试。 BP神经网络模型图如下 BP神经网络基本思想 BP神经网络学习过程由信息的…

golang的reflection(转)(一)

2019独角兽企业重金招聘Python工程师标准>>> 反射reflection 可以大大提高程序的灵活性,使得interface{}有更大的发挥余地反射可以使用TypeOf和ValueOf函数从接口中获取目标对象信息反射会将匿名字段作为独立字段(匿名字段的本质)…

idea教程--Maven 骨架介绍

简单的说,Archetype是Maven工程的模板工具包。一个Archetype定义了要做的相同类型事情的初始样式或模型。这个名称给我们提供来了一个一致的生成Maven工程的方式。Archetype会帮助作者给用户创建Maven工程模板,并给用户提供生成相关工程模板版本的参数化…

datatables.js 简单使用--多选框和服务器端分页

说明:datatables是一款jQuery表格插件。感觉EasyUI的datagrid更易用 内容:多选框和服务器端分页 缘由:写这篇博客的原因是datatables的文档写的不怎么样,找东西很麻烦 环境:asp.net mvc , vs2015sqlserver2012 显示效…