软件团队的共担责任

问责制被认为是个人与其社会系统之间的纽带,它创造了一种将个人与其行为和绩效联系起来的身份关系。在入门系列的第一篇文章《超越工具和流程:成功软件开发团队的策略》中,我们介绍了问责制的概念,并提出了以下定义:

期望对自己的行为负责,并需要在未来向他人提供此类行为的解释和理由。

无论集体的性质如何,从二元组到文明,解决其成员之间利益分歧的协调与合作都是必不可少的。问责制通过在社会系统中建立共同的期望来发挥作用。当制定了标准和期望时,人们必须遵守,否则可能会受到惩罚。社会系统的各个层面都会评估对标准的遵守情况,包括个人、二元组、团体、组织和整个社会。

问责制是所有社会(包括组织)的基本推动因素。如果社会体系缺乏问责制,个人行为将不顾他人造成的后果。因此,组织可能发现有效管理其运营具有挑战性。在软件开发中,问责制早在 80 年代的先驱者工作中就得到了承认。在 Barry W. Boehm 关于“软件工程七项基本原则”的论文中,他提出了一项确保对结果负责的原则,即“对结果保持明确的责任制”。

此外,“问责制”在 Scrum 指南中出现了九次。该指南非常强调问责制作为一种控制机制,例如“让彼此 [开发人员和团队成员] 以专业人士的身份承担责任”。那么,问责制如何控制和改善软件团队的成果呢?

图 1 直观地展示了追究责任的过程。它由一个评估过程组成,在这个过程中,个人要对自己的行为和决定负责,并受到特定社会文化背景下的人际、社会和结构因素的指导。受众会评估个人是否符合预先定义的规则、标准、官方和非官方期望以及共同规范,从而给予奖励或处罚。作为回应,个人会发展出各种应对机制,既有主动的,也有被动的,以维护和维持其社会体系中一致的自我形象。其中一些机制可能包括认知策略,例如将行动与受众偏好保持一致,或事后合理化,即个人用理由和借口为过去的行为辩护。虽然传统的问责理论通常将“受众”视为一个单一的实体,但它可以解构为一个由多个参与方组成的网络,个人需要对这些参与方负责。

在我们最近的研究中,我们研究了软件工程中问责制的构成要素,报告称,软件团队成员需要对多个问题承担个人和集体责任。

图 1:社会体系问责制的动态

项目成果,主要是软件质量、软件安全性和满足项目期限。业务分析师与软件团队中的其他角色共同承担这些成果的责任。

业务分析师 (BA) 共同负责软件质量、安全性和项目期限,因为他们的职责涉及定义直接影响这些结果的需求。通过收集业务需求并将其转化为技术规范,BA 可确保软件符合质量标准并按预期运行,这对于最大限度地减少缺陷和安全漏洞至关重要。此外,他们在生成构建软件的需求工件方面的作用会影响时间表,使团队工作与项目期限保持一致。当 BA 无法提供准确及时的需求工件时,就会对时间表产生影响。因此,让他们与开发人员和其他团队成员一起承担责任。

正式问责

组织有意实施策略来推动软件团队成员的责任感。这些制度化的驱动因素包括财务奖励、职业发展和惩罚。这些正式化的策略影响个人对责任感的看法,从而塑造他们对实现团队预期结果的承诺。虽然奖励旨在强化积极的表现,但惩罚旨在起到威慑作用,通过让工程师意识到潜在的负面后果来阻止他们表现不佳。

财务奖励。在上述研究中,我们发现软件团队成员在一定程度上受到财务奖励前景的激励,以满足既定期望。其中一些奖励包括财务激励,特别是与绩效评估挂钩的年度奖金。财务奖励,无论是奖金、加薪还是晋升,都用于坚持责任感并激励个人满足既定期望。

职业发展。在我们的工作中,职业发展也被认为是一种激励责任感的因素。组织会通过职业发展来奖励达到预期结果的期望。我们的研究结果表明,在软件专业职业中获得晋升的动力与表现出强烈的责任感密切相关。

惩罚。组织采用惩罚策略来激励表现不佳的团队成员达到或超过既定的预期结果。惩罚策略包括纠正措施(如绩效改进计划)和失业。惩罚策略表明,在某些情况下,组织致力于通过对未能达到预期结果实施明确的惩罚来推动软件专业人员的责任感。

控制机制是组织制定或嵌入软件开发实践的各种流程、工具和程序,旨在确保个人能够履行职责并遵守既定期望。在问责制的动态和流程中,控制机制属于图 1 中的“评估”。为了控制制度化的正式问责制,绩效评估作为一项问责制定期进行。这些定期评估推动了问责制,因为它们要求对组织就预定义期望的绩效负责,依靠代码中的缺陷计数和同行的反馈等指标,确保工程师始终如一地努力达到或超过组织既定的期望。

