当前位置: 首页 > news >正文

软件工程第三周

可行性研究 续

表达工作量的方式

LOC估算:Line of Code

估算公式S=(Sopt+4Sm+Spess)/6

FP:功能点

1. LOC (Line of Code) 估算

  • 定义:LOC是指一个软件项目中的代码行数

2. FP (Function Points) 估算

  • 定义:FP是基于软件的功能性和复杂性来估算的。FP的计算考虑了输入、输出、用户查询、文件和外部接口等因素。

估算公式含有PERT (Program Evaluation and Review Technique) 估算中的三种估算类型:

  • Sopt:乐观估算
  • Sm:最可能的估算
  • Spess:悲观估算

使用这三种估算可以给出一个期望值和估算的方差,从而更好地理解估算的不确定性。

 逻辑模型:工作业务的流程。可以使用系统流程图数据流图表示这样的系统。

操作上可行:比如火影新忍者审核。可研是抓住主要矛盾!

系统流程图

系统流程图是带有物理部件的数据流动的表示。

在不同的图形工具中,图形表示的含义不一定相同。


数据流图

描述的是一个逻辑模型控制流涉及到HOW,而数据流图不提供控制流,只关于WHAT

数据流图(Data Flow Diagram, DFD)是一种用于描述信息系统的图形化工具,它表示了系统中数据的流动、加工过程以及数据存储。DFD是系统分析与设计过程中常用的工具,可以从宏观到微观逐步细化系统的功能和数据流程。

数据流图由以下基本组件构成:

  1. 过程:通常用一个圆形或矩形表示,它代表系统中的一个功能或任务。过程中的数据会被转换或处理。
  2. 数据流:用箭头表示,显示数据在系统中的流动方向。数据流旁边通常会标明数据的名称或描述。
  3. 数据存储:通常用两条平行线表示,代表数据在系统中的存储位置,如数据库或文件。
  4. 外部实体:用矩形表示,代表系统的外部用户或其他系统。它们与系统交互,向系统提供输入数据或从系统获取输出数据。

顶层数据流图(High-Level DFD)

顶层数据流图,是表示系统整体情况的DFD。它通常只包含一个过程(代表整个系统)和与之交互的外部实体(若干个数据源点和终点)。数据流显示了从外部实体到系统的输入以及从系统到外部实体的输出。这种DFD为读者提供了对系统的总体概述,其实就是下图的基本系统模型

基本系统模型:系统和外部的实体有关联,是设计的基础和起点。将顶层图(基本系统模型)分解,形成0级图,再分解形成1级图。分解的目的是把数据的加工流程进一步细化,比如将上面的呢订货系统进一步拆分,形成更加细致的数据流图。

系统会和哪些人、软硬件打交道,界定了整个系统的范围。

可行性研究报告标准格式


课内实验和大作业是两个东西,这两个东西是通过实验连接在一起。

实验报告只要结论不要过程。

大作业报告写上过程。


第三章 需求分析

架构师:关注系统实现的整体结构,不是具体的设计内容。

需求工程师:关注需求调研和分析,产品的业务设计和应用设计。

两者结合,就是整个软件的最高价值所在。

确切描述,完整、准确、清晰、具体的要求。

可行性研究:浓缩度很高,会提出一些解决方案(包含了简单初步的需求分析等内容),不仅仅在于定义阶段,也可能在开发阶段,往往会忽略一些细节。需求分析和后续开发阶段就是一步步分析找到这些细节的过程

需求导出:Feasibility study and report

在项目管理和系统开发中,可行性研究是一个评估项目计划可行性的重要步骤。它包括分析项目的所有关键方面,例如技术可行性、经济可行性和法律合规性。基于这些分析,将生成一份报告,概述项目的可行性和潜在问题。报告还应包含关于如何解决潜在问题的建议或替代方案。

需求排序和分析:Requirement elicitation and analysis

根据重要性对需求进行排序是确保项目成功的关键步骤之一。通过使用不同的项目管理模型(如快速原型和增量模型),可以更灵活、更迅速地响应项目中最重要的需求

例如,在增量模型中,项目被分为几个小部分或增量,每个增量代表项目的一部分功能或需求。通过优先分配资源到最重要的增量,可以确保项目按照优先级顺序推进。

(需求)规格说明:Requirement specification

规格说明文档提供了关于系统或项目需求的详细信息。这包括对系统功能、性能标准和界面的详细描述。授权用户可以查询系统需求和系统描述以更好地理解系统的工作方式和功能。

同时,也应该允许用户查询自己的需求,从而确保系统满足他们的期望和需求。举个例子,如果是一个软件项目,那么在项目的某个阶段(比如在开发阶段或者测试阶段),应该让用户了解或者试用这个软件,让他们了解这个软件是否符合他们的需求和期望,是否解决了他们的问题或者满足了他们的目标。通过这种方式,可以在项目早期发现问题和不符合需求的地方,从而做出相应的调整和优化,确保项目的成功和用户的满意。

需求确认:Requirements validation

