博客
关于我
Karl Wiegers的Software Requirements示例挑错
阅读量:306 次
发布时间:2019-03-01

本文共 988 字,大约阅读时间需要 3 分钟。

针对Karl Wiegers和Joy Beatty的《软件方法》第三版中的用例分析,以下是对某些示例的改进建议:

  • 辅助执行者的错误使用

    在“Request a Chemical”用例中,Buyer、Training Database和Chemical Stockroom被错误地列为辅助执行者。这些角色在实际操作中对系统目标的实现没有直接影响,且Training Database的执行者列表中未有其出现,显得逻辑混乱。

  • 用例步骤缺乏明确交互

    用例步骤中未体现系统如何与辅助执行者进行交互。例如,通知Buyer和Chemical Stockroom的逻辑缺乏具体操作步骤,未能清晰展示系统的行为。

  • 执行者名称不规范

    Health and Safety Department作为“Dispose of a Chemical”用例的辅助执行者不合理。执行者应为具体的岗位或系统名称,而非组织名称。

  • 执行者名称的混淆

    Training Database作为执行者存在疑问。若为系统名称,则需明确其角色与系统功能的关联;若为非系统,则命名不当。

  • 用例名称不当

    “Manage Inventory”作为用例名称不够具体,容易引起歧义。

  • 用例规约中的前置条件问题

    PRE-1和PRE2前置条件不够严谨,且执行者名称从Requester变为User,可能导致需求理解偏差。

  • 前置条件的滥用

    PRE-3前置条件使用不当,Chemical inventory database的描述模糊,缺乏明确的需求背景。

  • 需求的不准确性

    “desired chemical”一词带有主观性,系统无法保证满足Requester的所有需求。

  • 规约步骤中的语义重复

    4.0.1步骤中的“Requester specifies the desired chemical”表述冗余,且主语不当。

  • 责任划分不明确

    4.1.3和4.1.4步骤中Requester的主动性不清,应明确系统和Requester的交互角色。

  • 规约步骤中的优化建议

    4.1.3和4.1.4应合并为单一步骤,信息重复需整合。

  • 用例终止条件的不当

    4.1.E1和4.1.E2步骤与用例目标关联不强,可删除。

  • 以上问题中,(1)、(4)、(7)和(10)为主要问题,需重点修改。《软件方法》作为需求分析领域的名著,尽管细节严谨,但仍存在上述改进空间。

    转载地址:http://pwva.baihongyu.com/

    你可能感兴趣的文章
    no session found for current thread
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    no1
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用node-red-contrib-image-output节点实现图片预览
    查看>>
    Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node-RED中建立Websocket客户端连接
    查看>>
    Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
    查看>>
    node-request模块
    查看>>
    Node.js 8 中的 util.promisify的详解
    查看>>