zoukankan      html  css  js  c++  java
  • 软件产品案例分析

    软件产品案例分析

    第一部分 调研,评测

    评测:

    下载并使用,描述最简单直观的个人第一次上手体验。

    使用困难,我搞不清楚 https://devcloud.huaweicloud.com/homehttps://console.huaweicloud.com/devcloud 的区别,前者的入口又几乎不可见,在「华为云」上找了半天发现这上面的「软件开发云」不是需要的那个东西。

    功能基本可用,是各种软件和服务的大杂烩,例如 teambition、Github 等。有自己的一些亮点和缺点,但大而杂,学习曲线长而陡,新手要么啃一个又一个视频教程,要么看几十面的 PDF 教程才有办法弄清楚和用好整个系统,似乎缺少一个可索引的友好的文档网站(或者我没看到/华为云没向我推荐)。

    按照描述的 bug 定义,找出几个功能性的比较严重的 bug。至少两个。用专业的语言描述(每个 bug 不少于 40 字),如有必要,可以配图.

    bug(feature?)和体验不好的地方实在太多,我只截图和列出以下的部分,按体验先后顺序排序。

    注册过程:
    注册密码最大长度过小,对于使用密码软件自动生成密码的用户来说是灾难;
    特殊字符是什么???;
    限制太低,「a12345」这种简单密码也可以作为一个极高安全要求的企业用户的密码。
    注册密码

    导航栏图标和按钮不平齐,可能是整个图片放上去,没有考虑 padding。另外找不到任何方式把需要的服务放进「收藏」中:
    导航栏图标和按钮不平齐

    web 领取新用户礼包时,新建项目后各个弹窗都不自动关闭和跳转:
    web 领取新用户礼包时,新建项目后弹窗不关闭

    软件开发云首页 iframe.js 无法加载,服务器 503 错误:
    首页 js 503

    进入某项目直接导致浏览器卡死并报 Crash:
    进入某项目直接导致浏览器 Crash

    关闭卡死标签后重新进入,依旧 js 503 和大量 warning,似乎是 js 运行时间太久了:
    关闭卡死标签后重新进入,依旧 js 503 和大量 warning

    各处的输入框输入内容限制较大,别家 emoji 都可以到处使用,而这里不支持αβ这些字母和更多特殊字符:
    输入内容限制较大

    添加工作项中,我不明白优先级和重要程度有什么需要区分的,难道非常重要的工作项可能优先级很低?:
    不明白优先级和重要性有什么不可相互替代的

    添加工作项完成后花了大概2秒才加载出来。

    软件各处大量按钮只是图标,鼠标放上去也没有提醒,看不懂的话只能猜功能,然后谨慎地不敢按:
    体验过程中大量按钮只是图标

    创建词条按钮无效,无任何提示(简单而黑盒的 bug,完全无法用到专业语言的 40 个字描述):
    无法创建词条

    代码仓库中自动创建的 license 不自动填充 year 和 fullname,这将需要二次 commit,而 Github 是支持的:
    代码仓库中自动创建的 license 不自动填充内容,还需要二次 commit

    不明白这个表格把文件列完后在下面显示一行项目名的用意:
    不明白这个表格把文件列完后下面显示一行项目名的用意

    仅测试模块有新手引导,而其他功能模块没有,体验不统一:
    仅测试有新手引导,而其他功能模块没有,体验不统一

    你觉得为什么这个产品组的人没有发现这些 bug?

    可能的原因有:

    • 需求分析不够明了;
    • 开发随意;
    • 缺乏测试;
    • 缺乏反馈渠道;
    • 开发周期短;
    • 开发流程不细致有条理;

    假设你们团队需要开发这套系统,需要注意哪些方面 (架构、部署运维、微服务等)。

    • 确定需求需要经过缜密分析;
    • 专门的架构设计人员,进行大量调研和评估;
    • 部署需要熟练准确,操作无误;
    • 24小时多地灾备,出现问题实时热切换;
    • 开发人员需要考虑的不仅是可用,还应好用,例如 js 运行时间要短,防止浏览器可能的 Crash……;

    采访:

    1.介绍采访对象的背景和需求(他们有没有用过这个 APP 或类似的 APP,除了现有的功能还有别的需求么)

    背景:舍友。
    需求:Github、Linux 环境的开发和编程等。
    是否使用过或类似产品:否。
    除了现有的功能还有别的需求:方便的 Linux 环境模拟测试。

    2.让采访对象使用华为软件开发云(请上传照片证明用户的确正在使用,远程采访的同学请让别人帮忙照相)

    照片

    3.描述用户使用这个产品的过程, 用户的问题解决了么?软件在数据量 / 界面 / 功能 / 准确度上各有什么优缺点?用户体验方面有问题么?

    用户的问题解决了么:没有。

    软件在数据量 / 界面 / 功能 / 准确度上各有什么优缺点:

    • 数据量较为丰富,但不清楚哪些数据对自己有用;
    • 界面偏向现代化,不会用得很不舒服,但存在卡顿;
    • 功能较为完善,但有的用不到,有的不会用,不能隐藏不需要的功能/快速获取帮助;
    • 准确度无评价;

    用户体验方面有问题么:

    • 学习曲线陡峭,短时间没办法掌握并精通;
    • 存在卡顿问题;

    4.用户对产品有什么改进意见?

    • 稳定高效是这类软件的第一要求,而不是功能多寡;
    • 入口实在难找,除了搜索引擎和书签或者背下来,没什么好办法了;

    5.结论:经过这么多工作,你一定有充分的理由给这个软件下一个评价, 请选择一个结论:

    • 不推荐

    第二部分 分析

    使用此软件的大部分功能,联系第二部分的分析,估计这个项目做到这个程度大约需要多少时间(团队人数 6 人左右,计算机大学毕业生,并有专业 UI 支持)。 分析这个软件目前的优劣(和类似软件相比),并推理出团队在软件工程方面可以提高的一个重要部分(具体建议)。

    大约需要时间:六个月

    优:

    • 中文化;
    • 免费;
    • 功能丰富且集中;

    劣:

    • 国际化不够;
    • 不稳定;
    • 用户体验不够好;
    • 对新手不够友好;
    • 功能间联系不够紧密;
    • 功能还不够精细;

    建议:
    增派测试和维护人员,把系统的稳定性和可用性提高一个等级。例如进行整体的代码评估,进行全面的测试,并修复现有的 bug,提升用户体验。

    根据理解和体验,画出整个软件所有功能逻辑框图,根据重要度标识出各模块的重要度、完成度、出发点及效果;

    数字为重要度,饼状图为完成度:
    功能逻辑框图

    针对不同的维度评分,对用户体验方面、UI 界面美观度、核心功能,分别打分。

    满分100分。
    用户体验:55。
    UI 界面美观度:72。
    核心功能:75。

    第三部分 建议和规划

    如果你是项目经理,如何提高从而在竞争中胜出?

    需求分析:深度挖掘用户需求,形成易用友好的功能分布;
    开发把控:合理安排各个开发职位,努力做到相比竞品开发得又快又好;
    注重用户反馈:建立丰富的反馈渠道,及时修复用户关心的问题,增加期待的功能;
    加强推广:没有用户的产品再好也只能死在沙滩上;

    目前市场上有什么样的产品了?

    禅道项目管理软件、TeamLab、ProjectForge、Redmine、IBM Rational 等。

    你要设计什么样的功能?

    一体化开发体验:

    • 开发者的高性能开发虚拟机/webIDE
    • 团队、任务管理与协作
    • 内部文档和用户文档管理
    • 代码托管,Git 系统
    • 多角度多环境测试
    • 多语言编译
    • 虚拟和真实环境部署
    • 服务器管理
    • 用户反馈收集渠道

    为何要做这个功能,而不是其他功能?

    这些功能组成了开发者的「一体化开发体验」,其他功能是冗余。

    为什么用户会用你的产品 / 功能?

    集中高效的开发体验,不需要到处注册,到处有一个「团队」,按整个流程开发下来十分愉悦。

    你的创新在哪里?可以用 NABCD 分析。

    Need:开发工具和技术多、复杂、不统一,各家有各自的标准和文档,体验良莠不齐,需要一站式开发,提高效率。
    Approach:web 端全功能和移动端部分功能相结合的方式。
    Benefit:统一的开发体验,没有那么多的账号和各种问题,完善的团队管理,从需求撰写、代码产生到用户反馈一路包办。
    Competition:竞品只有上述部分的功能,或者界面不够精美、不够易用。
    Delivery:各大热门开发者论坛宣传,用户口碑推广等。

    如果你来领导这个团队,会有什么不一样?

    • 监督机制完善;
    • 质量把控严格;
    • 团队高效、凝聚力强;

    如果你的团队有 5 个人, 4 个月的时间,你作为项目经理,应该如何配置角色(开发,测试,美工等等)?

    一个开发、一个开发/架构设计、一个开发/部署/维护、一个开发/测试、一个美工。

    描述你的团队在 16 周期间每周都要做什么,才能在第 16 周如期发布软件,大小里程碑绩点设定。

    事项
    1 需求分析、架构设计、编写文档
    2-3 开发虚拟机/webIDE 开发
    3-4 团队、任务管理与协作开发
    5-6 代码托管,Git 系统开发
    7-8 测试功能开发
    8-9 多语言编译功能开发
    10 部署功能开发
    11 服务器管理功能开发
    12 用户反馈收集功能开发
    13 开发收尾工作,部署项目
    14-15 内测,听取意见,修正
    16 最后完整测试与修正,宣传与发布

    分析 16 周后你所完成的项目上线需要哪些配套设备 (服务器、带宽、数据库需求数量与配置) 。

    应用服务器配置:2 核 2G * 12
    后端服务器配置:16 核 64G * 4
    关系型数据库数量:12(备份 4)
    缓存数据库数量:6(备份 2)
    网站安全性:WAF、DDOS

  • 相关阅读:
    省赛总结
    factorial
    poj 3842 An Industrial Spy
    最近我这是怎么了
    U盘分区的方法
    没事做贴个代码,判断是否素数,顺便打个素数表(非原创)。
    [转]ubuntu 安装code blocks全记录
    zoj 2312
    (转)Enterprise Library系列文章回顾与总结
    分布式缓存系统Memcached简介与实践
  • 原文地址:https://www.cnblogs.com/ladit/p/huawei_software_cloud.html
Copyright © 2011-2022 走看看