在项目开发过程中,需求确认是确认所有项目需求都已正确理解和记录的过程。需求命名有助于确保所有团队成员都对需求有相同的理解。通过为需求设置测试工具和标准,项目团队可以在项目结束时评估其有效性。这确保了项目不仅按照预定计划完成,而且满足了所有既定的需求标准和质量标准。

委托项目需求分析过程

访谈:极其重要的形式!访谈一定要有前期的准备,但是有局限性:访谈对象非常少!

问卷或interview:深入理解,把想要看到的推导给问卷被调查对象。

观察用户:细节问题

市场分析、网络搜索

创新项目需求分析过程

起始点:市场分析,头脑风暴,逐渐清晰我们的需求。

相关文章:

软件工程第三周

可行性研究 续 表达工作量的方式 LOC估算:Line of Code 估算公式S(Sopt4SmSpess)/6 FP:功能点 1. LOC (Line of Code) 估算 定义:LOC是指一个软件项目中的代码行数。 2. FP (Function Points) 估算 定义:FP是基于软件的功能性和…...

动态链接那些事

1、为什么要动态链接 1.1 空间浪费 对于静态链接来说,在程序运行之前,会将程序所需的所有模块编译、链接成一个可执行文件。这种情况下,如果 Program1 和 Program2 都需要用到 Lib.o 模块,那么,内存中和磁盘中实际上就…...

力扣:118. 杨辉三角(Python3)

题目: 给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中,每个数是它左上方和右上方的数的和。 来源:力扣(LeetCode) 链接:力扣(LeetCode)官…...

QGIS文章二——DEM高程裁剪和3D地形图

经常看到别人基于高程文件制作出精美的3D地图,笔者按照互联网几种制作方式进行尝试后,写的DEM高程裁剪和3D地形图教程,或许其中有一些错误的,也请指出。 本文基于海南省的shp文件和海南省DEM高程文件,制作海口地区的3D…...

【kubernetes】kubernetes中的StatefulSet使用

TOC 1 为什么需要StatefulSet 常规的应用通常使用Deployment,如果需要在所有机器上部署则使用DaemonSet,但是有这样一类应用,它们在运行时需要存储一些数据,并且当Pod在其它节点上重建时也希望这些数据能够在重建后的Pod上获取&…...

创建文件夹

/storage/emulated/0/代码文件/ 没有就创建 文件名命名方法:编号. 库 时间戳 使用Python的os模块来检查目录是否存在,并在不存在时创建它。下面是一个示例代码,演示了如何检查指定路径下的目录是否存在,若不存在则创建&#xf…...

点击router-link时候会发生什么?

当你点击链接或按钮时,将会导航到 User 组件,就会显示相应的用户 ID。 这里说一下执行流程,当点击一个 router-link 时,Vue Router会执行以下流程: 1)点击事件触发: 当你点击 router-link 组件时&#xf…...

【Spring】@Bean方法中存在继承如何分析

文章目录 1. 提问:如果让您分析Spring MVC的原理,您如何开始分析呢2. 如何破局3. 资料参考 本文主要介绍:如何分析 Bean方法存在继承 或 Bean方法中存在调用子类方法。 1. 提问:如果让您分析Spring MVC的原理,您如何…...

【Vim 插件管理器】Vim-plug和Vim-vbundle的区别

- vundle是一款老款的插件管理工具 - vim-plug相对较新,特点是支持异步加载,相比vundle而言 Vim-plug 是一个自由、开源、速度非常快的、极简的 vim 插件管理器。它可以并行地安装或更新插件。你还可以回滚更新。它创建浅层克隆shallow clone最小化磁盘…...

电子计算机核心发展(继电器-真空管-晶体管)

目录 继电器 最大的机电计算机之一——哈弗Mark1号,IBM1944年 背景 组成 性能 核心——继电器 简介 缺点 速度 齿轮磨损 Bug的由来 真空管诞生 组成 控制开关电流 继电器对比 磨损 速度 缺点 影响 代表 第一个可编程计算机 第一个真正通用&am…...

SDI-12协议与STM32 进行uart通信

场景是用stm32与一款温湿度传感器通信,不过是基于SDI-12协议,SDI-12时序和UART类似,故采用UART传输,原理图如下 其中DIR_OUT_SDI是一个IO引脚,控制UART_TX_SDI是否使能,U10是三态门IC,即拉低DIR…...

JS中的强制类型转换

JavaScript 中有多种强制类型转换的方式,可以将一个数据类型转换为另一种数据类型。这可以通过一些内置函数或操作符来实现。 显式类型转换(强制类型转换): 显式类型转换是通过特定的函数或操作符来明确指定要进行的类型转换。以下…...

WebSocket实战之四WSS配置

一、前言 上一篇文章WebSocket实战之三遇上PAC ,碰到的问题只能上安全的WebSocket(WSS)才能解决,配置证书还是挺麻烦的,主要是每年都需要重新更新证书,我配置过的证书最长有效期也只有两年,搞不…...

veImageX 演进之路:Web 图片加载提速50%

背景说明 火山引擎veImageX演进之路主要介绍了veImageX在字节内部从2012年随着字节成长过程中逐步演进的过程,演进中包括V1、V2、V3版本并最终面向行业输出;整个演进过程中包括服务端、客户端、网络库、业务场景与优化等多个角度介绍在图像处理压缩、省成…...