共同责任

共享或非正式的责任感源自同事的期望和软件专业人员的内在驱动力。前者促进了一种集体责任感,个人感到有必要回报同事并向同事展示自己的责任感,而后者则是天生的,具有内在基础。当软件专业人员感到内在驱动力以达到某些结果(例如,代码质量或按时完成任务)时,他们会表现出一种自我驱动的责任感。这种自我要求的责任感源于个人渴望超越或达到自我要求的标准,反映了软件专业人员的内在承诺和动机,即坚持和保持其交付成果的质量与他们的职业和个人价值观保持一致。共享责任感主要通过软件工程和开发实践(即测试和代码审查)以及同事的反馈来强化。

这种基于同行的问责制使用软件开发实践中固有的控制机制,例如测试或非正式同行的反馈,而不是既定组织的流程(如绩效评估)。

非正式或共享责任归因于团队的共同规范。然而,回报并不类似于正式的责任制(即财务奖励和职业发展)。在软件开发环境中,软件专业人员对同事的期望感到有责任,希望得到同事的评价,并为集体努力做出贡献。此外,避免团队层面的制裁。相反,我们的研究表明,软件团队更喜欢一种心理上安全的方式来应对表现不佳。

软件专业人员的责任不仅受到制度化机制(例如绩效评估)的影响,还受到同事的期望和内在动机的影响。虽然绩效等传统责任控制机制在软件团队中具有相关性,但它们与同事驱动和内在动机驱动的责任共存。

我们的工作表明,软件专业人员对同事驱动和内在动机驱动的责任有着天然的倾向。因此,在下一篇文章中,我们将深入探讨这种责任如何发生以及如何有助于满足团队成果的期望。

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

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

相关文章

【Python爬虫实战】深入解析 Scrapy:从阻塞与非阻塞到高效爬取的实战指南

🌈个人主页:易辰君-CSDN博客 🔥 系列专栏:https://blog.csdn.net/2401_86688088/category_12797772.html ​ 目录 前言 一、阻塞和非阻塞 (一)阻塞 (二)非阻塞 二、Scrapy的工作…

【Python数据分析五十个小案例】电影评分分析:使用Pandas分析电影评分数据,探索评分的分布、热门电影、用户偏好

博客主页:小馒头学python 本文专栏: Python数据分析五十个小案例 专栏简介:分享五十个Python数据分析小案例 在现代电影行业中,数据分析已经成为提升用户体验和电影推荐的关键工具。通过分析电影评分数据,我们可以揭示出用户的…

第八篇:CamX RawHdr Feature Enable

CamX RawHdr Feature Enable RawHdr feature介绍: 试用于拍照场景,输入3张Raw,输出一张Raw。 对应的pipeline: camxSWMFMergeRaw.xml (usecases: UsecaseZSL) featureGraph: RTRawHDRBayer2YUVJPEG ​ RT -> RawHdr -> Bayer2Yuv -> JPEG RTRawHDRBayer2YUVJPE…

Python毕业设计选题:基于django+vue的期货交易模拟系统的设计与实现

开发语言:Python框架:djangoPython版本:python3.7.7数据库:mysql 5.7数据库工具:Navicat11开发软件:PyCharm 系统展示 系统首页 期货信息 个人中心 管理员登录界面 管理员功能界面 用户管理 期货公司管理…

文件内容扫描工具

简介 文件扫描助手是一款基于Vite Vue 3 Electron技术栈开发的跨平台桌面应用程序。它提供了强大的文件内容搜索功能,支持Word、Excel、PDF、PPT等常见办公文档格式。用户可以通过关键词快速定位到包含特定内容的文件,极大地提高了文件管理和查找效率…

数据结构--AVL树(平衡二叉树)

✅博客主页:爆打维c-CSDN博客​​​​​​ 🐾 🔹分享c、c知识及代码 🐾 🔹Gitee代码仓库 五彩斑斓黑1 (colorful-black-1) - Gitee.com 一、AVL树是什么?(含义、性质) 1.AVL树的概念 AVL树是最…

【算法】连通块问题(C/C++)

目录 连通块问题 解决思路 步骤: 初始化: DFS函数: 复杂度分析 代码实现(C) 题目链接:2060. 奶牛选美 - AcWing题库 解题思路: AC代码: 题目链接:687. 扫雷 -…

24.11.26 Mybatis2

resultMap 中的标签和属性 如果是主键列 一般用id标签对应 propertyjava对象的属性 column 数据库中的列( javaType实体类数据类型 jdbcType数据库列的数据类型 ) 不需要配置 <id property"empno" column"empno" />如果是普通列 一般用result对…

