中小型嵌入式软件的高效管理

上传人:ba****u 文档编号:158884539 上传时间:2022-10-07 格式:DOCX 页数:11 大小:47.74KB
返回 下载 相关 举报
中小型嵌入式软件的高效管理_第1页
第1页 / 共11页
中小型嵌入式软件的高效管理_第2页
第2页 / 共11页
中小型嵌入式软件的高效管理_第3页
第3页 / 共11页
点击查看更多>>
资源描述
中小型嵌入式软件的高效管理随着GJB5000A-2008军用软件研制能力成熟度模型在我国科 研单位的逐步应用推广,软件产品研制过程的工程化要求越来越科学 和严格。因此我们在某些重点项目上进行了 GJB5000A二级的首批实 践。这次实践有效地提高了软件研制的工程化水平,但是同时也发现 了许多问题和和失误。通过管理人员和技术人员的分析和总结,得出 结论:GJB5000A二级的应用需要关注的两方面工作重点,一是建立 适应于中小型嵌入式软件的高效的项目管理体系,二是利用软件测试 技术提高软件的可靠性,保证软件的质量。1 中小型嵌入式软件的高效管理1.1 软件研制的现状在电子信息系统及相关产品中,主要包含三类软件:(1)人机交互类软件,采集目标状态信息和各分系统状态信息 显示于终端图形界面上,同时由操纵员进行人工操作;(2)数据处理类软件,包括数据处理、信号处理、数据融合、 数据交换等;(3)控制类软件,包括波束控制,机械装臵控制,时序控制, 系统校准,系统自检等。这三类软件的功能模块基本相同,包括系统 初始化、任务调度、数据解算、时序控制、I/O通信定时管理、中 断管理、任务问的通信同步互斥管理及内存管理等。它们的研制 特点如表 1 所示:表 1 反映出三类软件均存高实时性的嵌入式芯片或平台上开发 和运行,三类软件规模较小,研制周期短,不同项目的软件之间具有 重复性。在实际工作当中,每个软件项目组的人员配臵上,全部软件 研发人员人数一般不多于 10 人,项目组成员同时分担大量的硬件研 制、系统组成、系统联调、试验的工作。因此我们面对的主要是中小 型软件项目的嵌入式软件。在软件工程化的首次实践中,软件研制过程反映出 4 类共性的问 题:(1) 项目软件研发时间紧,人员少,人员投入度不足,人员职 责不明晰,造成部分执行要求被人为简化,甚至随意取消;(2) 项目软件的计划性不强,经常出现需求、人员、资源的变 动,造成了进度拖延,计划无法得到保证;(3) 项目软件研发过程中会议和文档较多,但利益相关方的界 定不明晰,造成不必要的“文山会海”现象,降低管理效率,影响软 件设计工作;(4) 管理人员和技术人员的工作过程缺乏足够的监管和测量分 析,造成了项目管理进程缺乏统一性和技术可重复性。为了解决通过上述问题,我们在实践过程中逐渐摸索和总结出一 些适合中小型嵌入式软件研制方法。下面将从软件项目管理体系和软件项目研制过程两方面进行阐述。1.2 软件项目管理体系成功的软件取决于科学的管理体系。GJB5000A二级的七个过程 域中,项目策划(PP )、配置管理(CM )、过程和产品质量保证(PPQA) 这三个过程域是十分重要的管理过程域。项目策划的目的是制定和维护定义项目活动的计划,具体分为四 项工作:( 1)制定项目软件研制计划;( 2 )适当地与利益相关方交换意见;( 3 )获得对计划的承诺;( 4 )维护该计划。项目策划可以理解为整个软件研制过程的剧本,其规定了 “WWWHI0”( When、Who、Where、How、Input、Output ) 六个要素,即规定时间内安排项目人员及相关管理人员在一定环境下 按照软件工程化的方法,以项目的早期需求或软件研制任务书为输入 依靠项目软件经理与所级主管领导、项目总师、科研开发部、质量管 理部、设计师、同行专家经过多方协调,在需求管理、软件生命周期、 代码规模估计、文档规模估计、工作量估计、进度、风险管理、培训 管理、数据测量、数据管理等达成一致输出整个项目的软件开发计 划。初期的计划往往无法做到尽善尽美,需求和承诺的更改,不准确 的前期估计都会影响计划的实施,导致项目计划需要在过程中调整甚 至重新制定,因此对于研制周期较长、软件模块之间存在复杂依赖关 系的项目,需要分每一阶段进行更细化的项目策划。配臵管理紧紧依赖于软件开发计划,目的是利用配臵标识、配臵 控制、配臵状态纪文和配臵审核建立和维护工作产品的完整性。整个 软件生命周期中,配臵管理起到 “数据库”和“录像机”的作用。 首先组织级配臵管理员规定三类基线:功能基线、分配基线、产品基 线;规定三类文件存储库:开发库、受控库、产品库 然后项目级配 臵管理员规定基线下的工作产品,如技术文档、软件源代码及可执行 程序、评审报告等,根据软件研制阶段不同分别放臵于对应基线下的 库中。组织级和项目级配臵管理员进行合理计划,输出配臵管理计划。配臵管理工作不能误认为仅仅是档案工作,作为组织级项目配臵 管理员,其职责为:(1)定制标准化的开发流程;(2)定制访问控制、变更控制的条例;(3)监督配臵管理事件并驱动相应的对策;(4)软件配臵管理工具的日常管理与维护。 作为项目级配臵管理员,其职责为:(1)提交配臵管理汁划;(2)各配臵项的管理与维护:(3)执行版本控制和变更控制方案;(4)完成配臵管理阶段工作报告。过程与产品质量保证是从制度和规范上严格保证了软件工程化 的实施。质量管理人员应该具备软件研制开发的经验,熟悉各种软件 的研制流程。首先建立对研制过程、工作产品的评价标准;其次通过 检查标识并文档化不符合项,追踪不符合项的闭环;然后定期将软件 研制过程的质量情况通报整个项目组和高层,并做出阶段总结报告。项目软件经理、组织级项目级配臵管理员、质量保证人员三者 应该及时沟通,从不同的角度管理软件研制项目组成员,包括相互之 间的监督,促使软件研制过程严格按照GJB5000A二级标准执行。他 们也需要按阶段或定期向项目总师、部门领导以及所领导汇报软件工 程化的实施情况以获得上级对项目的支持。1.3软件项目研制过程项目策划和配臵管理虽然已经定义了流程化或模板式的操作方 法,但大部分项目软件人员会犯“先做事,后补文档”的错误。因为 对于总师、分系统负责人、设计师等项目组技术人员来说,他们更关 注如何能够促进软件研制过程又好又快的进行。为了这个目的,必须 重视需求管理(REQM)、项目监控(PMC)、测量与分析(MA)这 三个工程过程域。下面以一个瀑布模型的软件研制过程为例说明如何进行过程中 的监控。项目监控从图1中的软件需求分析阶段开始直至项目结束。项目 监控过程中,设计师和管理人员需要提供个人工作周报,记录自己实 际的工作完成情况;在双周或整月时,项目软件经理组织项目组成员 交流项目情况并记录;阶段结束后,组织针对阶段工作产品的评审会,然后输出里程碑报告。管理人员对照软件开发计划中的进度计划、风险管理计划、数据管理计划、利益相关方参与计划等文档监控进度 偏差、工作量偏差、规模偏差、风险变化、培训情况、评审状况、问 题数量和回归状况。一旦出现偏差加大的趋势,就需要及时开会交流,查明原因,迅速纠偏。饮ri石求:;卄I翩豳户筋求耿 ITMI脍悝仝讣j测量与分析更加详细地规定了对于能够证明过程的文档的采集和存储方法,而且需要对采集数据汇总后进行统计分析,将分析结果, 如偏差、趋势、错误数目等展示给项目组成员和高层领导,由他们进 行项目开发的决策。项目监控是手段,测量与分析为辅助,需求管理则是最终目的。 结合图 1,需求在整个软件研制周期内不可能是一成不变的,是逐步 细化的。用户需求是第一步,随后软件研制任务书将用户需求工程化, 需求规格说明对任务书的需求细化,设计说明对需求规格说明的需求 细化,软件源代码将设计说明对应到代码。单元测试、集成测试、系 统测试是对细化后的需求进行回归。根据GJB438B-2009中的软件 需求规格说明模板,需求包括 10 类技术需求和 4 类非技术需求。非技术类需求一般可以得到客观保证,因此不会出现大的变动,可以 暂不纳入需求跟踪矩阵。技术需求由于项目研制情况会出现变化,需 要纳入需求跟踪矩阵进行管理,确保软件工作产品的需求能够进行双 向追溯。一旦需求变更状况时,及时记录并且上报整个项目组,获得 项目组的一致认可。1.4项目管理信息化手段的应用工欲善其事,必先利其器。软件工程化管理主要通过文档来反映 过程。如果通过传统的人工撰写文档和凡事开会沟通的方式进行软件 项目管理的话,将会大大增加管理人员和设计师人员的工作量,况且 这种方式的效率是十分低下的。因此有必要应用先进的项目管理信息 化工具。目前,关键科技公司推出专门针对GJB5000A二级软件工程化产 品的解决方案,包括 KPFLOW、KRFLOW、KCFLOW 和 KTFLOW 四类工具:(1)KPFLOW :对软件项目的进度、成本、质量、资源等情况 进行集成管理的平台。其主要功能包括:任务分配与跟踪、项目估计、 项目周报和个人周报记录、问题与风险管理、项目度量分析。该平台 支持系统建模,即意味着可以针对不同项目设计对应的模板和模块。 该平台主要体现PP (项目策划)、PMC(项目监控)、MA (测量与分 析)和PPOA四个过程域的信息化管理;(2)KRFLOW:需求管理工具,其主要功能包括:需求的获取 和编辑、需求跟踪和分析、变更建议系统、基线管理。该软件主要实 现REQM (需求管理)过程域的信息化管理工作;(3 ) KCFLOW :确保软件项目生存周期内产品的完整性、一致 性和可追溯性。其主要功能包括:配臵计划管理、变更控制、版本管 理、产品依赖关系和一致性管理、软件问题跟踪管理、软件配臵状态 审计。该软件实现了CM(配置管理)过程域的信息化管理,同时也 可以管理REQM和PPQA两个过程域;(4 ) KTFLOW:测试过程的管理软件,其主要功能包括:梳理 测试需求、制定测试计划、设计测试用例、执行测试过程、输出测试 报告。该软件帮助测试人员在短时间内、大批量的完成多个项目的软 件测试。这四类工具有两个特色:一是它们相互之间可以进行数据互联, 帮助管理人员从不同角度监督研制过程;二是工具支持文档自动生成 项目组人员只需要按照GJB438B模板,填写部分软件研制过程的信 息,即可输出标准化的文档。尽管具有功能强大的工具,但是在初期实践阶段,由于工具普及 的程度参差不一,我们先使用KCFLOW配置管理工具,先由组织级 配置管理员负责使用,然后逐步对项目级配置管理员以及项目相关成 员进行推广。在这个过程中,项目组成员需要不断的实践,逐步提高 劳动效率。2 嵌入式软件可靠性的提高2.1 软件可靠性软件工程化的核心是为了实现好的软件,而评价软件好坏的关键 标准是软件可靠性。软件可靠性(Software Reliability)指的是在给定 时间和特定环境要求下,软件完成规定功能的能力。针对在雷达系统 中使用的嵌入式软件中,可靠性指标一般隶属于分系统或整机的指标 即在初始系统正常的条件下,在规定时间内,软件不引起系统故障的 能力。由于嵌入式软件与硬件结合相当紧密,其可靠性指标具有很大的 随机性,如外界环境变化、系统输入出错、使用不当以及软硬件设计 的固有缺陷等原因都会导致软件可靠性指标降低,但是不能因为这些 困难,使得嵌入式软件可靠性的保证成为空谈。软件可靠性是可以通 过软件工程化的实践来提高。1.1 2.2靠性的提高严格进行软件工程化管理是提高软件可靠性的必经之路。按照软 件工程化要求,需要做好如下五方面工作:( 1)前期项目组针对软件进行充分的论证和分析,争取将软件 需求明确体现在软件研制任务书中;(2) 设计过程中,尽量提高软件模块或单元的高内聚性、低耦 合性。单元之间的接口尽量明晰,整个系统软件的复杂度不易过高, 该拆分的就需要合理拆分为多个组成部分;(3) 加强软件文档的健全性和准确性,按照GJB438B-2009武 器系统软件开发文档的要求,软件研制过程中的文档不能有缺失、 描述不清、前后矛盾等情况出现。这些文档必须经过专业人士的评审 认可,并且问题回归后才能进行归档;(4) 逐步建立软件标准化工作,包括文档标准化和代码模块标 准化,这样可以有利的缩短研制周期,降低研制风险,提高软件产品 的重用率;(5) 切实加强嵌入式软件的测试工作。3.测试3.1软件测试的重要性 尽管软件工程化管理工作对软件质量的保证起到至关重要的作 用,但是技术人员依然心存质疑,是否好的管理就能够确保高可靠性 的软件。答案就在于软件测试。软件测试是将软件可靠性指标具体化 的手段。从广义上讲,软件测试是为了尽快尽早地、不断地发现各种 软件缺陷而开展的对软件及过程产品的验证和确认活动。从狭义上讲 软件测试包括 4 类测试:( 1)针对软件源代码的静态测试和代码审查,确保软件源码符 合GJB5369航天型号C语言安全子集或其他开发语言标准的要 求;( 2)针对软件设计说明对应的软件模块的单元测试和动态 测试,确保软件模块的代码覆盖率达到 100;( 3)针对需求规格说明对应的软件功能性能的集成测试, 确保软件功能、性能、外部和内部接口等符合要求;( 4)针对软件研制任务书对应的软件需求的系统测试或验收测试,确保软硬件各项指标符合用户的验收要求。在这个测试过程中,测试问题及问题数目、测试问题的归零情况、 测试问题中文档问题和软件问题的比例、阶段测试的缺陷率、软件故 障等级、软件失效概率等度量数据可以直观地反映出软件的可靠性状 况。因此软件测试工作对于软件研制起到关键的保障作用。1.1 32 软件测试工具的应用软件测试是一项有难度的专业技术工作,除了人工代码走查、问 题记录分析工作之外,大部分工作需要专业的软件测试工具完成。英国LDRA公司的LDRA Testbed测试软件是目前针对嵌入式软 件测试最有效的工具之一。该软件主要可以实现代码评审、质量评审、 设计评审、单元测试、测试确认以及整个过程的测试管理功能。代码 评审考察了软件源代码对编程规则的适应以及代码结构的合理性;质 量评审分析了代码的圈复杂度、循环嵌套和不可达性,反映出代码的 清晰性、可维护性和可测试性;设计评审包含接口分析、数据流分析、 数据对象分析,确保了代码与需求规格说明的一致性;单元测试 包含动态测试,主要测试代码的语句覆盖和分支覆盖程度;测试确认 采用自动化的方法对于测试产生的问题进行回归和记录,自动输出测 试用例集和软件测试报告。对于该工具的具体使用上,需要注意两点,一是该软件还不能有 针对性的自动生成测试用例,也就意味着我们需要针对前文提到的三 类软件进行人工设计和输入测试用例,并将这些测试用例标准化后存 入测试库中作为范例;二是该软件主要面对的是软件源码,因此如果 遇到需要软硬件结合测试的情况,还需要使用实时在线测试工具,如 RTInsight软件或半实物仿真测试平台等。软件测试工具可以极大的解放开发和编码人员,我们必须建立专 业化的测试标准、测试平台、测试队伍,这样才可有效的保证软件产 品的质量。1 4.束语软件工程化二级的实践在整个软件研制过程中是一个逐步深化, 不断提升的过程。因此不能抱有“一劳永逸”的麻痹思想,而是应该 加强实践,建立愈加完善的软件项目管理体系,同时切实做好软件测 试工作,确保软件的高可靠性。相信只要通过科研工作者和管理者的 努力,一定会使我们的软件工程化水平得到很大的提高!
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸设计 > 毕设全套


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!