WebSocket实战之五JSR356

一、前言 前几篇WebSocket例子服务端我是用NodeJS实现,这一篇我们用Java来搭建一个WebSocket服务端,从2011年WebSocket协议RFC6455发布后,大多数浏览器都实现了WebSocket协议客户端的API,而对于服务端Java也定义了一个规范JSR356,即Java API for WebSoc…...

flask-sqlalchemy结合Blueprint遇到循环引入问题的解决方案

想要用flask_sqlalchemy结合Blueprint分模块写一下SQL的增删改查接口,结果发现有循环引入问题。 一开始,我在app.py中使用db SQLAlchemy(app)创建数据库对象;并且使用app.register_blueprint(db_bp, url_prefix/db)注册蓝图。 这使得我的依…...

05_对象性能模式

对象性能模式 面向对象很好地解决了“抽象”的问题,但是必不可免地要付出定的代价。对于通常情况来讲,面向对象的成本大都可以忽略计。但是某些情况,面向对象所带来的成本必须谨慎处理。 典型模型: SingletonFlyweight Singleton 单件模式…...

快速选择排序

"你经过我每个灿烂时刻,我才真正学会如你般自由" 前些天有些无聊,想试试自己写的快排能否过leetcode上的排序算法题。结果是,不用截图可想而知,肯定是没过的,否则也不会有这篇文章的产出。 这份快排算法代码…...

国庆中秋特辑(六)大学生常见30道宝藏编程面试题

以下是 30 道大学生 Java 面试常见编程面试题和答案,包含完整代码: 什么是 Java 中的 main 方法? 答:main 方法是 Java 程序的入口点。它是一个特殊的方法,不需要被声明。当 Java 运行时系统执行一个 Java 程序时&…...

Centos7 安装mysql 8.0.34

Centos7 安装mysql 8.0.34 准备工作 centos7 服务器 xshell 安装教程 安装并配置 在安装MySQL之前,我们应该确保系统已经更新到最新的软件包和安全补丁。打开终端,输入以下命令来更新系统 yum update为了方便安装MySQL,我们需要下载并…...

(二)原型模式

原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...

《通信之道——从微积分到 5G》读书总结

第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...

使用van-uploader 的UI组件,结合vue2如何实现图片上传组件的封装

以下是基于 vant-ui&#xff08;适配 Vue2 版本 &#xff09;实现截图中照片上传预览、删除功能&#xff0c;并封装成可复用组件的完整代码&#xff0c;包含样式和逻辑实现&#xff0c;可直接在 Vue2 项目中使用&#xff1a; 1. 封装的图片上传组件 ImageUploader.vue <te…...

数据库分批入库

今天在工作中&#xff0c;遇到一个问题&#xff0c;就是分批查询的时候&#xff0c;由于批次过大导致出现了一些问题&#xff0c;一下是问题描述和解决方案&#xff1a; 示例&#xff1a; // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

企业如何增强终端安全?

在数字化转型加速的今天&#xff0c;企业的业务运行越来越依赖于终端设备。从员工的笔记本电脑、智能手机&#xff0c;到工厂里的物联网设备、智能传感器&#xff0c;这些终端构成了企业与外部世界连接的 “神经末梢”。然而&#xff0c;随着远程办公的常态化和设备接入的爆炸式…...

Springboot社区养老保险系统小程序

一、前言 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;社区养老保险系统小程序被用户普遍使用&#xff0c;为方…...

HashMap中的put方法执行流程(流程图)

1 put操作整体流程 HashMap 的 put 操作是其最核心的功能之一。在 JDK 1.8 及以后版本中&#xff0c;其主要逻辑封装在 putVal 这个内部方法中。整个过程大致如下&#xff1a; 初始判断与哈希计算&#xff1a; 首先&#xff0c;putVal 方法会检查当前的 table&#xff08;也就…...

让回归模型不再被异常值“带跑偏“,MSE和Cauchy损失函数在噪声数据环境下的实战对比

在机器学习的回归分析中&#xff0c;损失函数的选择对模型性能具有决定性影响。均方误差&#xff08;MSE&#xff09;作为经典的损失函数&#xff0c;在处理干净数据时表现优异&#xff0c;但在面对包含异常值的噪声数据时&#xff0c;其对大误差的二次惩罚机制往往导致模型参数…...

R语言速释制剂QBD解决方案之三

本文是《Quality by Design for ANDAs: An Example for Immediate-Release Dosage Forms》第一个处方的R语言解决方案。 第一个处方研究评估原料药粒径分布、MCC/Lactose比例、崩解剂用量对制剂CQAs的影响。 第二处方研究用于理解颗粒外加硬脂酸镁和滑石粉对片剂质量和可生产…...

基于SpringBoot在线拍卖系统的设计和实现

摘 要 随着社会的发展&#xff0c;社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 在线拍卖系统&#xff0c;主要的模块包括管理员&#xff1b;首页、个人中心、用户管理、商品类型管理、拍卖商品管理、历史竞拍管理、竞拍订单…...