Redis设计与实现第14章 -- 服务器 总结(命令执行器 serverCron函数 初始化)

14.1 命令请求的执行过程 一个命令请求从发送到获得回复的过程中&#xff0c;客户端和服务器都需要完成一系列操作。 14.1.1 发送命令请求 当用户在客户端中输入一个命令请求的时候&#xff0c;客户端会把这个命令请求转换为协议格式&#xff0c;然后通过连接到服务器的套接字…

ArcGIS pro中的回归分析浅析(加更)关于广义线性回归工具的补充内容

在回归分析浅析中篇的文章中&#xff0c; 有人问了一个问题&#xff1a; 案例里的calls数据貌似离散&#xff0c;更符合泊松模型&#xff0c;为啥不采用泊松而采用高斯呢&#xff1f; 确实&#xff0c;在中篇中写道&#xff1a; 在这个例子中我们为了更好地解释变量&#x…

【面试题】2025年百度校招Java后端面试题

文章目录 前言一、网络IO1、服务器处理并发请求有哪几种方式&#xff1f;2、说一下select&#xff0c;poll&#xff0c;epoll的区别&#xff1f;3、Java 有一种现代的处理方式&#xff0c;属于异步I/O&#xff0c;是什么&#xff1f;redis&#xff0c;nginx&#xff0c;netty 是…

【Zookeeper 和 Kafka】为什么 Zookeeper 不用域名?

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

RiceChem——用于评估大语言模型在教育领域自动长答卷评分 (ALAG) 的数据集

摘要 论文地址:https://arxiv.org/abs/2404.14316 源码地址&#xff1a;https://github.com/luffycodes/automated-long-answer-grading 迄今为止&#xff0c;教育领域的自然语言处理&#xff08;NLP&#xff09;主要集中在简答题评分和自由文本作文评分方面。然而&#xff0c…

Java ArrayList 与顺序表:在编程海洋中把握数据结构的关键之锚

我的个人主页 我的专栏&#xff1a;Java-数据结构&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01;点赞❤ 收藏❤ 前言&#xff1a;在 Java编程的广袤世界里&#xff0c;数据结构犹如精巧的建筑蓝图&#xff0c;决定着程序在数据处理与存储时的效率、灵活性以…

【04】Selenium+Python 手动添加Cookie免登录(实例)

一、什么是Cookie&#xff1f; Cookie 是一种由服务器创建并保存在用户浏览器中的小型数据文件。它用于存储用户的相关信息&#xff0c;以便在后续访问同一网站时可以快速检索这些信息。Cookie 主要用于以下几个方面&#xff1a; 1.状态管理&#xff1a; Cookie 可以保存用户…

GitLab|应用部署

创建docker-compose.yaml文件 输入docker-compose配置 version: 3.8 services:gitlab:image: gitlab/gitlab-ce:15.11.2-ce.0restart: alwayscontainer_name: gitlab-ceprivileged: truehostname: 192.168.44.235environment:TZ: Asia/ShanghaiGITLAB_OMNIBUS_CONFIG: |exter…

【PX4_Autopolite飞控源码】中飞控板初始化过程中的引脚IO控制(拉低/拉高)

先选择自己飞控板支持的硬件平台 打开对应的路径我的是Desktop/px4/PX4-Autopilot/boards/zhty/nora 找到board_config.h文件&#xff0c;打开nora后再往下去找Desktop/px4/PX4-Autopilot/boards/zhty/nora/src/borad_config.h 打开后可以看到有很多GPIO引脚的定义&#xff0c…

如何使用Postman优雅地进行接口自动加密与解密

引言 在上一篇文章中&#xff0c;分享了 Requests 自动加解密的方法&#xff0c;本篇文章分享一下更加方便的调试某个服务端接口。 Postman Postman 这个工具后端小伙伴应该相当熟悉了&#xff0c;一般情况下我们会在开发和逆向过程中使用它来快速向接口发送请求&#xff0c;…

Spring Boot——统一功能处理

1. 拦截器 拦截器主要用来拦截用户的请求&#xff0c;在指定方法前后&#xff0c;根据业务需要执行设定好的代码&#xff0c;也就是提前定义一些逻辑&#xff0c;在用户的请求响应前后执行&#xff0c;也可以在用户请求前阻止其执行&#xff0c;例如登录操作&#xff0c;只有登…

PYTORCH基础语法知识

初识Torch PyTorch&#xff0c;简称Torch&#xff0c;主流的经典的深度学习框架&#xff0c;深度学习的框架。 简介 PyTorch是一个基于Python的深度学习框架&#xff0c;它提供了一种灵活、高效、易于学习的方式来实现深度学习模型。PyTorch最初由Facebook开发&#xff0c;被…