[全程建模]元用例和需求与绩效之间的关系讨论

看了《随笔2:开发任务的分解过程》http://blog.csdn.net/CSDNATM/archive/2010/07/12/5730142.aspx后的评论内容,涉及到需求分解和获取,任务分配和绩效管理的内容。

slowgrace让我过来看看,上面这篇文字中提到的内容很多是常见内容,但是根源却不在撰写者的内容。下面进行一下我个人的观点描述:
1、“往往因为功能(任务)分解得不够细致而造成过程失控”
这段文字中的问题其实是因为需求没有做好的原因。关于最小分解单位可以对应于uc和us的方式,在我的定义中将之具体化为元uc/us的概念,也就是最小的不可分的操作,对应于用户业务过程中的一个最小的动作,比如从办公室拿文件送给领导看就分为两个最小动作,拿过去和看!
如果你非要说从桌上拿起来也是一个动作,但是要注意这个动作在软件系统中是不需要具体化的动作,软件系统中需要具体化的动作就是送到领导桌子上,然后是领导看,也就是领导点击打开,至于打开以后是否看了,谁也无法做主,只有领导本人知道,就类似于领导拿到了你送上来的文件,眼睛盯着,心里却在想着三顿晚饭去吃那一顿的问题,那你也没办法。
2、量化问题
这个问题建议去参考我的绩效管理模型,那里面给出了量化方法和操作过程。
任何事务在一定层面上都是可以量化的。当然到了再细分一层的层面可能就无法量化,比如原子物理学中原子核组成的量化,到了中子质子组成的时候却又出现了无法量化的问题,于是有了云概念的提出和解释,从而衍生了很多新的推理。
软件开发的工作量也是可以量化的,量化的基础就在于一定层面,而不是100%精确,其实100%这个词本身就不够精确,因为它只精确到了小数点后两位,如果非要较真地说精确,那就是100.00000%(这里有无穷多个0)。
3、“把模块和功能一一分解出来”
根据我这几年总结的东西来看,我认为软件项目的开发任务不是分解出来的,而是归纳出来的。
常规情况下说分解,是因为需求没有做到位的原因,大家都认为项目是一个整体,却没有反过来思考一下,其实项目是由众多需求组成而形成的,每个需求有自己的基础组成内容。
比如文中的例子:
““添加用户”还不能做为一个独立的项目,因为,添加时会用到查重、用户名的格式限制,所以,可以再次分解,这样分析出“查重”和“用户格式限制”这两个独立项目”
其实,这是多个uc或者us之间的相互连接的关系,也就是开发中的接口定义和重用问题。
这个问题如果只是从需求,从项目的层面往下看,的确会认为这个需求很大,但是,如果你是从细分角度来看整体,那就是一个积木组合或者方法/对象间调用关系,并不复杂。
如果用我的元用例的概念来看待,那就是多个元用例的重新组合问题,或者说就是元工作任务(最小工作任务)的重新组合。
这时候往往一切都能豁然开朗了。
4、任务的大小
其实任务的大小未必要限定到1个工作日这样的规模,因为在开发中有些元工作任务有可能十分复杂,因为这个功能对于你这个系统只需要一个返回值,而这个模块是另外一个组几十个人几个月的工作量。这里面就涉及到组间协调和配合的问题,一方面要看你团队的管理者的管理水平,另一方面也要看你们的协调和开发配合问题。
也可能这个很大功能的返回对于你们公司是没有技术力量开发的,那么购买组件或者成品就是最佳选择,如果你的领导这时候非要坚持自己开发,那必然带来整个项目的复杂化和细分的问题,这就只能具体问题具体分析了。
关于任务的大小规模,要根据元用例产生的基础原因来定义考虑,而不是随心所欲的认定或者讨论认定,当然元用例的规模也要进行讨论否则可能出现错误和偏差,但是这些内容的根源都在于需求你如何看待如何整理如何获取的问题,而不是其他。
在我新书的需求章节中提供了新的关于需求细分的方法,也曾经在我的blog中发布过。可以去看看。

补充:

loveisbug看后总结说:需求是归纳出来的,不是分解出来的。

分解出来的需求,往往是开发者根据自己经验给用户套上的需求,这样的需求往往是不准确的,因为有经验的开发人员经常习惯用已知的名词和名词的覆盖范围来覆盖当前用户的需求和想法,于是,就出现了需求中有些是用户不需要的,有些是用户需要修订的。而如果是按照我的方法归纳出来的,则绝不会出现这样的问题!

已标记关键词 清除标记
相关推荐
<p> <span style="color:#337FE5;"><strong>【为什么还需要学习C++?】</strong></span> </p> <p style="margin-left:0cm;"> 你是否接触很多语言,但从来没有了解过编程语言的本质? </p> <p style="margin-left:0cm;text-align:start;"> 你是否想成为一名资深开发人员,想开发别人做不了的高性能程序? </p> <p style="margin-left:0cm;text-align:start;"> 你是否经常想要窥探大型企业级开发工程的思路,但苦于没有基础只能望洋兴叹? </p> <p style="margin-left:0cm;text-align:start;">   </p> <p style="margin-left:0cm;text-align:start;"> 那么C++就是你个人能力提升,职业之路进阶的不二之选。 </p> <p style="margin-left:0cm;text-align:start;"> <br /> </p> <p style="margin-left:0cm;text-align:start;"> <br /> </p> <p style="margin-left:0cm;"> <strong><span style="color:#337FE5;">【课程特色】</span></strong> </p> <p style="margin-left:0cm;text-align:start;"> 1.课程共19大章节,239课时内容,涵盖数据结构、函数、类、指针、标准库全部知识体系。 </p> <p style="margin-left:0cm;text-align:start;"> 2.带你从知识与思想的层面从0构建C++知识框架,分析大型项目实践思路,为你打下坚实的基础。 </p> <p style="margin-left:0cm;text-align:start;"> 3.李宁老师结合4大国外顶级C++著作的精华为大家推出的《征服C++11》课程。 </p> <p style="margin-left:0cm;text-align:start;"> <br /> </p> <p class="ql-long-24357476"> <span style="color:#337FE5;"><strong>【学完后我将达到什么水平?】</strong></span> </p> <p class="ql-long-24357476"> 1.对C++的各个知识能够熟练配置、开发、部署; </p> <p class="ql-long-24357476"> 2.吊打一切关于C++的笔试面试题; </p> <p class="ql-long-24357476"> 3.面向物联网的“嵌入式”和面向大型化的“分布式”开发,掌握职业钥匙,把握行业先机。 </p> <p class="MsoNoSpacing" style="margin-left:18pt;"> <br /> </p> <div> <br /> </div> <p> <br /> </p> <p style="margin-left:0cm;text-align:start;"> <span style="color:#337FE5;"><strong>【面向人群】</strong></span> </p> <p style="margin-left:0cm;text-align:start;"> <span style="color:#222226;font-family:PingFangSC-Regular, "font-size:14px;background-color:#FFFFFF;">1.希望一站式快速入门的C++初学者;</span> </p> <p style="margin-left:0cm;text-align:start;"> <span style="color:#222226;font-family:PingFangSC-Regular, "font-size:14px;background-color:#FFFFFF;">2.希望快速学习 C++、掌握编程要义、修炼内功的开发者;</span> </p> <p style="margin-left:0cm;text-align:start;"> <span style="color:#222226;font-family:PingFangSC-Regular, "font-size:14px;background-color:#FFFFFF;">3.有志于挑战更高级的开发项目,成为资深开发的工程师。</span> </p> <p style="margin-left:0cm;text-align:start;"> <br /> </p> <p> <br /> </p> <p> <span style="color:#337FE5;"><strong>【课程设计】</strong></span> </p> <p> 本课程包含3大模块 </p> <p> <strong>基础篇</strong><br /> 本篇主要讲解c++的基础概念,包含数据类型、运算符等基本语法,数组、指针、字符串等基本词法,循环、函数、类等基本句法等。 </p> <p> <br /> <strong>进阶篇</strong><br /> 本篇主要讲解编程中常用的一些技能,包含类的高级技术、类的继承、编译链接和命名空间等。 </p> <p> <br /> <strong>提升篇:</strong><br /> 本篇可以帮助学员更加高效的进行c++开发,其中包含类型转换、文件操作、异常处理、代码重用等内容。 </p> <p> <img src="https://img-bss.csdnimg.cn/202007091130239667.png" alt="" /> </p>
百度云盘分享 简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级、中级、高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情、执着,对IT的憧憬、向往!此时此景,笔者只专注Android、Iphone等移动平台开发,看着这些源码心中有万分感慨,写此文章纪念那时那景! Java 源码包 Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行ATM机的流程及操作:获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,并将当前的计数器初始化,调用每一个EJB对象的count()方法,保证Bean正常被激活和钝化,EJB对象是用完毕,从内存中清除,从账户中取出amt,如果amt>账户余额抛出异常,一个实体Bean可以表示不同的数据实,我们应该通过主键来判断删除哪个数据实…… ejbCreate函数用于初始化一个EJB实 5个目标文件,演示Address EJB的实现,创建一个EJB测试客户端,得到名字上下文,查询jndi名,通过强制转型得到Home接口,getInitialContext()函数返回一个经过初始化的上下文,用client的getHome()函数调用Home接口函数得到远程接口的引用,用远程接口的引用访问EJB。 EJB中JNDI的使用源码子 1个目标文件,JNDI的使用子,有源代码,可以下载参考,JNDI的使用,初始化Context,它是连接JNDI树的起始点,查找你要的对象,打印找到的对象,关闭Context…… ftp文件传输 2个目标文件,FTP的目标是:(1)提高文件的共享性(计算机程序和/或数据),(2)鼓励间接地(通过程序)使用远程计算机,(3)保护用户因主机之间的文件存储系统导致的变化,(4)为了可靠和高效地传输,虽然用户可以在终端上直接地使用它,但是它的主要作用是供程序使用的。本规范尝试满足大型主机、微型主机、个人工作站、和TACs 的不同需求如,容易实现协议的设计。 Java EJB中有、无状态SessionBean的两个子 两个子,无状态SessionBean可会话Bean必须实现SessionBean,获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,计算利息等;在有状态SessionBean中,用累加器,以对话状态存储起来,创建EJB对象,并将当前的计数器初始化,调用每一个EJB对象的count()方法,保证Bean正常被激活和钝化,EJB对象是用完毕,从内存中清除…… Java Socket 聊天通信演示代码 2个目标文件,一个服务器,一个客户端。 Java Telnet客户端实源码 一个目标文件,演示Socket的使用。 Java 组播组中发送和接受数据实 3个目标文件。 Java读写文本文件的示代码 1个目标文件。 java俄罗斯方块 一个目标文件。 Java非对称加密源码实 1个目标文件 摘要:Java源码,算法相关,非对称加密   Java非对称加密源程序代码实,本中使用RSA加密技术,定义加密算法可用 DES,DESede,Blowfish等。   设定字符串为“张三,你好,我是李四”   产生张三的密钥对(keyPairZhang)   张三生成公钥(publicKeyZhang)并发送给李四,这里发送的是公钥的数组字节   通过网络或磁盘等方式,把公钥编码传送给李四,李四接收到张三编码后的公钥,将其解码,李四用张三的公钥加密信息,并发送给李四,张三用自己的私钥解密从李四处收到的信息…… Java利用DES私钥对称加密代码实 同上 java聊天室 2个目标文件,简单。 java模拟掷骰子2个 1个目标文件,输出演示。 java凭图游戏 一个目标文件,简单。 java求一个整数的因子 如题。 Java生成密钥的实 1个目标文件 摘要:Java源码,算法相关,密钥   Java生成密钥、保存密钥的实源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥,通常应对私钥加密后再保存、如何从文件中得到公钥编码的字节数组、如何从字节数组解码公钥。 Java数据压缩与传输实 1个目标文件 摘要:Java源码,文件操作,数据压缩,文件传输   Jav
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页