查看原文
其他

《非程序员》电子杂志下载(1-38期)

UMLChina 2023-06-27
在2001-2005年间发布的免费电子杂志《非程序员》,杂志从“软件以用为本”出发,重点关注软件需求和设计技能。杂志发行到51期后停刊。许多内容到今天依然有参考价值。
全51期-百度网盘下载>>
http://pan.baidu.com/s/1bnHE5mn

第1期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer1.pdf

千年决心,Scott Ambler
......在新千年的开始,让我们花点时间为自己的事业下点决心。
【访谈】
Dassault Aviation为业务的成功实施面向对象技术和UML
......Dassault Aviation是行业领先的跨国军用和民用航空产品的制造商
【方法】
用Use Cases捕获需求,Pete McBreen,苏康胜
......Use Cases是非常有效的需求捕获技术,它能使需求变得容易回顾,并且避免在需求中有实现细节的偏好出现。
《分析模式:可重用对象模型》前言和介绍(笔记版),Martin Fowler,Windy J
......重用才刚刚开始,更多的是在GUI开发和数据库交互上,还没有出现的地方是在业务级。
【过程】
参与变革,Lisa J. Roberts,mirnshi
......论述了为什么要建立可重用过程以及从中得到的好处。
创建成功的工程,Bruce Eckel,Hairui
......以下工程开发指导是我对决定一项使用任何语言的软件工程成功与否的决定因素的一些认识。
更好地领导一个项目的诀窍,Warren Keuffel,Think
......技术管理就像开车。当你做得正确时,没有人注意,一旦某个环节出错,问题会接踵而来。
【工具】
选择一种UML建模工具,objectsbydesign,think
......以下标准用于评估一种UML工具。
【服务】
国内出版的软件工程书籍一览

第2期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer2.pdf

【方法】
用UML设计Java应用程序,Hans-Erik Erikkson, Magnus Penker,刘忠
......本文的案例学习提供了一个例子,说明如何将UML用在现实中。一个处理图书馆借阅和预定图书和杂志的应用程序,可以大到足够检验UML解决现实问题能力的程度。但是如果太大的话,则不适合在杂志上发表...
《分析模式:可重用对象模型》学习笔记之二:责任模式,Martin Fowler,Windy J
......在这一章中,首先我们接触到是是Party模式,在进行系统分析和概念模型设计的时候,经常发现人和各种各样的组织有着同样的行为,例如,固定电话的计费可能是针对个人,也可能是一个单位;需要各种服务的时候,你可能...
《分析模式:可重用对象模型》学习笔记之三:观察与测量,Martin Fowler,Windy J
......许多计算机系统记录现实世界中各种对象的信息,这些信息通常表现为计算机系统中的记录、属性、对象等其他各种各样的形式。最典型的方式是把某项信息记录成某个对象的一个属性,例如,一个人体重70公斤记录成“人(Person)”类的体重(Weight)属性,值为70。
用户需要什么-软件的工程可用性,Larry L. Constantine,Huang Yin
......并不是行业中认为可用性不重要。新的用户界面窗口小部件和GUI开发工具的广告充斥了商业杂志。关于用户界面设计的书在书店里的书柜中排列成行。所有的软件公司都详细地描述他们在昂贵的可用性试验支持下的用户界面测试程序。我们过多的关注用户界面设计--对于一些项目而言几乎是预算的三分之二--但仍然与项目的目标谬之千里。肯定在某些地方出了问题。......
【过程】
深刻理解CMM-成功的关键,蓝尔公司
......当看到国内众多软件企业正轰轰烈烈进行CMM二级评估(评估的费用昂贵),我们想,大概美国人在笑。...
项目管理规范-RUP管理实施 (1),李杰
......此规范是基于CMM模型规范,以RUP软件工程过程为蓝本,由我本人根据项目实际情况而选择修改
成功项目管理的秘密,Karl Wiegers,Shids
......在最好的情况下,管理软件项目也是很困难的。不幸的是,许多新项目经理实质上没有受到任何就职培训。这里有20个成功的管理经验供项目经理参考。...
【工具】
UML相关产品价格,ObjectsByDesign,Cliff

第3期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer3.pdf

【方法】
模式的讨论FAQ,Doug Lea,Qian_x_j
......本文的话题提炼并精简于模式讨论列表,格式为问答方式
Abstract Class模式,Bobby Woolf,透明
......为一个类体系(hierarchy)定义接口,并将具体实现交给子类。
Document-View-Presentation模式,Ku-Yaw Chang等,透明
......本模式建立在Document-View模式的基础上,并且很有效的将翻译函数与翻译结果的输出相解耦。
Role Object模式,Dirk Bäumer等,透明
......每个角色对象扮演了组件对象需要在一个用户的环境(context)中扮演的角色
Matcher-Handler模式,Frank Metayer,透明
......用一种松耦合的方式将原始数据分发传递给一个或多个数据处理器。
Alternator模式,John Liebenau,透明
......在一个层次化结构中允许多个候选子树
Authenticator模式,F. Lee Brown, Jr.等,透明
......描述了一个一般性的机制,它为服务器提供了对用户的身份鉴定与认证方法。
用户需要什么-软件的工程可用性(二),Larry L. Constantine,Huang Yin
......为何要问“为什么”?因为只有询问了用户为什么要用这个系统之类的问题才能帮助
【过程】
项目管理入门,Karl E. Wiegers,mirnshi
......终于来到了:从工程师的队伍里你被提拔到了软件项目领导或者团队领导的位置。
项目管理规范-RUP管理实施(二),李杰
......此规范是基于CMM 模型规范,以RUP 软件工程过程为蓝本,由我本人根据项目实际情况而选择修改

第4期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer4.pdf

【方法】
用例的使用误区:管理需求之一,Dr. Timothy Korson,James Zhong
......如果我发现另一个小组以“用例驱动方法”名义如此行事,真想在下届Object Expo(对象博览会)时,由一支行刑队带着蒙着眼睛的整个小组去面对公众执行枪决!
构造用例过程:管理需求之二,Dr. Timothy Korson,June Fourteenth
......这次我将阐述一下误解和滥用最常发生的部分,即用例的构造(Configuration)过程。
创建有用的用例:管理需求之三,Dr. Timothy Korson,June Fourteenth
......他仍认为在他部门的编程人员应该具备可以解读这一切的基本知识。“没有任何雷达专家会犯如此基本的错位”,他坚持说。
《分析模式:可重用对象模型》学习笔记之四:企业财务分析中的观察和测量,Martin Fowler,Windy J
......是要发现这些问题的根源却比较困难,因为这样的企业会产生大量的信息,以至于很容易分析人员就被淹没在这些信息当中了。
勇于直面需求变更,Windy. J
......针对当前软件系统建设中普遍存在的需求变更问题提出了自己的见解
掌握可用性规则,Lucy Lockwood,Nothing
......下面这些规则将能帮助开发小组提高项目界面设计的质量。
【过程】
在小型软件开发组织中使用CMM,Mark C. Paulk,张俊
......CMM SM 是适用于小工程项目和小规模组织的经剪裁的CMM 版本。
项目管理规范-RUP管理实施(三),李杰
......此规范是基于CMM 模型规范,以RUP 软件工程过程为蓝本,由我本人根据项目实际情况而选择修改
威赛儿商务通系统开发员手册,苏康胜
......为了保证商务通系统项目开发成本优化并且有利于将来的扩展及重用

第5期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer5.pdf

【方法】
面向对象分析和设计技术,Martin Fowler,easehawking
......在早期使用一种技术时你倾向于按着书来做。一旦你习惯之后你会发现它并不按你喜欢的方式去做。别犹豫去改变事物...
数字录音机设计方案,Ivan Porres Paltor,Johan Lilius,乐林峰
......本文内容是采用统一建模语言(UML)对一个嵌入式系统进行面向对象分析和设计的实例。被分析的系统是一个数字录音机或称口授留声机。设计实现采用一个嵌入式微处理器和C++编码...
怎样避免用例陷阱,Susan Lilly,qian_x_j
......我们应该能够扫视用例模型,并且列举那些在用户使用系统中想要做的事。这些并非是琐碎的用户的交互,而是真正的目标。选择那些反映附带的行为,而不是真正的角色目标,会导致过多的用例...
使用UML设计数据库应用,Michael Blaha,张启鹏
......范式对于基于面向对象(或基于实体)的开发不是很重要。如果你采用OO方法并且你的模型经过很好的构思,那你就正在把数据组织成为有意义的单位,也在本质上满足了范式的规定...
【过程】
统一变更管理的威力,Brian White,James Zhong
......本文针对UCM的诸多能力及优点,权作抛砖引玉。从根本上讲,软件项目变更管理流程--通过Rational ClearCase和Rational ClearQuest来自动化--提升了抽象级别,以及通过将现实世界对象引入到CM系统中的自动化可行性...
项目管理规范-RUP管理实施(四),李杰
......在项目开发过程中,最麻烦的就是个别'高手'的要胁。这种'高手'掌握了系统关键的部份,并且此时无人可替,非他不可,这时'高手'借机要求加薪,升职...

第6期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer6.pdf

【访谈】
UMLChina和《设计模式》作者John Vlissides交流实录,透明,think,Qingrun 整理
......我认为在分析模式和设计模式之间有非常多的关系。同样的关系也存在于分析和设计之间。你不能将分析从设计中独立出来,如果你打算这么做,那么你一定会失败的。分析模式捕捉反复出现的领域建模问题的通用解决方案;设计模式捕捉反复出现的程序设计问题的通用解决方案。...
【方法】
Temporal(时效) 模式,Andy Carlson, Sharon Estepp, Martin Fowler,透明
......在面向对象设计中,我们不断使用"对象"(object)这个词。对象不仅仅用来表现真实世界中存在的物件,它们也被用来表现那些曾经存在但已经消失了的物件,以及那些可能存在于未来的物件。上述的要求给我们的建模工作提出了一个特别的挑战...
Java 中的Singleton (上),石一楹
......在面向对象的程序中,某些类只需要一个实例。譬如,在一个窗口应用程序中,我们只需要一个主窗口。又如在一个数据库应用程序中,我们往往希望将所有的数据库连接集中于一处,并能为整个程序所使用。...
建模鸡汤,Scott Ambler,乐林峰
......我们期待自己成为一个优秀的软件模型设计者,但是,要怎样做,又从哪里开始呢?将下列原则应用到你的软件工程中,你会获得立杆见影的成果。...
【过程】
回顾过去,展望未来,Karl Wiegers,Johanna Rothman,亚玲
......回顾,这种小小的投资,将几乎肯定地获取比它大的收益。在今天速度驱动和有明显交货底线的开发世界里,你无法承受重犯过去的错误和一个项目接一个项目地遇到相同的意外。...
功能点过程,Adams Wang
......本规程的目的是基于软件需求产生软件规模的估计。功能点是基于应用软件的外部、内部特性以及软件性能的,一种间接的软件规模的测量。...
【工具】
CASE工具赛马,Gary K. Evans,张启鹏
......正在搜索完美的面向对象建模工具?谁不是呢?那些由开发者创建并且也是为开发者创建的工具,总是承诺即将是成熟的产品,却鲜有实现。随之,我们已经学会了讨厌它们,但又不能离开它们。在过去的五年里,OO世界已经从工具能力令人绝望的缺乏,变成令人困惑的选择过剩...

第7期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer7.pdf

【访谈】
交互设计之父Alan Cooper访谈,uidesign.net,亚玲
......拯救这个世界 -- “一点一滴地”...“让人做他们胜任的事情,让计算机做他们真正胜任的事情。”...
【方法】
模式与XP,Joshua Kerievsky,Gigix
......由于我继续学到更多关于XP的知识,我很快开始考虑这样一个事实:那些清楚介绍"XP是什么"和"XP如何工作"的人毫不提及模式。看起来,焦点已经全部从开发转向了重构。构造一点,测试一点,重构一点,然后再重复。那么,模式怎么了?...
预订和使用可重用实体的分析模式,Eduardo B. Fernandez,Xiaohong Yuan,Shane
......一个客户(个人或机构)需要预定一个可重用的实体(如旅馆房间、车辆、演出座位)供他随后使用。...
仓库管理器:一个库存的分析模式,Eduardo B. Fernandez,邓克
......现代制造系统中,制造过程中所涉及信息的管理已经成为降低产品成本,提高产品质量的一个关键因素。很多公司和机构在这个领域投入了大量的资源,制造资源计划系统(MRP)已经变得重要了[Salv92]。库存是MRP系统中最重要的一部分,用来跟踪目标对象的数量和位置。...
使用模式集成UML视图,Alexander Egyed,davidqql
......视图集成的主要的障碍是缺乏完好定义的(工程的)模型基础。视图经常使用迥然不同的表示信息方法,而这使得确定它们在哪里和怎样出现重叠非常困难。这样,组合和比较视图的任务经常是手工的而且潜伏着错误的。集成框架的目标是要补偿鉴别和解决体系结构不匹配自动化辅助手段的不足。...
【过程】
项目经理面试指南(上),Patricia L. Ferdinandi,zhoufang
......本文的目的是为应聘项目经理提供帮助。项目管理是升迁的途径,需要运用你过去的开发经验,而且薪水通常高于程序员。应聘项目经理的准备工作包括:复习一些常用的概念、术语,问自己一些在面试中经常问到的问题。学会运用一个或多个项目管理计划编制工具。通过以上的准备,将为你应聘这个职位增加信心。...
《人月神话》节选,Fred Brooks,Adams Wang

第8期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer8.pdf

【访谈】
Ivar Jacobson访谈,Adriano Comai,Tang Xiaoming
......我想最接近的东西是通信案例这个想法。但是我必须指出一点:我因为用例而出名,这的确是事实,但是1967年我们有基于组件的开发方式的时候,用例还没有诞生。因此基于组件的开发是我一生一直在努力的东西。另外一个是体系结构,我的意思是指真的先辨别出一个体系结构---在做任何事以前。...
UMLChina访谈高焕堂:恢复中华民族设计自己产品的信心
......我想更合理的是:一开始,不必使用include或extend, 因为增加了很多初学者的困扰. 初学者常常分不清Use Case与SubSystem两者之间的关系,常把include看成模组之间的呼叫关系。...
【方法】
程序调试的智力游戏,David Burns,史彦军
......对于软件开发人员来说,程序调试实际上就是一种生活。而对于职业程序员来说,"捉虫"是专门描述这个智力游戏的名称。以下是关于"捉虫"和修正的10个建议。...
Chain Constructors,Joshua Kerievsky,透明
......在同一个类的两个或更多的构造子中编写重复代码,这就是在为自己埋下麻烦的种子。别人会在你的类中添加新的变量,然后更新一个构造子来对这个变量进行初始化,但是却忘了更新别的构造子。于是,"砰"的一声,向新的bug问好吧。...
设计模式的理解,Adams Wang
......面向对象指使用离散的对象来构建软件系统;设计模式利用了对象的继承、组合和代理(delegation),在较OOP高的层次上考虑问题。尤其是使用代理来对任何不稳定或不确定的方面,如状态、对象的创建、应用平台等等,进行封装,从而保证了源代码的重用和设计的稳定。...
【过程】
项目经理面试指南(下),Patricia L. Ferdinandi,zhoufang
......问题10:怎样确定人员需求?答案10:不考虑资源限制进行计划开发。在任务旁边加上诸如数据模型制作者,业务分析员和用户等角色。再加上能将任务重叠起来的补充性的资源。在计划中要考虑开发团队包括支持团队和用户代表失去一个或多个资源的情况,要在每个任务上增加15%的余量。要使项目小组的组成容易理解,要有角色所必备的技术水平的说明。
为什么还不编码?,张俊
......您正从事着一项专业品质的应用开发,正处于其设计阶段--您正在和用户面谈,正在记录对象的定义,正在绘制对象的模型--这时--就在这时!--您的老板走过来问道:"为什么你还不写代码?!"--好吧,也许不尽然都是这样露骨的质问--但老板对你缺乏那些在开发进程中眼见为实的东西而心怀不快,却是显而易见的。...
《面向对象项目成功之道》节选,Alistair Cockburn,乐林峰
......"Surviving Object-Oriented Projects: A Manager's Guide"是Alistair Cockburn所著的经典著作之一。它的中文译本《面向对象项目成功之道》即将发行,译者为UMLChina翻译组的乐林峰,这是翻译草稿的片段。...

第9期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer9.pdf

【访谈】
UMLChina访谈Kent Beck:只是一种正确做事的方法
......XP在长远的未来将变得脆弱及老旧,并且将有某些更好的东西来替换,在50年之内。不管如何,我期望许多XP实践被当做"只是以正确的方式做事情的方法"接受。...
UMLChina访谈Alan Cooper:垃圾,都是垃圾!
......手机不应该成为一团。为什么我需要将键盘举到我的耳边?为什么作为一个和人交流的工具要有号码?我认为手机应当是隐形的,一个带小型麦克风的听筒放在头部。...
【方法】
极端编程中"坏气味"的发现与响应,Amr Elssamadisy,Dr. Gregory Schalliol,herman
......Martin Fowler在他的书"Refactoring"中引用Kent Beck对"坏气味"隐喻,描述如何识别一种早期的警示信号,它们指示程序代码的某一部分必须重写。在本文中,我们希望把这一隐喻扩展到必须重新构造整个软件开发流程的早期征兆。对于大型项目,把重写所包括的所有流程与重构单一的过程相比较,我们觉得错误流程的征兆(坏气味))应该引起更多的关注。...
用创建方法取代多个构造子,Joshua Kerievsky,透明
......某些语言允许你用自己喜欢的任何方式为自己的构造子命名,而不用管类的名字。另一些语言(例如C++和Java)则不允许这样做:每个构造子都必须按照所属的类的名字来命名。如果只有一个构造子,不成问题;但是如果拥有多个构造子,程序员就必须去了解构造子期望的参数、观察构造子的代码,这样才能正确选择自己要使用的构造子。这有什么毛病?毛病太多了。...
【过程】
通过CMM评估的战略,Victor Stachura,zhoufang
......我所在的组织进行CBA IPI时,我会经常做噩梦,但我建议你要放松。如果你已经作了评估过程中的所有工作,那么你就没有什么可担心的了。...
软件项目管理小说《最后期限》(草稿)节选,Tom DeMarco,透明
......是的。我们从六个关键性的项目开始,目标是制造出六个精心挑选的软件产品。我们的最高领袖--元首--亲自挑选出这些产品。而你,你的工作就是让这六个项目和整个机构正常运转。...

第10期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer10.pdf

【访谈】
UMLChina访谈Martin Fowler
...使用团队自己选择的方法。是团队选择了XP,而不是你强加给他们的。...
【方法】
返璞归真:通过简化用例来简化用户界面,Larry Constantine,harvey
......我们常被问及精简那些最简化、抽象和通用窗体用例的重要性。到底有多重要呢?在以用户为中心的设计中,简化那些重要窗体的用例是获得成功的关键。它能够为开发者设计优秀的用户界面助一臂之力。通过消除不必要的或技术驱动的操作步骤,设计者可以使用户界面上那些最常用或最基本的操作变得简捷。...
对于模式的"十大误解",John Vlissides,透明
......过去,我一直认为第一项是模式最大的好处。现在我认识到,第二条起码也同样重要。请想一想,在一个开发项目的过程中,有多少字节的信息在开发者之间流动(包括口头的和电子的)?我猜就算没有1G也有好几兆。(在推出了《设计模式》之后,我已经收到了好几十兆给GoF的电子邮件。而且我们所描述的还都是小型到中型的软件开发项目。)由于有如此之大的信息交流量,所以效率上任何微小的提升都能大量节约时间。在这个意义上,模式拓宽了人们交流的带宽。我对第三、四条的评价也在逐渐提高,特别是在项目越来越大、软件生存周期越来越长的今天。...
用户界面的交互模式,Martijn van Welie, Hallvard Trætteberg,James Zhong
......由用户界面设计(UID)模式引发的兴趣可追溯至1994年(Rijken 1994,Bayle 1998),但即使存在多种模式集,也未能形成一套被接受的模式集合,即模式语言。似乎缺乏对UID模式的格式及焦点的一致意见。既然UID的模式语言必须在开发足够多的采用同样焦点或"视点"编写的模式后才能出现,它当然没有确立起来。我们认为UID的模式需要一种以可用性为中心的特殊格式。...
糟糕界面集锦-控件篇,iarchitect,bucher
......????没反应--我再"剪切"--我又"剪切"--我"剪切"……却不知道其实早就完成了操作。"雷德蒙(微软总部)里的那些家伙正因为这个被人嘲笑...
用UML描述工作流管理系统规约,Pavel Hruby,wind.deng
...统一建模语言(UML)为描述面向对象系统定义了一系列的标准符号。使用UML增强了领域专家、工作流专家、软件设计者和其他不同背景的专家之间的交流联系。UML可以在普遍的场合使用,对工作流系统的用户而言很直观。除了这些,UML符号具有准确的语义,也就是说可视化的工作流描述可以作为软件规约。这一章侧重讨论了如何使用UML来描述工作流管理系统,如何跟踪从业务流程到面向对象软件设计的描述信息,如何用UML可交互工件来结构化项目知识库。...

第11期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer11.pdf

【访谈】
UMLChina访谈Roger S. Pressman:CMM不是宗教
......任何过程模型和评估成熟度的相关方法都是有意义的。但是必须避免过分强调过程。每个机构必须自己选择...
【方法】
面向对象开发中的本质用例及其职责,Robert Biddle,zhangxxin
......本质用例(Essential Use Cases)是一种轻量级的方法,它简单明了,不受技术约束,用于沟通用户意图和系统职责,能够有效地捕捉用户界面的设计需求。在设计过程中,使用本质用例从系统职责中提取的关键词汇可以直接作为对象来使用,具有显著的优点。本文描述如何使用本质用例直接驱动面向对象开发过程,并实现与用户界面进行并行开发的方法。...
利用角色扮演和用例卡片进行需求复审,Robert Biddle,caorui
......我指定我要哪一个座位。除非我不想这样做……,如果我这样做,但没有座位,我就得不断的选择座位,直到找到。要是系统能告诉我哪些座位可用就好了。停!--在这个例子中,用户已经深入到角色中去了,并且发现了当前版本用例的不足。...
针对用户界面设计的用例结构和式样,Larry L. Constantine, Lucy A. D. Lockwood,zhen_lei
......不管增加的定义多么微小,当前的"官方"定义实际上从Jacobson最初重于使用的定义转移到"系统为中心"的观点:重点放在系统如何工作而不是用户完成的或所希望的用途。我们的观点是,这种从内到外的透视方法,虽然精致,但实际上导致在界面设计中使用用例时出现问题。...
网上商店的模式,Eduardo B. Fernandez,Huang Yin
......网上购物已经变得很普遍,许多网站都为此提供了方便的用户界面。为了支持不同种类的导航视图,网上商店需要良好的基础结构。目录模式和购买流程模式是网上商店基础结构的一部分:目录模式描述了如何组织网上商店的商品信息,购买流程模式描述了在网上购买商品所必需的步骤。我们还将展示在网上商店中如何结合应用这两种模式。...
分析模式学习笔记之四:企业财务分析中的观察和测量(下),Windy J
......最常见的是用Name(名称)来识别对象,但任何有商业意义的属性都不适合作为对象的唯一标识,因为商业规则是不稳定的。关于这点可以参考Scott Ambler的文章"Mapping Objects to Relational Databases"...
【过程】
《人件》节选,Tom Demarco、Tim Lister,方春旭、叶向群
......用Billy的话来说,维也纳正在等着你,那是你人生之路的最后一站。当你到达那里时,一切都完了。如果你认为你的项目组成员对如此沉重的话题一点也不担心,请你再想想。你的下属很清楚上帝赐予每个人的生命都是短暂的,他们也非常清楚在他们这种无聊的工作之外还有更重要的事情在等着他们。...

第12期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer12.pdf

【访谈】
UMLChina访谈Scott W.Ambler: 空手道和太极拳
......我学习刚柔流空手道和太极拳,也很喜欢风景摄影。我也喜欢旅行,去年我去过南极,希望有一天会去中国。我很想看到长城、沙漠还有很多其它东西。...
【方法】
发明软件,Larry Constantine,zhen_lei
......看其他人的工作的第三个理由是可以帮助打破只有一种方法或只有一种正确方法的思维模式。尤其针对开发经理,需要学习不去接受程序员们的肯定说法。"这可能不灵活(或效率不高,浪费资源,粗糙),但这是采用Java(HTML、C++或API、MFC)仅有的一种方法。",程序员说。"胡说,"精明的经理说,"回去,找到另一种方法。"...
软件设计模式的非软件例子,Michael Duell,Wu
......代理模式提供一个中介以控制对这个对象的访问。一张支票或银行存单是账户中资金的代理。支票在市场交易中用来代替现金,并提供对签发人账号上资金的控制。...
GOF模式用于GUI设计,James Noble,cntang
...某些对象从来不在用户想要的地方。比如,用户想要存储目录结构下很深的一个文件,想让它很容易存取。或者用户希望下载一个网页,放弃任何包含的图像而保持文档结构不变。一个对象如何才能同时出现在两个地方呢?...
业务资源管理模式语言,Rosana T. Vaccare Braga 等,zhen_lei
......本文的模式语言反映了十年资源管理系统开发的职业经验。它的应用使分析新系统变得容易,因为它为系统分析提供了指南,包括了这一领域需要注意的主要问题。我们计划扩展这种语言,包括仓储管理和更好地处理付款,基于这种语言的框架也会开发出来。...
用户界面设计从抽象到实现——基于规范抽象组件的抽象原型,Larry Constantine,* Helmut Windl, James Noble, Lucy Lockwood,Lin George
......一个有前途的、同时支持新手和更高级使用模式的联合应该既支持在列表内用上-下按钮移动,又支持用拖放移动。初始设计可能类似于图7(a),它凸显了几个问题。如果将上-下按钮和滚动条按钮放在他们通常的位置上,很容易造成混淆。如果只是简单地移到左边,则它们可能容易被忽略,并且它们的功能可能不清晰。...
用创建方法封装子类,John Vlissides,透明
......如果客户(client)需要知道每个具体类的存在,那么让客户直接控制这些类的实例化也是个不错的选择。但是,如果客户不想知道这些,又该怎么办呢?如果这些具体类都被放在一个包的内部,并且都实现了同一个接口,而这个接口又不太可能发生变化,那么就应该把这些具体类隐藏起来,让包外部的客户去使用超类公开的创建方法(Creation Method),并通过创建方法得到满足需要的实例。..

第13期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer13.pdf

【访谈】
UMLChina访谈James J. Odell:UML的将来
......是的--很不幸--UML变得越来越复杂。我们正在努力改善这个问题,我们都需要新特性,所以,这是一个永久的矛盾。从哲学上说,我们已经决定UML的核心不会支持每个人的所有要求,相反,我们提供一个基本的核心,供大家使用"profiles"来扩展。通过这种方法,你可以在UML的基础上添加自己喜爱的方法,并使它成为标准,却没有把每件事都弄得复杂。例如,我们打算产生一种Agent profile,不是每个人都需要agent,但需要的人可以使用基本UML的这个扩展。...
UMLChina访谈Alan Shalloway:面向对象设计的新视角
......模式会从分析、设计和实现的角度来告诉我们问题。比如说,在分析阶段,我可能会发现我有几种不同的文档,需要支持不同的输出设备。所以,我看到系统中有文本、图片……它们使用激光打印机、绘图仪、点阵等等作为输出设备。这正是Bridge模式的场景。所以,我可以用一个抽象(不同的文档类型)来定义问题领域,然后给它以不同的实现(点阵、绘图仪等等)。现在我不必担心如何实现,因为我对Bridge模式很有把握。要求更快得到反馈则使你不得不对开发过程进行调整,因为你不能再等待完整的需求,也不能再希望做完整的系统设计,也不能先做完所有的编码工作再测试。...
【方法】
为什么用例如此难用?,Gary K. Evans,zhen_lei
......IT企业一直在尽力使自己开发的软件符合指定的需求,但是如何才能更有效地发现、捕获与沟通这些需求的确是个难题。用例在6年前的出现似乎提供了一个与该目标接近的解决方案。用例虽然已被权威的统一建模语言(UML)吸收采纳,许多组织却发现其约定令人感到困惑。虽然用例的意图是简洁和直接的,但许多IT组织发现使用用例收集和定义项目需求非常困难,它们往往难于管理和难于理解。...
隐喻的使用及误用,Larry Constantine,whoisred
......在现实生活中,你走进一家商店去购物,却被告知你虽然需要购物车,但却不能在购物时携带。相反,你只能把购物车放置在商店对面的屋子里。在你走进那间屋子前,你不能检查购物车内的商品,你甚至无法直接看到车内的东西,而只能看到一张车内物品的清单。在进行这样的购物时,你会有什么样的感想呢?...
停止过分设计!,Joshua Kerievsky,透明
......习惯所致,我马上就想到了模式。首先浮现在我脑海中的是Decorator模式,于是我就提议用Decorator模式来封装要显示的对象,然后重载封装对象的toString()方法。可惜,我的搭档的回答让我大吃一惊:"杀鸡焉用牛刀?"他创建了一个名叫NodeDisplay的类,它的构造子接收一个待显示类的实例。NodeDisplay类很容易写,因为它的全部代码量还不到10行。而我的Decorator模式起码需要50行代码,要通过很多次委托才能调用到需要显示的对象。...
【过程】
大型项目中的XP-开发者角度,Amr Elssamadisy,simaetin
......我们在ThoughtWorks的开发过程中采用了XP方法,我们根据经验对该方法加以剪裁以适应我们这个超过35名开发人员和15名分析员的大型项目。这个在内部称为ATLAS的项目是一个租用应用,它开始于三年以前,使用传统项目开发过程中标准的分析和front-loading(前载)设计方法。本文基于开发者的视角,讲述他们实践并积累的经验和技术。我们将通过列出与Kent Beck的《Extreme Programming Explained》(《极限编程精解》)中不同的实践方法,并给出我们的体会。之后,作为全文的总结,我们将给出对XP过程的推荐修改,使之可以在应用于大型项目时仍能快速产生高质量的代码。...
通过CMM 4级和5级的组织,SEI,shiyy
......我们根据最新的调查结果编辑了以下高成熟度级别的组织名单,需要说明的是,这个名单不是永久性的,它一直保持更新状态。该网页在不久的将来可能和"公布的成熟度级别"在某些方面结合起来。在http://www.sei.cmu.edu/sema/profile.html上可以看到即时的最新消息。...
【工具】
使用Rational Rose全景追踪,Richard Felsinger,盖九宇
......启动 Rose:选择菜单File-New,选择File-SaveAs,将文件另存为BusinessModel.然后选择File-New-SaveAs,另存为Requirements-AnalysisModel;注意,当Requirements-Analysis(需求分析)完成后要另存为Design-ImplementationModel(设计-实现模型);选择View(视图)选中Status Bar,Browser, Documentation, As Unified;选择Tools-Options-Diagram 选中Stereotype...
Rational ClearCase LT 使用指南,Jim
......b. 选择"高级"页面,点击"环境变量"按钮,进入环境变量设置。在"用户变量"一栏中点击"新建"按钮,输入变量名称:CLEARCASE_PRIMARY_GROUP 变量值设置为将要访问ClearCase的用户组,例如CLEARCASE_USERS,表示CLEARCASE_USERS组可以访问ClearCase。(在安装ClearCase...

第14期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer14.pdf

【访谈】
UMLChina访谈Alistair Cockburn:选择你所需要的
......最常犯的错误是太细化了。有时,人们书写非常非常细的用例,读起来都很烦。用例是一种叙述,我从未写过一个用例超过九步。如果你超过九步,那么要么是出现了界面设计,要么是步骤太详细了。...
【方法】
界面耻辱纪念堂--隐喻使用不当,iarchitect,金哲凡
......我五岁的侄女爱死了这个回形针,我每次打印,她都会兴奋得尖叫起来,因为回形针会模仿纸张在打印机上的动作,在滚轴上被压扁。五岁的孩子们认为回形针很可爱,Microsoft应该从中意识到一些问题:五岁的孩子是不会购买$500.00的软件包的,这是成年人的事,而大部分成年人会很快对这种"可爱"感到厌烦。...
界面耻辱纪念堂--可视元素,iarchitect,wanghongbao
......当我们最后意识到这个导航栏是可以滚动的,我们选这个例子的第二个原因就变得很清晰了:WebZip 为新用户提供了一个"Quick Start"选择,这个选择使用了一个向导风格的界面来清晰地说明如何使用这个程序。不幸的是,这个选择是导航栏的最后一项,直到用户知道如何使用这个定制的滚动控件才为用户所见。...
设计模式之路(一),Jun Qian
......很快在我做的项目里就碰到了我平生的第一个模式, Factory模式.这个项目是与加拿大一家公司合作的项目,他们的程序是用COBOL在MainFrame的机器上面写的。而我们的程序是C++在Unix机器上运行的。我们小组的项目就是中间的一个转接层程序(现在流行叫Multi-tierJ),通过TCP/IP接受加拿大来的信息,然后根据不同的信息类型,送到不同的处理单元去处理,最后通过TCP/IP返回给加拿大....
提取创建类,Joshua Kerievsky,透明
......从根上来说,这个重构其实就是Extract Class[Fowler],只不过是对类的创建方法进行的。一个类中存在创建方法,这很正常;但是随着创建方法越来越多,类本身的主要责任--它存在的主要目的--可能就变得越来越模糊,甚至被对象创建的逻辑给遮蔽住了。如果情况真是这样,就应该对这个类做一些调整,将创建方法移动到一个专门的创建类(Creation Class)中去,还这个类以本来面目。...
利用重构改进面向对象设计,Lance Tokuda and Don Batory,koun
......重构是一种保留程序行为的程序转变,能够使得面向对象程序进行设计的自动改进。存在三种设计改进,它们分别是:方案转换、设计模式微结构、特点驱动式趋进。这个研究展示如何利用重构使这三种方式得以自动进行;也给出一个全面的为设计改进的的重构方式的列表,同时分析了所支持的方案转换、设计模式以及特点驱动元模式。...
一个产品的订货和配送(系统)的分析模式,Eduardo B. Fernandez, Xiaohong Yuan, and Sandra Brey,li.sining
......本文给出的这些分析模式描述了顾客提交产品订单和订货之后的产品的配送过程。我们首先给出了两个基本的模式――订单和配送,然后把基本模式组合成为一个我们称之为语意分析的模式,与实际应用中增加灵活性相反,我们强调应用模型的语意方面。这类模式的目的是作为把需求转化为真正系统设计的起点。这个模式代表一个最基本的应用,可以把它应用在不同的场合,也可以与其它的相关模式组合在一起来描述更复杂的应用。产品的订货和配送是现实生活中一个非常通用的问题,这个模式集中在订单和交货以及它们之间的相关过程的基本特征。...


第15期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer15.pdf

【访谈】
UMLChina访谈Bruce Powel Douglass:实时系统和UML
......内存碎片回收是个大问题,因为它给系统增加了非常大的不确定性,很多RT都难以解决。你可以用C, C++, Java,Ada...甚至汇编语言来实现UML模型。我曾经用6502汇编语言为一个心脏起搏器写过一个多任务操作系统,而它来自一个OO模型。...
【方法】
界面耻辱纪念堂--颜色的使用,iarchitect,freeyourmind251
......尽管Windows95事实上允许用户可以选择多种颜色方案,但是,对于很多开发者,他们还是执着于默认值,那种中度灰色,这是标准的颜色方案。当共享电话联机Dialog程序运行在非默认颜色方案的机器上时,可以从其中的图片明显地看出这种现象。Dialog32的开发者在程序中固定使用一定的颜色来匹配他们自己PC上的颜色方案,却没有意识到运行在不同的颜色方案下的最后效果。最后的结果很不幸…。...
对象-关系数据库之间的映射,Scott W. Ambler,Adams Wang
......面向对象设计基于如耦合、聚合、封装等理论,而关系模型基于数学原理。不同的理论基础导致了不同的优缺点。对象模型侧重于使用包含数据和行为的对象来构建应用程序;关系模型则主要针对于数据的存储。当为访问数据寻找一种合适的方法时,这种不匹配就成为了主要矛盾:使用对象模型,常常通过对象之间的关系来进行访问;而关系理论则通过表的连接、行列的复制来实施数据的存取。这种基本的不同使两种机制的结合并不理想。换言之,需要一种映射方法来解决这个矛盾,从而获得成功的设计。...
如何用状态图进行设计,Dr. Doron Drusinsky,Jill
......所有软件实质上都可以认为是一种特殊的状态机。状态机是一个公共术语,用来描述一个系统在某种条件下会做什么以及按什么顺序去做。就像一个程序员写的声明,必须按某种顺序执行,每条声明说明计算机状态的改变。...
保险系统的部分模式,Wolfgang Keller,liwenhua
......对于许多保险公司来说,要建立一个能够缩短产品周期,柔性灵活的保险系统可谓是一个挑战。虽然这个系统有着巨大的市场,围绕这些相同的问题开展了许多项目,但是这些项目似乎仍然有些扑朔迷离。实际上,这个问题没有答案。这篇文章收集了一些模式,他们解释了那些驱动保险系统运转的各个部分在设计上的基本规律和方案。...
【过程】
XP的价值和局限,张恂
......国际著名杂志IEEE《Software》2001年最后一期对极限编程(eXtreme Programming,XP)做了深入报道,一共刊出4篇文章,分别是:《从CMM角度看极限编程》(Mark...
《极限编程研究》样章-设计死亡了吗,Martin Fowler
......对于许多开始粗略接触极限编程(Extreme Programming,XP)的人来说,似乎XP宣告了软件设计的死亡。不但许多设计工作被奚落为"Big Up-Front Design(巨大的前置设计)",而且诸如UML、富有柔性的框架,甚至模式这样的设计技术都不被重视或者近乎于忽略了。实际上,XP包含有许多设计思想,只是采用了一种与既定的软件过程不同的方式来进行设计。XP借助的多种实践让演进成为一种可行的设计策略,以此使演进设计的概念焕发青春。设计者需要学会如何进行简单设计、如何使用重构技术保持设计清晰,以及如何以演进的方式使用模式,因此XP也带来了新的挑战和技巧。...

第16期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer16.pdf

【访谈】
UMLChina访谈David Van Camp:模式、构架和XP
......模式不是技术——它们是简单的文档和教学技巧。当你逐渐熟悉模式,你就建立了一个模式“词汇表”。这使你能够更好地寻找模式和应用模式。这是一个学习过程。在美国和欧洲,许多人已经建立“模式讨论组”讨论模式。他们通常提出一个模式,然后大家评阅并相聚讨论。鉴别新的模式是一种艺术,不妨试一试,假以时日,你的能力会得到提高。鉴别一种新的模式,关键是要认识到其他人已经独立地找到了相同的解决方案并且得到确认。适当运用模式能够带来“良好”或改善的结果(不是其它途径能够带来的)。John Vlissides已经写了很多关于寻找和编写模式文档的文章。...
【方法】
使用UML和Rhapsody 开发导航控制系统,G.R. de Boer,ottafei
......本方案的目的是为了深入了解基于统一建模语言(UML)的开发工具Rhapsody。使用Rhapsody能够设计和构建高水平的嵌入式软件。我们选用Rhapsody为导航控制(CC)建模,目的是从中找到Rhapsody这种开发工具的各种可能性。目前导航控制(CC)在小汽车上的应用已经非常普遍。因而非常适合作为控制系统在日常生活应用的案例。导航控制(CC)包括基本的循环控制和一些用户接口。...
处理对象的特性,Martin Fowler,Xu Zhiling
......几乎每个创建的对象都需要特性:有关对象的一些声明,例如,人的身高,公司的CEO,航班的航班号。有许多种方法可以模拟特性,在本文中,我将探索其中的一些方法,以及可能在什么时候使用它们。常见到一些模式(pattern)涉及到这个主题,但是它们通常仅覆盖部分图景(picture)。在此,我想广泛地研究这个问题,给出对这些选择的更好讨论。...
根据合同进行分析--录像店案例研究,Richard Mitchell,zhen_lei
......本文包括录像店案例研究的一些片段,用来说明根据合同进行分析的原理。本文假定读者已经从其它渠道学习了一些关于根据合同进行分析的方法。...
Reactor模式――同步事件复用和处理调度的对象行为模式,Douglas C. Schmidt,Tonny Tam
......为图解Reactor模式, 考虑一个如图1所示的提供分布式日志服务的事件驱动式服务器程序。客户程序在分布的环境中使用日志服务记录它们的状态信息。这些状态信息通常包括错误通知,除错跟踪,还有执行效率报表等。日志记录被送到中央的日志服务器,并被日志服务器记录到各种输出设备上,例如控制台,打印机,文件,或者是数据库。...
【过程】
《人月神话》20周年纪念版评论集,陈懋戍
......Brian Kernighan:我唯一一本读过一遍以上的书,是Fred Brooks的《人月神话》,实际上我每过一两年都重读一遍。部分原因是这本书文笔很好,部分原因是书中的忠告很有价值,即使是25年以后。当然,现在很多细节上的地方,和我们做事情的方法,都有不同。我们的工作更自动化,计算机的“马力”更强劲,但书中依然有许多好的忠告,我非常推崇这本书。这是我唯一能想起来的你能从中体会到乐趣和思想的计算机科学书籍。...
《敏捷软件开发》翻译草稿样章,Alistair Cockburn,Jill
......通常,极限一小时的主持者会选择一个有趣的任务,如设计一个捕鱼设备,它能够保证鱼在交到厨房的时候还是活的,也能保证啤酒在全天时间里一直是凉的。(当然,在迭代过程中他们不得不缩小范围!)我们使用90分钟的微缩流程来帮助一个有50个人的公司的团队来体验我们建议的新的开发流程(你将注意到这个微缩流程经验与第57页所描述的信息是多么相似)。...

第17期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer17.pdf

【访谈】
UMLChina访谈Marko Boger:XP、UML和Poseidon
......ArgoUML是一个开放源代码的项目,这便是它与一般的项目所不同的。这也只是简单的提法。当然,Poseidon还会有很多不同之处。很显然,我们是Rational的竞争对手。如果Rose是更好的工具的话,我想我们就不会开始Argo的开发了。...
UMLChina访谈Peter Merel:妻子告诉我该睡觉了
......我曾经好几次遇到过这种情况,我并不认为有非常完美的解决方案。最好你的远端客户能指定一个本地的代表,这个人有相关领域业务知识并能定期和客户沟通。在HP工作的时候,曾经有一次有三个小组介入了我负责的一个项目,主要的两个在圣地亚哥。除了相当昂贵的电视会议系统的花费外,我们每个月还必须派人飞来飞去。...
【方法】
用户界面的UML建模,Paulo Pinheiro da silva, Norman W. Paton, 李巍
......统一建模语言(UML)是对应用程序进行面向对象建模的标准标记语言(notation),因此我们会很自然地将其作为用户界面(UI)建模的选择。但是,我们并不清楚如何使用UML来进行UI的建模。本文给出了一个使用UML进行用户界面建模的案例。该案例指出了那些无法使用UML标记来进行建模的UI侧重面,以及一组可用于UI建模的UML构建法(constructor)。其中的建模问题说明了使用UML进行UI建模的一些缺陷,而采用的这组构建法也同时表明了一些该方面的能力。这些被证实的能力和缺陷可作为公式来表达成一种对UML进行扩展(extend)的策略,从而对用户界面的设计提供更好的支持。...
界面耻辱纪念堂-术语,iarchitect,金哲凡
......如果程序开发者和用户具有相同的知识背景,那可就太好了。程序就会按用户完成任务的需要来设计,双方都知道对方说的是什么。不幸的是这样的情况太少了。有太多的程序给人的印象是:它们使用不同的语言。下面就是一些非常不清楚的程序元素的例子。...
用户界面软件,Jens Coldewey,Tom.X
......象SmallTalk或Java这些语言,通常需要一行代码来使得某个菜单选择失效,或者弹出一个简单的对话框来提醒用户。所以,当你的域层面的代码(domain code)里发生了一些奇怪的事情时就总想提示用户,问:“要不要继续运行?(是/否/帮助)”然而,这真的是一个好主意吗?或迟或早你就会发现有不同的用户要对系统进行操作。它们必须每天重复上千遍的工作,希望按尽可能少的键来让这个系统帮他完成工作。...
分析模式学习笔记:LOG-日志记录模式,Windy.J
......轻轻地我走了,正如我轻轻地来,我挥一挥衣袖,不带走一片云彩。这样的情况在有了日志记录的系统里是不可能发生的,因为,日志把发生的一切都“记录在案”了,这一节,我们就来看看日志记录建模和实现的各种思路。我们首先来看一张Windows系统日志的图片...
电子商务应用系统的几种模式,Dragos A. Manolescu,Adrian E. Kunzle,杨德仁
......软件开发业见证了从桌面应用系统的开发向高扩展的、分布式的、基于服务器的电子商务应用系统的开发的转移。大多数开发者来自于PC世界,很少知道如何处理分布式应用、服务器、并发性、扩展性、高可用性和容错事宜。电子商务应用开发模式将使开发者意识到他们需要处理的核心问题,并向他们展示解决这些问题的方法。本文的构建电子商务应用系统的模式集迈出了这方面的第一步。...
重构过程中的行为保持,William Opdyke,透明
......显然,重构应该保持程序的行为不发生变化。在本章中,我将讨论几个与“行为保持”相关的主题。在第1节中,我首先向读者介绍几个很容易在重构过程中被破坏的程序属性。在第2节中,我对重构的作用范围做了一个定义。在第3节中,我列出了用于描述重构前提条件的函数式,这些前提条件可以保证重构前后程序的行为保持一致。...

第18期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer18.pdf

【方法】
驳UML三大“硬伤”论,张恂,think
......本文对2002年5月《程序员》杂志刊登的《UML三大“硬伤”》(指UML“上不着天、下不着地、一盘散沙”)一文所存在的18个错误逐一进行了批驳,指出原文在论据、论证、论点和文风上存在的严重问题,并结合RUP(瑞理统一过程)给出UML建模实例,演示了如何对原文所提及的商业公司进销存系统进行正确的业务分析。本文适合的读者包括UML和面向对象技术的爱好者、初学者,软件开发人员、软件企业与行业企业的技术主管等。...
电梯系统的UML文档,Lu Luo,王君
......作为我们的教学项目,电梯系统的设计与“真实”的系统相比省去了很多技术上的细节。我们的电梯系统有所有的电梯系统都有的基本功能,如上升和下降、开门和关门当然还有载客。电梯假设被用在一幢大楼的第一层到第MaxFloor层,第一层是大厅。电梯里有每一层对应的呼叫按钮。除了第一层和顶层,每一层都有两个按钮,乘客可以呼叫上楼或下楼。顶楼只有一个下楼按钮,而大厅只有一个上楼按钮。当电梯停在某一层,电梯开门,电梯指示灯亮标明当前运行的方向,这样乘客就知道了当前电梯运行的方向。电梯在两个楼层之间快速移动,但它应该能提前减速停在目的层。为了保证电梯系统的安全,在任何不安全的情况下,紧急制动就会被促发,电梯被强制停止。...
构建EJB应用—模式集合(上),Eberhard Wolff,杨德仁
......虽然EJB为相对复杂的任务提供了简单的API,然而设计和实现一个基于EJB的可扩展的、可维护的和合理的快速应用系统并不容易。随着时间的推移,一套公认的模式已经形成,本文将讨论其中的一些。这些模式将是本文作者写作中的有关EJB体系结构和应用模式一书的部分篇章。我们不准备讨论J2EE的其它部分如Servlets或JMS,只讨论由EJB组成的中间层。...
一种在线拍卖管理的模式语言(上),Paulo C. Masiero,vicky wei
......商业资源管理的模式语言主要处理商业资源的交易、位置和维护。在线拍卖管理的模式语言正是在这种环境中开发出来的,用以帮助开发那些通过web方式拍卖来进行交易管理的系统。在线拍卖管理的模式语言的开发是基于三个现有Internet拍卖系统——DBay,iBazar,Arremate.com。由于缺乏对这些系统的文档或源代码的访问权限,我们基于用户界面对这些系统作了逆向工程。然后基于我们自己对拍卖系统的理解,并参考现有的关于拍卖系统的手册,我们开发了一些模型以描述系统的功能。通过发掘三个系统的共有功能,我们从这些模型抽象出这些模式。他们展示了在线拍卖系统中的功能特点,而非设计或实现问题。本文中提供的范例也是从这些模型中抽象出来的。...
CRC建模方法――跨跃开发者与用户之间的交流障碍,Scott W. Ambler,huang_shen
......当小球传到某人的手里,他应该将这个职责的业务逻辑一步一步地描述出来。应该看作:BDE正在为职责叙述伪代码(高层程序代码)。这往往是用例场景测试中最难的部分,许多BDE也许不太习惯一步一步地描述业务过程。遇到这种情况时,辅导员应该帮助他们理顺逻辑。你会发现,通过头几个场景的测试,BDE能很快地掌握描述过程逻辑的技巧。BDE描述过程逻辑时,记录员应该将其记录下来(记录员的工作就是为系统记录业务逻辑和规则,这正是BDE所描述的)。...
【过程】
轰然巨响,Martin Fowler,Jady
......我曾经跟客户谈到他们要我完成的一个对象模型复审。“我们能先给你一些文档,有用吗?”他们问。希望我没有说谎,我给了肯定的答复。两天后,随着一声闷响,UPS在我的门外卸下了包裹。那是足有1.5英寸厚的文档。我打开包裹,发现那些由CASE工具产生的印刷品。显示了一些图、给出了每个类的详尽描述、包括类的所有的属性和操作。这些都有定义。Contract类定义成“一个很多团体之间的合同”,其dateSigned属性定义为“签订合同的日期”。我读遍了这1.5英寸厚的文档,最后我却糊涂了。那有很多关于那些对象是什么的描述,但是没有它们真正意味着什么的解释。这种情况已经不是第一次出现了,我想也不会是最后一次。...
烧毁这本书,别让员工看到―《人件》评论集,柳林
......这是我一直喜爱的软件工程书籍。《人件》正确指出软件工程是对人,而不是针对技术。它看到在软件开发过程中人的许多方面,并指出人并不是软件开发机器中简单的小齿轮。这本书花费了许多的时间讨论团队,使你认识到团队的价值。但它没有一般的管理书籍列出“好团队”的标准,而是论述如何创造一个好团队,并指出它有多难。对于一个尽力去建造一个团队的管理者,这本书帮助他认识到成功的技术与技巧。它并不教你关于开发过程的知识,而是通过教你认识到在软件开发中人的价值去管理开发过程(但它并不仅仅论述管理者,我强烈推荐这本书给每一个人,从低级工程师到CEO)。这本书也包含涉及办公环境的章节,并提供证据说明为什么通常的观点并不适用于软件开发。我只学了这些章节,就促使我辞掉了原来的工作!...

第19期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer19.pdf

【新闻】
Borland以1.85亿美元收购UML工具厂商
......Borland这次在设计方面有目的的扩张对UML巨头Rational形成强有力的挑战。TogetherSoft由UML领袖之一Peter Coad创立, 迅速在分析设计领域获得关注,与其他Java IDE一起广泛使用。Coad有望在提升Borland在软件开发中的地位方面扮演重要角色。...
【访谈】
UMLChina访谈高焕堂:何谓世界软件之神
......iteration 与 prototyping 来不断修正 architecture的分析与设计。吴清源大师说:「整体、和谐、创新」代表的即是在以架构为主的设计上,要能注重团队的和谐、一致性。在团队的脑力激荡下,是需要发挥 design 的创意的。「兵无常势,水无常形,能因敌之变化而取胜者,谓之神」,希望能藉以孙子兵法的这句话让各位对软件的 design 有更多的深思。因为软件的需求是善变的,所以善于利用需求之变化而取胜者,将能称霸软件世界,谓之:世界软件之神。...
UMLChina访谈尤克滨:简单正是用例的价值
......用户一般不会说看不懂我们写的需求,而是等我们开发出他们认为不对的结果之后告诉我们,原因是我们没有在早期提供一个用户作出正确判断的机会(组织形式)。各种方式表述的需求在微观层面没有差异,但组织形式完全有可能阻碍用户正确地理解。...
【方法】
致面向对象技术初学者的一封公开信,Alistair Cockburn,袁峰
......过去6年中,我曾经无数次地在饭店、酒吧、旅店大厅等各种地方以同一种方式度过愉快而漫长的夜晚:和同样追求真理、光明和智慧的伙伴一起探讨面向对象的真谛。现在,我已经可以回答很多当年我遇到的问题。这些同样的问题也在困扰着我的一位新同事,在一家饭店里,我花了整整一个晚上和他讨论这些问题。结果第二天,他的同事又来问这些问题,并建议把我们的谈话内容记录下来,这样他可以拿去给他的同事看。考虑到还有很多和他的同事一样询问这些同样问题的人,我决定写下这篇文章。...
高焕堂答疑录(一)
......所谓business process是有很多个views, 有些人重视activity flow, 就会抽象出activities而抽掉data 及worker等, 成为activity diagram. 有些人重视data flow, 就会抽象出data而抽掉activities 及worker等, 成为Data Flow Diagram. 有些人重视workers之间的message passing及互助合作, 就会抽象出objects而把data 及activity纳入objects内, 成为object model. UML是来自OO领域, 比较偏重object model, 需要习惯于object thinking, 一般人会觉得不太直观. 但是要将MIS系统落实到N-tier或component-based环境, 就必须将activity flow & data flow的model转为object model, 因为object model 的内涵(semantics)最丰富, 能提供充足的information给software developers. UML2.0已经吸收IDEF, 强化了business activity flow的表达.因为manager喜欢activity flow diagram, UML2.0 比较能抓到manager’s view 了. 记得, use case不是用来表达business内部的work flow!...
构建EJB应用—模式集合(下),Eberhard Wolff,杨德仁
......通常,不保留旧数据就删除实体组件或改变数据,因此一个改变仅仅是用新数据覆盖旧数据。但是,往往因法律原因这种做法不可接受。法律要求旧数据归档而非删除,以便能重建旧数据。在这种情形下,通常存储旧数据以便能用手工SQL查询语句(历史化)重新产生它就足够了。但存储旧版本以备发生错误时撤销就有意义了。在这种情形下,旧数据必须能被应用和用户(版本)访问。...
一种在线拍卖管理的模式语言(下),Paulo C. Masiero,vicky wei
......图8就是在线拍卖网站Arremate.com所采用的拍卖资源模式的范例,它采用多重拍卖Multiple Auction方式拍卖单个或多个资源项。Arremate.com还使用了其他两种拍卖方式:底价拍卖Reserve Price Auction和赢家拍卖Winner Auction(是采购拍卖Purchase Auction的实例)。eBay在多项产品的交易中使用荷式拍卖Dutch Auction,在单项产品的交易中则使用标准拍卖Standard Auction。它还提供底价拍卖Reserve Price Auction和采购拍卖Purchase Auction方式。iBazar只提供标准拍卖Standard Auction和底价拍卖Reserve Price Auction两种方式。...
一种关于物品修理的分析模式,Eduardo B. Fernandez,Xiaohong Yuan,刘巍
......把一件损坏的东西拿到修理店去修理,在日常生活中是一件很平常的事。顾客将损坏的东西,如电脑或者汽车送到修理店时,一个负责接待的技工会对要做的修理作出大致的估算,他同时会对修理的内容作纪录。所有修理活动都被记录到修理日志中。一次修理可能因为缺少零件或其他原因而被耽搁,也可能被取消。...
【过程】
《人月神话》节选,Fred Brooks,Adams Wang
......第二个经常提及的解释——《人月神话》仅仅是顺便提及了软件,而主要针对团队中的成员如何创建事物。这种说法的确有些道理,1975年版本的前言中提到,软件项目管理并不像大多数程序员起初所认为的那样,而更加类似于其他类型的管理。现在,我依然认为这是正确的。人类历史是一个舞台,总是上演着相同的故事。随着文化的发展,这些故事的剧本变化非常缓慢,而舞台的布局却在随时改变。正是如此,我们发现二十世纪本身会反映在莎士比亚、荷马的作品和圣经中。因此,某种程度上,《人月神话》是关于人与团队的书,所以它的淘汰过程会是缓慢的。...

第20期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer20.pdf

【新闻】
IBM收购Rational
......Rational为开发企业应用和开发软件产品提供开放的,工业标准的工具、最佳实践和服务。通过收购Rational,IBM将能够提供一个全面的开发环境,从整合业务流程和软件基础架构。这次收购是IBM的“e-business on demand”策略的重要组成部分。...
【方法】
家用报警器的UML设计及其在C++和VxWorks上的实现,M.W.Richardson,liuweiw
......论文描述了如何运用UML(统一建模语言)设计一个简单的家用报警器,并实现到VxWorks操作系统上。本文分两个部分,第一部分描述了如何用UML设计和验证家用报警器的模型,以使其独立于特定的硬件和操作系统。第二部分则细节地描述如何将此模型实现于运行VxWorks操作系统的486硬件平台上。模型的设计、开发和验证使用了I-Logix公司的可视化编程环境“Rhapsody”。...
使用模式和XP构造复杂的面向对象系统,Eduardo B. Fernandez,曲俊生
......复杂是很多重要系统的特性。这些系统都具有大量交互的实体,复杂的约束,同时需要满足非功能性需求。在语义分析模式(SAP)中,每个模式都对应一系列用例。我们利用SAP在增量式开发中建立一个整体的概念模型。这个整体模型为XP提供了一个能够考虑分布式、安全以及测试性等因素的结构。SAP也可以应用在XP的每个增量开发阶段,从而保证良好软件开发原则的应用。...
【过程&人月神话专题】
钱五哥答疑录(一),钱岭
......软件开发不是一个随便玩玩就可以的事情,一些非专业人员的程序更本无法投入使用。能够发布使用的产品即需要在软件工程的管理下进行,同时也很需要开发人员的编程水平,完成同样的功能,高水平程序员和业余程序员写出来的程序,在性能、可靠性、可维护性等方面都相距很远。最近看有报道说高水平技工在国内看好,我想在软件开发领域也是一样的。国外,很多程序员会一辈子搞程序开发,因为他们把这当作一种事业和一种追求。...
Frederick Brooks传
......20世纪最后一年也就是1999年的图灵奖,授予了年已69岁 的资深计算机科学家布鲁克斯(Frederick Phillips Brooks, Jr.)。布鲁克斯这个名字在中国知之者不多,但在美国却是大名鼎鼎。因为他在60年代初只有29岁时就主持与领导了被称为人类从原子能时代进入信息时代标志的IBM/360系列计算机的开发工作,取得辉煌成功,从而名噪一时。以后他作为硬件和软件的双重专家和出色的教育家始终活跃在计算机舞台上,在计算机技术的诸多领域中都做出了巨大的贡献。从某种意义上说,对于布鲁克斯而言,图灵奖是一个“迟到的荣誉”。...
《人月神话》各章精选,Fred Brooks,Adams Wang
......史前史中,没有别的场景比巨兽在焦油坑中垂死挣扎的场面更令人震撼。上帝 见证着恐龙、猛犸象、剑齿虎在焦油中挣扎。它们挣扎得越是猛烈,焦油纠缠得越 紧,没有任何猛兽足够强壮或具有足够的技巧,能够挣脱束缚,它们最后都沉到了坑底。...
《人月神话》软玉生香,刘天北
......“大”,对于书--尤其是技术书--来说,不见得就“了不起”。以我个人的阅读习惯,多于五百页、开本又超过“大32开”的技术专著,那就只能当字典查,又好比皇宫里的大龄宫女,偶一调情也可,若要三千宠爱集一身,不啻为非分之想。本来一卷在手,有如软玉生香在抱,总以“轻”、“薄”为妙,若是庞然巨物,体态狼伉,未免让人产生心理障碍(借此一角向通读了《C++ Primer》的各位致意:你们都可以去做《大内密探零零发》里艳福齐天的皇上)。眼下说的这本MMM,正是技术书中的赵飞燕,可作字面意义上的掌上舞:大32的开本,算上注释、索引共332页,要紧的是,每章前的大量篇幅留给题图和题记,19章下来,实在要读的内容不到200页。...
《人月神话》与实践,Adams Wang
......许多朋友认为现在的软件工程数据比较理论化,可操作性不高,往往只能了解一些理念。在面对具体项目的时候,还是有些迷茫。而在整个翻译的过程中,Brooks的观点以及治学态度经常令人叹为观止。这里,就自己的一些体会和实践同大家探讨。...
《人月神话》20周年纪念版评论集,陈懋戍
......嫉妒、羡慕和突然的现实:什么是我们拥有的象年金一样的东西。我高兴地说,自此书出版至今,我已读过1975版至少四遍;在接到Brooks电话后,我再次将它从书架上拿下来,重读了一遍。但这次,是有特殊目的的:实际的原因来自于他的电话,Brooks教授告诉我,目的是发现自这本书1975年出版以来,计算机领域是否有有意义的事件发生。...
《人月神话》争论:软体尚方宝剑何在,欧阳进
......本文以时间的前后﹐依序交叉介绍两位大师的见解﹐期能引起读者对软体未来的些微兴趣。由于笔者的学养和功力远不如两位大师﹐只能介绍他们文章里的精华﹐并未添加笔者的阐释或见解以免您受到笔者有限能力的误导或局限您的思想和视野。希望您有空细读两位大师的原文著作﹐培养您自己的思维和创意。...
《人月神话》出版后的网友评论,chinapub、cnforyou
......一本多年来看到被无数的工程、实践著作引用的文献,终于乖乖地躺在了我的手心里。第一件事就是把中国人写的那些页数,统统裁下来扔进垃圾筒,本来中文的表达力已经限制了我们对全书的理解,请不要再让那些什么UMLChina之类的废话把整本书的导向都弄错了吧!在《神秘的人月》诞生的时候,别说UML,连C++都还没有呢。什么印度,呵呵,印度注定要失败的。不过客观地说,翻译的水平虽然没有我期望的那么高,但居然也不像我想像得那么差。总体而言,还算差强人意。排版不错,我喜欢这种小开本的书,封面也不错。如果是裘宗燕老师来翻译,一定又是一本旷世译作。...

第21期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer21.pdf

【新闻】
年度回顾:开发工具的UML/MDA趋势
Visual Studio .Net 2003--“Whitehorse”蓄势待发
《人月神话》与软件开发基本问题研讨会在京举行
【访谈】
UMLChina访谈Jutta Eckstein:没有客户就没有项目
......但是如果你希望忽略客户,你为什么去开发一个系统?没有客户,没有项目;或者说,没有客户,就没有成功的项目。请你牢记:客户是每个项目所必须的,而不仅仅只是XP的项目。...
【方法】
傻姑之路:通往职业初段—前言,think
......此方法基于UML,但只专注三个核心要素:用例、类、交互。通过这三个要素的协作,“自外而内,由粗至精”,就能解决软件开发的基本问题。就如金庸小说中的黄药师,只教给傻姑三招,让她练得精熟。开发人员只关注这三样东西,但对每一个细节中蕴含的道理细细体会。每个细节都要精熟,到位,不浪费一分力气。...
过程敏捷性和软件可用性:以使用为中心的轻量级设计,Larry L. Constantine,huang_shen
......现在的软件开发有时像一场奇怪的比赛。场地的一边,站着一帮身着各种颜色的破旧运动衫的没规矩的家伙,他们象征许多公司在程序设计时所呈现出的毫无章法的混乱状态。而在场地的另一边,我们看到了排着整齐方队的重量级选手们,每一个大汉的胸前都镶嵌着一个大大的“U”字。现代软件开发的重量级选手正是统一过程(Unified Process)和它的追随者以及统一建模语言(UML)。...
Web应用模型中的抽象和复用机制,Gustavo Rossi,ydr
......建设复杂的WEB应用是一项耗时的任务,因为它们必须提供对重要信息资源的导航访问,不仅允许用户全面浏览潜在的信息世界,也允许对信息进行操作。在某些领域如电子商务中,客户的行为触发了那些必须要与核心业务软件集成的复杂工作流。这种集成也必须以另外一种方式进行;例如,电子商店中的营销软件应该监视顾客的行为,以便更有效地为顾客导航。第一个明显结果是,我们不仅必须仔细设计导航体系结构,而且要有效地与业务模型集成。...
GUI设计精髓:交互,Weinschenk,Ma Yaohua
......只对那些频繁或关键的操作设置命令按钮(见图1)。实际上,命令按钮扮演着醒目显示操作内容的角色。在一个窗体上,命令按钮不应当超过六个。同时命令按钮的操作内容也要出现在菜单项中。如果操作既不频繁也不关键,将其放到下拉菜单中即可。...
【最后期限】
总把新桃换旧符——写在《最后期限》出版之前,透明
......如果有可能的话,在一个星期之内读《人月神话》和《最后期限》这两本书,绝对是一个绝妙的阅读体验。你能看到Brooks和DeMarco在几乎相同的知识背景下得到的两种截然不同的态度:“人月是神话、银弹无处求”的悲观,和“逢山开路、遇水架桥”的乐观。如果读者再带着项目的紧迫压力希望在这些武林秘籍中找到一些灵丹妙药,被这一阴一阳的两股内力搅和搅和,怕是脑子会被弄晕掉。...
《最后期限》:一本软件开发小说,Huang Yin
......几年以前,我读过Eliahu Golden的目标和思想,“哇,如果有个人能够写一本象工程技术方面的《目标》那样的关于软件项目管理的小说来取代那些软件工程教科书,该有多好!”在《最后期限》中,梦想成真了。DeMarco用一种幽默而有趣的方式为软件工程教学作了一项伟大的工作。实际上,有时我发现自己总是在没有认识到一个项目管理教训的价值之前学习它。......
《最后期限》各章精选,Tom DeMarco,透明
......“没问题。唔……”元首似乎有点走神。他懊悔的回头看着屏幕,好象是想找回刚才做的事情。现在汤普金斯可以看到屏幕了,上面似乎是一页程序代码。C++,他想。一个声音从房间的后面传过来,莱恩小姐端来一盘软饮料和点心。元首稍微愉快了些。“噢,好。”他说道,然后拿起一块奶油蛋糕,塞进了嘴里。......

第22期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer22.pdf

【新闻】
SteelTrace公司集成Catalyze套件与Rational Rose
Chick-fil-A统一使用Together ControlCenter进行Java开发
Sun整合第三方UML建模工具
【方法】
用例:十年风雨,Alistair Cockburn,think
......用例是与外界交互时系统行为的平直叙述。我想你们中的大多数人已经使用或听说过用例。其中一些人可能还听说过关于用例实际上是怎样有用(或怎样无用)的热烈争论。在过去的十年间,我们对用例的理解已经向前迈进了一大步。本文的目标是为了说明:了解这些发展能让你了解现在人们使用、滥用、或者只是误解用例的方法,以及你自己如何更好地使用用例。为了展示发展的阶段,我把文章分成4幕来讨论:史前(比十年前还早),过去十年,现在,未来。...
通往职业初段—使用用例组织需求(上),think
......伴随着UML到来的“用例”,为需求技术在国内的普及起到了至关重要的作用。目前,“用例”是UML中讨论得最多的话题之一,从UMLChina讨论组的帖子可以统计出。用例是什么?用例是文档还是图?用例的粒度如何把握….都是经常被讨论的话题。...
UML与XP,Alan Cameron Wills,刘巍
......在我们给客户咨询过程中,我们已经取得了一些适应上述需要的经验,同时保留了极限编程(XP)的优势。当然,其结果非常类似如RUP这样的其他的迭代过程。不过,我们注意到了其他方式的许多改进。现在,我们把这种方式叫做XP/RM。...
分析模式应用――帐务模式,Windy.J
......代理是一种销售方式,代理商通过出售源厂商的产品或推广服务商提供的服务获得利润,不管是产品还是服务,代理商和产品/服务商之间的利润计算都是基于更优惠的代理价格(对产品代理而言,代理价格可能跟历史代理销售收入有关,如果上年度或上季度的代理销售收入较高,可能代理价格就更优惠),或者基于代理销售收入本身(对服务代理而言,更有可能是这种形式,代理销售收入越高,代理佣金也就越高),或者可能的其他方式;因为基于代理价格的结算相对而言较为简单,结算通过代理商对购买的产品付费已经完成,所以,我们在这里要应用到帐务模型进行处理的,不是基于代理价格的结算,而是基于代理销售收入的结算。...
【人件】
别把开发人员当成牲口,Mike Gunderloy, think
......幸运的是,在某些公司或者在某些领域,事情还是好转了。Microsoft因为在办公设施方面“浪费钱”而“声名狼藉”:给开发人员配备带有门和窗的办公室,还提供免费饮料,休息区,还有其他很多无聊的东西。结果呢?Microsoft的人们确实喜欢呆在办公室,自由自在地集中精神,写出高质量的代码。事实上,Joel Spolsky曾声称:微软成功的原因之一就是公司里的所有经理都读过《人件》。Joel推荐软件经理每年重读这本书一遍――这主意不坏。...
《人件》各章精选,Tom DeMarco、Timothy Lister,方春旭、叶向群
......几年前,我与南加州一个大项目的项目经理交流各自的艰辛历程。他开始叙述将项目和疯狂的时间表压到他下属的身上产生的影响。一是发生的两宗离婚案,其中原因可以直接追溯到与他的人经常加班有关;再者就是一个员工的孩子吸毒,其中原因可能是由于在过去的一年里,孩子的父亲太忙,未能尽到做父亲的责任,最后,测试团队的负责人又神经崩溃。......


第23期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer23.pdf

【新闻】
业务流程领域的Popkin-Intalio联队
JBuilder套件用Together Modeler取代Rose/RUP
【方法】
UML序列图开发,Il-Yeol Song,李巍
......然而从表面上看来,构建一个OID的方法没有在文献中更多地加以描述。我们的经验表明,初学者在理解和开发OIDs上会有很大的困难。大多数UML书只是简单地阐述了OIDs的标记和语义,以及介绍事先已构建好的序列图。有些作者提供了序列图开发的简单指导原则。我们发现这些简单指导原则对于许多初学者而言是不够的。基于作者多年从事面向对象分析和设计的教学经验,我们提出了一个有效的开发序列图的十步启发法,并结合一个案例学习来演示本方法。...
过程模式的UML描述,Harald Storrle,Happy
......现在UML正迅速发展成一种数学上精确形式化的主体,逐步趋向于自动化和形式化,不仅对于过程模型,对产品模型也是如此。现在来看看过程模式的影响,设计模式(Design Pattern)的概念在使用者中被广泛接受,并成功地证明了它的实际适用性。模式捕捉细小的、连贯的和自充分的知识片断,允许在不同的环境中使用,特别是应用于不同的规模。使用设计模式是一种重用设计知识的形式。过程模式非常像设计模式,只是应用于过程领域。确切地说,术语“设计模式”有点误导:典型的设计模式如(MVC)模型-视图-控制器等,真正说的只是产品,那是设计的结果,而非设计的过程。所以,为了区别它们,我把它们叫作结果模式和过程模式。...
小项目的RUP应用,金哲凡
......通常人们都认为小项目只需要小团队。很大程度上这种想法是对的,但是特定的任务仍然需要特定的技能。这意味着开发团队要么必须能拥有多项技能,要么与特定技能相关的活动不得不被取消,而后一种情况更加常见。举例来说,对项目X,开发团队决定用用例来捕获需求,并使用UML对用例进行分析,以此将设计工作推进到分析模型。然而,由于缺少必要的UML建模技能,用例开发出来,流程定义好之后,代码就直接从用例描述中产生出来。代码直接来自用例,与过去很多项目的直接从需求进行开发并无不同。造成这种状况的原因是前述的时间约束,加上缺少合适的技能。...
把业务对象连接到关系数据库(上),Joseph W. Yoder、Ralph E. Johnson等,Happy
......这些模式描述如何把业务对象映射到非面向对象的数据库中。面向对象和非面向对象这两种技术存在着阻抗不匹配,因为对象由数据和行为组成,而一个关系型数据库则是由表和它们之间的关系组成的。虽然不可能完全消除这个阻抗不匹配,你可以遵循适当的模式使之最小化。适当的模式可以向开发人员隐藏持久化细节,而让他们专注于理解域问题而不是如何将对象持久化。...
现实世界电子商务系统的数据库设计,Il-Yeol Song,herman
......电子商务价值链是表现在线购物者与电子商务系统交互性的一系列业务过程。价值链帮助我们理解电子商务系统的业务过程,确定建立可操作数据库系统的数据要求。Treese和Stewart展示了一个四步价值链,由“ 吸引”、“交互”、“操作”和“反应”组成。“吸引”指获取并保持顾客的兴趣。“交互”把兴趣变为定单。“操作”管理定单;作出“反应”服务顾客。四环价值链可以被视为最小的电子商务系统模型。...
【人件】
人的问题:关于《人件》,Jacques Lebrun
......在我书房的一角,《Peopleware》尴尬地和其他原版“技术书籍”分享着位置。尴尬,首先就从书名中显露出来,这个自造的表达方式置身众多的“Patterns”“Models”和“Components”之间显得可疑、孤单、缺乏一目了然的“技术特征”。People和software之间这个狡诈而轻快的拼搭,带有明显的“头脑风暴(brainstorm)”的痕迹(你还能在书中找到其他的例子,比如“teamcide(队杀?)”)。...
开发人员是人吗?,Dr. Jakob Nielsen,Windy J
......由于正在为一个开发人员站点写这篇文章,我想我将挑战这个古老的问题:开发人员是不是人?我确实希望能从广大读者的血样中来个DNA测试,证明他们属于人类这个物种,但那并不是我关心的,相反,这里的问题是开发人员和其他人类是不是一样,或者,到底差了多少。......
办公室空间,下一场革命,Diane Pettus,Windy J
......一个仔细考虑了办公室空间设计的真实例子是Interface Technologies, Inc. (ITI),一个定制软件开发公司,去年十二月刚刚搬到罗利(Raleigh)Six Forks大道Forum I大厦一个大概11000平方英尺的单位。他们的总裁Kelly Campbell说他搬迁的目标是要建立一个能象加满了润滑油的机器一样运转的地方,一个因为尊重开发人员的日常工作模式,因为认识到客户们对效率的期望,从而不断增加能量的地方。...

第24期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer24.pdf

【新闻】
数据建模工具与BPM日趋融合
业内第一个全面的用例开发平台
面向服务架构(SOA)的原则
Ivar Jacobson即将离开Rational
【方法】
让历史告诉未来-—评Ivar Jacobson 博士的《用例的昨天、今天和明天》,IT 之源 张恂
......2003年3月,著名的电子杂志《The Rational Edge》在IBM出巨资收购Rational之后的第一期发表了UML之父Ivar Jacobson博士撰写的《Use Cases——Yesterday, Today and Tomorrow》。这篇文章依次介绍了用例技术的起源、发展和演进过程,并且对大家在实践中困惑较多的用例关系、用例数量、用例与UML等问题作了深刻的阐释,同时提出了对扩展/包含用例的改进意见,最后还对用例未来的发展趋势作出了有趣的预测。这次由用例的发明人亲自撰文、现身说法讲述用例的历史,实在难得。我怀着如获至宝的心情反复研读了原文。现在把我整理、学习这篇文章的体会记录下来,在介绍Jacobson博士观点的同时加入我个人的分析和评述,以飨广大读者。......
从组织建模出发开发用例,Victor F.A. Santander 等,wnb
......面向对象的开发规范吸引了许多软件工程领域的支持者参加。目前其主要的成果之一是统一建模语言(UML),一种实现可视化建模的标准。用例图用于获取系统的功能需求。然而,系统开发往往基于一个重要的前提,组织过程已经建立完好。因此,对系统如何完成组织目标需要获取组织需求,以及为什么需要它,有哪些可能的选择,在包含的各个部分中存在何种联系等等。遗憾的是,UML及其它基于场景的技术难以胜任对组织需求进行建模的任务。需要其它的技术来完成该任务,I*技术恰好可以应用于对组织需求建模的工作。当然,组织需求必然与由用例表达的功能需求有关。本文提出了一些辅助从I*技术表达的组织模型出发,进行用例开发的需求工程方法原则。...
复杂软件驱动系统的UCM与UML,Daniel Amyot,殷建民
......UML包含了两类图之间的几种隐含的连接(例如,顺序图和协作图可以使用类图中定义的实体)。但UML并没有强调许多系统构件协同工作时(例如,跨越网络的事务处理)出现的大规模行为单元的首要的和紧密的描述方式。本文描述了一种被称为“用例映射图”(Use Case Map,UCM)的制图技术,作为一种以外在的、可视的方式联接行为与结构的手段。UCM是第一流的架构实体,它描述了捆绑到底层的、组织化的抽象构件结构的各种职能(responsibility)之间的因果关系。本文试图图解UCM怎样帮助在用例模型中的用例和分析设计模型中的其它行为图(顺序图、状态图、活动图)之间的概念缺口上搭建桥梁。UCM还提供了从行为图中的各种活动到结构图中的各种构件(以及对象)组织之间的鸟瞰图,这将使贯穿系统设计发展全过程的架构推导成为可能。...
把业务对象连接到关系数据库(下),Joseph W. Yoder、Ralph E. Johnson 等,Happy
......数据库值类型并不总是和对象类型直接对应,例如,一个布尔值也许在数据库存成T或者F,在Patient例子中,性别可以是一个属性,以一个名为Sex的类存储,男性实例有某些行为,而女性实例有另外不同的行为,在数据库中也许他们的值是M和F,当从数据库读取这个值,M需要转换成一个Sex类的男性实例,F需要转换成Sex类的女性实例。类型转换允许对象值和数据库值之间的转换。...
案例研究:设计一个基于Web的服务配送系统,Min Song、Il-Yeol Song,林善茂
......在这篇论文中,我们介绍了一个使用IBM的Net.Commerce设计一个基于Web的服务配送系统的案例研究,以及我们通过这个项目学习到的经验。采用UML符号来介绍设计规约,采用IDEFIX符号来介绍数据库方案。我们的设计规约包括架构,使用包图(package diagrams)描述系统构件,使用用例图描述系统功能,处理逻辑采用活动图(activity diagrams),数据库设计方面,我们介绍了详细的数据库设计,对设计和专门针对电子商务系统的用户个性化考虑进行了评论。...
业务规则说明,Windy J
......结构规则关注业务中的概念和概念之间的关系,是业务的静态部分,经常表现在实体关系图中。具体而言就是,通过事实(Fact)将术语(Terms)关联起来,形成对业务组成的结构描述。所以,一个事实(Fact)包括两个或两个以上的对象角色(Object Role),并表达了它们之间的关系,在这个fact中,每个语义上的对象角色(Object Role)都由术语来担任,例如事实“每个客户拥有一个或多个活期帐户”,在这里,客户和活期帐户是业务术语,客户担任拥有者(Owner)的角色,活期帐户担任被拥有者的角色。...
在大型过程公司中应用XP,James Grenning,袁峰
......本文描述了在一家使用传统正规过程的公司中应用了很多XP实践开发的一个项目。其中介绍了如何将XP建议给管理层、如何开始项目、怎样进展。并列举了实际执行过程中小组在最初6个月遇到的一些问题。...
【人件】
《人件》在计算机行业的实践
......谁在度假时还想到老板?Alan Hampton可能如此,因为雇主Intuit公司会为他的休假付费。雇员们在回报社会方面作出了重要的贡献:雇员们每年有32个小时的带薪志愿服务时间,去年社区服务的时间达到7,600小时。...

第25期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer25.pdf

【新闻】
Rational能保持中立吗?
用Select Scope Manager进行自动极限编程(XP)开发
Embarcadero宣布支持Microsoft Visual Studio .NET 2003 和.NET Framework
【方法】
使用用例组织需求―识别用例,think
......作者给用例起名叫Add,Browse,Delete,Modify等。然后在繁衍(扩展)出AddPerm….这也是正确的,不是吗?因为任何业务落实到数据这一层,都是增加、修改、删除、读取(CRUD)。但我们是不是应该从这个角度去识别用例呢?如果带着这副有色眼镜去看,世界上的一切都是CRUD。......
基于角色访问控制的UML表示,Michael E. Shin、Gail-Joon Ahn,UMLChina
......RBAC的概念静态模型如图2所示,包括类、类之间的关系和关系的势。基本的实体是用户、角色、权限、约束和会话类。角色和权限类分别特化出两种类别:使用者和管理者。这个特化依赖于用户的资历。RBAC模型的约束可以有很多种形式,依赖于应用系统。为了简化分析模型,我们静态模型中的约束只有三个:用户约束、权限约束、会话约束。另外,静态模型还有一个特殊的类session hour,当用户建立一个会话来激活他/她的角色时,该类被使用。这对表达基于会话的约束很有用。例如,一个组织可以要求用户只能在某些时间建立会话。为了强化这类约束,我们需要跟踪每个会话的会话时间。实体类的属性在图3中定义。...
关系数据库访问层 一种模式语言(关键模式),Wolfgang Keller、Jens Coldewey,Happy
......这个框架为那些将数据库以关系型方式使用的应用程序提供了一个数据库视图接口,其它的持久化框架和模式语言都是关于对象的持久化,例如对象-关系的访问层[Bro+96, Col+96, Kel+96a],它使用一个关系型数据库;还有对象访问层,它使用一个面向对象数据库[Col97]。图3显示了这些不同访问层的区别。...
以用途为中心的Web应用工程,Larry Constantine、Lucy Lockwood,金哲凡
......然而,Web开发在许多方面有其特殊性。尽管在本质上,任何可通过软件实现的功能都可以通过Web发布而在浏览器使用,但实际上几乎所有方面都与以往有所不同。由于缺乏标准和惯例,Web的开发和使用显得更加混乱而复杂。不同的浏览器、平台和连接的不一致性这几种因素加在一起,降低了我们对用户的实际所见和使用感受的控制能力。在一个工程里,多达70%的工作是为了让理应是标准的特性能够在某种浏览器(如NetScape)和某个平台上(如Apple Macintosh)正常工作,而以客户需求为本的工作加起来不到10%。Web程序设计风格的多样性使得局面更加混乱,一些被广泛接受的使用习惯也常常会被省略掉,比如将主页连接放在最左边的列,链接以蓝底文本的风格显示等。...
Rational统一过程对用户界面设计的支持,Chris Phillips、Elizabeth Kemp,herman
......Rational统一过程(RUP)是用例驱动的迭代软件工程过程。RUP中的用户界面设计包括用户界面建模与用户界面原型。本文涉及两种支持映象——可延展的用例表格和UI(用户界面)部件串——它们是连接用户界面建模与用户界面原型的桥梁。它们支持“事件流”故事板,用户界面元素群组和UML(统一建模语言)边界类定义,以及用户界面原型草图。...
【人件】
中国“人件”非正式调查
......你们的软件公司发生过这种事吗?--几年前,我与南加州一个大项目的项目经理交流各自的艰辛历程。他开始叙述将项目和疯狂的时间表压到他下属的身上产生的影响。一是发生的两宗离婚案,其中原因可以直接追溯到与他的人经常加班有关;再者就是一个员工的孩子吸毒,其中原因可能是由于在过去的一年里,孩子的父亲太忙,未能尽到做父亲的责任,最后,测试团队的负责人又神经崩溃。......

第26期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer26.pdf

【新闻】
Microsoft希望与OMG重修旧好
Rational, WebSphere和你
【方法】
UML相关工具一览(2003年6月版):A-H
......两年以前,《非程序员》第2期曾经刊登了“UML相关产品价格”一文。两年过去了,UML相关工具的发展又如何呢?以下总结了全世界的各种UML相关工具,都放上来供大家选择。工具的品种相对于两年前多了许多,总共有一百多种,所以我们以连载的方式刊登。按工具名称字母排序,本期刊登A-H。......
现代需求规约,Donald Firesmith,wnb
......当然,前述的需求规约任务的实现方法存在一些众所周知的问题。需求规约文档作为手工处理的结果,需要耗费大量的时间,完成该任务代价很高,并且在放入配置管理控制后很少对其进行维护和修改。这样产生的需求规约非常容易出错。一般来说,也难以保证其完整性和一致性,许多问题不清楚,阅读也非常困难,鲜有修改。采用此方法,想为不同的用户建立多个版本的需求规约太过昂贵,因此只能使用一个版本,即使是面对不同的使用者。这样的后果是:对某些使用者(如管理人员),该文档太细。而对另外的使用者(如独立测试人员),该文档又太粗。需求规约文档一般也没有包含关于需求的元数据(如调度信息、对开发者的任务分派、状态等等)。凡此种种,使得需求管理非常困难。...
安全模型的一种模式语言,Eduardo B. Fernandez 等,Happy
......用类和类的关联来表示授权规则的元素。类Subject描述一个主动实体,类ProtectionObject描述一个被请求的资源,一个授权规则由这两个类的关联来定义。一个关联类Right,包含访问许可的类型(读,写等),包含一个谓词,对授权持有者来说必须为true,还包含一个复制标志可以为true或false,表明这个权限是否可以转让。另外还有一个操作check_rights用来让主体或对象检查请求的合法性。图2展示了涉及到的元素。...
减少耦合,Martin Fowler,李巍
......我们需要对耦合进行控制,但如何进行呢?我们在任何地方都需要担心耦合吗,或者是否耦合在一些地方会比其它地方更为重要呢?哪些因素会使耦合变糟,而哪些则能够被容许呢?...
规则对象,Ali Arsanjani,Happy
......业务规则的变动往往比它们关联业务对象的其他部分要频繁,这些规则通常在一个业务对象的规则方法中实现,并且它们也引用该业务对象周围相关的其他业务对象,这就建立了一个隐含的网络,它们的依赖关系日益增加并难以维护。这种情况下,改变一条业务规则会影响一系列依赖该规则的对象,特别是当实现一条规则的代码在分散类的若干方法中,甚至是若干协作类的方法中,平均信息量就将大大增加。缺少集中控制导致了波纹效应,并且改变一条规则的if-else语句元素还会产生副作用。...
基于设计模式的网站设计,Francisco Montero 等,lanmobj
......本文继续收集网站设计方面的模式。传统意义上,网站主要是作为信息交换的媒介,因此绝大多数网站被设计得像书一样,允许人们从一个页面跳到另一个页面。在开发网站时,应该考虑可用性准则[Nie00]。本文中这组模式就是基于可用性准则的。...
《有效用例模式》中译本样章(草稿),Steve Adolph、Paul Bramble,车立红
......在探讨重构面向对象软件的书籍《重构》中,Martin Fowler(1999)把软件可能要求重构的标记叫做“坏气味(bad smell,一种不好的代码形式)”。在用例中应该一直注意的一个“坏气味”是用例过长。一个好用例的主成功场景通常为3~9步。包含9个以上步骤的主成功场景可能说明用例或者有多个目标,或者包含较低级的细节。在任何一种情况下,您都应该RedistributeTheWealth(8.1节),合理地将较大的用例划分为较小的、内聚的用例。...
【人件】
烧毁这本书,别让员工看到―《人件》评论集,柳林
......汇总了以前发表过的《人件》 文章...

第27期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer27.pdf

【新闻】
UML2.0正式通过
QuickUML 1.1 for Windows、Linux上市
OMG推荐模型驱动架构FastStart计划
Borland向Eclipse组织推荐敏捷设计解决方案
Flywheel:前进的马达在轰鸣
【方法】
UML相关工具一览(续):I-O
......关注“用手建模”的UML建模工具,强调创造性和弹性。支持电子白板,支持在桌面、可移动物体上建模。...顺序图双向工程 ......针对Delphi的工具,支持构件和模式,支持某些“自适应”的方法学。和Delphi IDE自然结合。
UML状态图指南,Scott W. Ambler,梁涛
......尽管上述描述状态图的方法使用良好,但是所产生的状态图会变得非常复杂。想象一下在图2中,“教授中”(Being Taught)这个状态同样有子状态的话,状态图会变成怎样的情况。一种可选的方法是对非常复杂实体的状态图分级。例如,图3是顶级视图,而图1是种更细节化的视图。...
误用例:带敌对意图的用例,Ian Alexander,林善茂
......人类甚至在冰河时代的篝火旁,争论捕获一头毛犀牛的危险性时,就已经开始分析不利的情况:如果在它中矛前转身向我们冲过来怎么办?最近更多的情况是:如果黑客们发动了拒绝服务攻击(DoS)怎么办?现代系统工程师能够通过使用误用例(misuse case)——用例的负面形式——来证明和分析这些情况。一个误用例是一个简单的用例,从一个带有敌视意图的角色的视角来看系统的设计。对于用例来说,误用例有许多非常有意思和有帮助的应用和影响。...
RUP的反模式,Julia Filho,沙萌、于宏光
......“我们目前的迭代是需求,下一次迭代才是设计”--对那些一直遵循严格的瀑布开发过程的人们而言,瀑布RUP是最容易犯的错误之一。瀑布RUP是反模式的原因很简单:它不能帮助降低风险程度,而降低风险是基本的RUP原则之一。RUP迭代式开发要求每次迭代应该是一个应用程序的“小型发布版”。每次迭代有小型的需求,设计,开发和测试环节,并且交出应用程序的一个可运行部分。使用这种方式,需求、设计、实施和测试的问题在每一次迭代中都得到“冲刷”,要求问题越早解决越好(问题越早解决其消耗的代价就越小)。...
领域建模,Paul Oldfield,陈明勇
......OO系统保持灵活性的能力在于以不同的方式使用已有对象,因此如果你想以不同的方式使用系统,你所要做的就是让系统以不同的方式使用系统中的对象,然而,这依赖于一个假定,对象可以以不同的方式使用,如果责任分配合理,对象表达了正确的概念,它就可以以不同的方式使用,如果责任分配不合理,那么改变系统对象的使用方式往往需要改变系统内核。...
角色建模——实用的系列分析模式,Francis G. Mossé,samying
......在进行面向对象分析时,我们经常遇到与角色有关的问题。角色是与某些概念(或类)所在的上下文有关的一个概念(或类)。举例来说,“公司”可能是某些特殊“产品”的“供应者”。“供应者”是一个角色。通过选择以下介绍的五个角色模式,所有的角色问题都能很容易地被解决。这五个模式是:继承角色、关联角色、角色类、泛化关系角色类、关联类角色。每个角色模式都综合了它对能力、灵活性和复杂性方面的考虑。这些模式一起,提供了对所有角色问题的完整解决办法。...
建立稳定分析模式的模式语言,Haitham Hamza 等,wnb
......对每个BO都将其对应的IO表示出来。例如,HotMail是HOST的可能的物理表示,但是,从一般性考虑,该IO在任何时候都可以发生变化以表示任何可能出现的HOSTS,而且不会影响模型的核心。在该示例中,两个模式中所有的连接都仅建立在IO层。...
【人件】
亮出怀疑的尖刀,Peopleware
......一个普普通通的开发人员能做什么?首先能做的只有怀疑,用怀疑的尖刀一次又一次轻轻地刺激梦魇中的Neo(就象《人件》26章中的“唤醒霍尔加”)。怀疑加班,怀疑进度表,怀疑口号,怀疑开会,怀疑老板的说话,怀疑家具警察,怀疑工作环境...仅仅是怀疑而已,但,仅这一点就已经是致命的。...
信息时代的技术阅读,刘天北
......技术行业里,大师巨匠大多自信、安恬,温和有趣,水平低得多的技术人员反而常常自矜于一得之见,对旁人摆起面孔。相应地,很多教材名作也都面目有趣,语言温醇,甚至不少段落漂亮得都可以拿去做英语范文。而你很难从大多数教程作者那里指望考究的文风,他们的典型句式是:“读完下面的10页,你将学会a…b…”——要是再加上一个电话号码,这就能构成不错的电视购物广告。...

第28期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer28.pdf

【新闻】
SteelTrace架起需求和UML之间的桥梁
Gentleware双喜临门
JRules4.5增加图形表示规则新功能
【方法】
UML相关工具一览(2003年8月版):O-R
......UML/SDL实时开发,产生的代码可以在CHORUS, Nucleus, OSE, OSEK, pSOS+, VRTXsa?, VxWorks, WIN32等实时操作系统平台运行。...
点评独孤木专栏《漫谈UML OOAD and RUP》,IT之源 张恂
......有些人很奇怪,大概自我感觉很好,总是恐惧、厌恶陌生的东西吧,所以总喜欢树立一些假靶子,企图用一打假命题来证明OO是如何的失败,从而为内心排斥OO、拒绝学习OO寻找暂时的安全感。...
用例/OOAD随笔之一,think
......好像还不错是不是?要是我们问一问客户,为什么要做一个系统?听一听客户――一家××代理商怎么说,“××的运费在顾客购买总费用中占相当比例,如果能想办法降低运费,顾客肯定非常乐意找我们买××...
集成Rational工具套件编写需求文档—Step by Step,Kirsten Denney,michael
......本白皮书说明了这些缺点可以通过集成使用Rational工具套件的不同组件来克服。它还说明了通过提供图形化的能力和对需求工件的适当管理,这些工具可以进一步增强需求工程。最后,这一白皮书也对RUP中提供的用来改进和扩张需求工程的工作流和最后交付提出了建议性的修改。...
用户界面设计背后的理论,Mauro Marinilli,Sha Meng
......设计专业的用户界面不仅仅是有好的图形艺术家和好点子的问题。不幸的是,人们只是为了产品而创建用户界面,完全没有意识到背后的基本原理和理论。紧迫的计划、错误的观念(像“可用性是现在我们不能提供的额外的东西”)和缺乏专业性造成我们周围充满了低劣产品。本文开始可能会有一点抽象,但它的主要意图是让大家了解一些仅限于学术界和专业领域的主题。我们不去探讨诸多UI设计方法的细节,因为从我个人的经验,我发现为建立有效的用户界面“所做的事情”往往更吸引人们,而不是掌握一些简单的概念,在UI设计的过程中受到启发。...
一种请求及分配有限资源的分析模式,Fei Dai、Eduardo B. Fernandez,wnb
......在许多情况中,可用资源的数量远远小于请求的数量。例如,流行体育竞赛的门票在比赛开始前就已经全部告罄;公司中重要的职务往往有多个角逐者。在中国,原始股票由于其价格低廉往往首次提供就全部卖出。从系统的观点来看,这些资源都是不可重用资源。不存在资源的返回和重新分配的问题。与之相对应的是可重用资源,如交通工具、宾馆房间、飞机座位,这些可重用资源在使用后返回并可在未来重新分配使用。...
【人件】
中国“人件”的声音,UMLChina
......原先我总是在身边放一把空椅子,谁到我这里都可以坐下来聊聊天,很多工作的问题就在交谈中解决了,还可以随时了解别人的工作情况。结果某一天,一个家具警察(我们的研发秘书)过来把空椅子拖走了——她并不是要用这把椅子,只是不喜欢看我“乱放”。结果那两天,没人陪我聊天了,我解决问题的速度明显下降,而且团队的笑声也减少了。...
建立完美公司的模式,Linda Rising 等,funwave
......Enron和WorldCom公司丑闻的曝光,让我们有机会看到一种困扰人的领导模式和它所导致的后果,在这样的模式下,以希望、诚信和完美为基础的完整意义的一个公司是见不到的,而惟利是图的公司却处处可见。我们深信,要想赢利, 你必须绝对信得过自己的产品或服务,并且关爱你的顾客或客户。这不是刻板的教条,这是活生生的商业准则。一个真切关注自己产品和产品使用者的公司是能够创造奇迹的。Tom Peters讲过一个有关麦当劳创始人Ray Kroc的故事:有人问Ray Kroc“你成功的秘诀是什么?”,他答道, “你得有鉴赏汉堡包美丽的能力”。看到这里,你可能先是一笑,稍加思索之后,你得承认他的话很有道理。...

第29期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer29.pdf

【新闻】
《有效用例模式》中译本发行
《人月神话》中译本修订版即将出版
Borland发布Together Edition for Microsoft Visual Studio .Net
基于模型的开发领域,微软从零开始
Rational为IBM的按需开发添上双翼
Rational为由设计直接生成代码努力
【方法】
UML相关工具一览:S-T
......可以和ERWin, Caliber-RM协同工作,Rose输入输出。...支持UML2.0,支持MDA。...
重构:当前研究及未来趋势,Tom Mens,wnb
......尽管在重构领域相当多的工作已经实现,从实践及规范的角度来看,仍然有许多问题仍然需要关注并解决。本节将对这些问题进行总结,并给出部分的解决办法。问题的组织方式分为基础部分和研究问题,实践部分和工具问题等两个主要的分类。...
使RUP敏捷,Michael Hirsch,Michael Zhou
......2000-6:客户没有提供这个版本的反馈。事实上,客户甚至没有安装该软件。许多需求仍然不清晰。客户没有时间与我们一起工作以澄清需求。来自客户的关键人员没有空,因为他们被分配到了其他紧急的项目中,大部分时间被他们遍布全球的客户所占用。我们从客户的组织的不同的人那里收到了互相矛盾的信息。尽管如此,我们仍然冒着遗漏信息的风险继续开发和工作。...
或许我们不应该“写”需求,David Gelperin,安丰亮
......对于我们过去的较小的项目,使用文档管理需求效果很好,通过二、三十页纸需求能够被详细说明。我们在本单位或者网上可以获得很多模板,这些模板为需求文档的不同信息提供了编辑样式,然而,文档的效力却无法准确衡量。大型文档检查和使用都是有困难的。因为文档的组织形式是固定的,作者必须选择简单的最好的方法组织信息。不幸的是,对于大量的信息,没有简单的、最好的方法甚至是较好的方法。...
UML驱动的基于TTA协议的处理器设计,Johan Lilius、Dragos Truscan,梁涛 译
......在本文中,对于TTA处理器的协议处理应用的开发,尤其是TACO处理器,我们实验了一种协议处理设计的方法。因为我们是在讨论可配置的处理器架构,我们对于反应了平台的硬件配置的应用的各个重要的方面的学习必须给出一些启发。通过建议所需资源的类型和数量,这样的信息被用来开发处理器的架构。在这样的设计过程中,UML扮演了一个重要的角色。我们使用UML作为一种描述性的语言,研究UML的行为图(Behavioral diagram)的语义来为我们的模型获得一个良好定义的可执行的语义。而且,近来在代码生成(Code-generation)方面的研究工作使得直接从UML的最后规约(Specification)生成TACO的微代码(Micro-code)成为可能。......
一种基于Web的多源数据采集应用开发模式语言,Lei Zhen、Guangzhen Shao,刘辉 译
......价值链之间的整合和信息共享对于企业优化整个价值链以及在不同层次上建立快速和有价值的决策非常重要。考虑一下下面的设想:当一个提炼厂的主管打开浏览器,决策支持系统的主要页面显示在他面前。在页面中间,显示生产过程的模拟,生产过程的主要部分都被显示,相关的部分用颜色标注,比如用红色表示警告;在页面左边,它可以查看企业的重要统计数据;在页面右边,它可以查看石油和产品的价格。如果他想进一步查看详细的数据,他可以点击相应的超链接进入相关的页面。...
【人件】
国内中文书对《人月神话》的引用精选(一),UMLChina
......Fred Brooks说,“要计划丢弃某些东西”。1988年,我把Ruby卖给Bill Gates,当时只是一个原型...接下来要把它和Bill的QuickBasic结合,成为Visual Basic。我做的第一件事就是抛弃Ruby的原型,除智慧和经验外,一切从零开始。...

第30期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer30.pdf

【新闻】
Borland将UML引入.NET世界
Borland开始给予C#平等对待
Duvessa发布基于用例的估算工具
Gentleware领跑UML2.0建模工具
【访谈】
Rebecca Wirfs-Brock访谈,ObjectbyDesign,李巍
......你问了一个很好的问题:为什么UML工具没有对CRC卡提供任何支持呢?我更愿意把它说成「为什么UML工具没有对表达不同抽象级别上模型元素的行为和特征提供良好的支持」。我想这是因为大多数工具(尤其是那些支持双向工程(roundtrip engineering)的工具)专注于提供类的一个实现级别上的视图。...
【方法】
UML相关工具一览:U-X
......强力的UML-数据库双向工程。...支持用例文档,文本分析。...有VS.NET2002-2003插件。支持GoF模式。...
基于职责建模(上),Alistair Cockburn,李巍
......职责(Responsibilities)是陈述系统设计基本原理的一种方式。整个系统的职责鉴别和分配是业务模型和软件的主要设计活动。作为一个主要的活动,职责鉴别和分配会相互密切追随并伴随着既有组件的重用。在面向对象的建模和设计中,职责的定义和分配是同时进行的,与其他的方法不同,例如结构分析(structured analysis),它们不需要在定义时进行分配。...
防火墙的模式语言,Eduardo B. Fernandez 等,yoochen
......动态特性...我们用序列图描述基本防火墙模式的动态特性,序列图对应于两个基本用例。...
检测网站检索的可用性,Jennifer English,沙萌
......另一个常常被提及的检索用户界面的不足是它们不能支持中间级的检索。如象棋游戏,检索过程有开局,中盘,末盘。开局时的选择是至关重要、反复研究的,对整盘棋都有深远影响。末盘棋则要根据棋子及其所在的位置精心设计把对方将死。中盘更难描述,更需要灵活地、有机地把战术和策略结合起来。...
【人件】
软件开发 以人为本,乐林峰
......几个篮球场那么大的一个房间,以前据说是做库房用的。每四张办公桌被放到一个格子里...
《人月神话》中译本修订版对每章前引语的修订
......原译:岸上的船儿,如同海上的灯塔,无法移动。--修改:前车之履,后车之鉴。...
《人月神话》国内评论集之二,UMLChina
......我女朋友是做外贸的,一天晚上她一直捧着我书架上的一本书在看,很投入的样子,后来她叫住我很认真的说:“这本书写的很好,我明天可以带到办公室接着看么?”那本书是《人月神话》。...

第31期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer31.pdf

【新闻】
Flashline加入OMG
OMG的MDA FastStart计划进展迅速
SAP和IDS Scheer达成合作
Intelliun使Executable UML成为现实
Borland的 企业核心对象“ECO”技术加快软件快速开发的进程
简化应用集成的工具
【访谈】
Alistair Cockburn与UMLChina交流会,think
......而象我的妻子那样做面包,就和那两个层次不一样了,她只需要凭她的手感,抓一些面粉,倒一些水,弄点鸡蛋在里面揉揉就能做出她想要的面包,这就是‘离’的阶段。到了她那个阶段,她既知道如何根据处方来做,也知道不看处方怎么做。...
【方法】
UML中文FAQ,张恂
......一直很难找到中文的、适合国人看的UMLFAQ,而英文的UMLFAQ 往往散落于各处不易收集和消化,导致很多看似简单却很基本、很关键的问题在网络论坛、BBS 上被反复地提出,既浪费了提问者、解答者不少的时间和精力,也给大家学习总结、进一步提高带来了困难。于是,结合自己的所学所想试着编写了一个UML中文FAQ 供各位参考。...
基于职责建模(下),Alistair Cockburn,李巍
......火车发动机(Train engines)挂着多节车厢和一节守车(caboose)。确定是发动机还是守车具有「连接发动机到守车」的职责则是一个难点。解决方案:有一些抽象被遗漏了,其中有关于火车结构(configuration)的,有关于火车的。系统很可能想要管理发动机,车厢和守车的结构,并且想要随时能够变化。...
用例随笔,think
......部门工作人员给基础信息交换系统发出命令后,基础信息交换系统就连通部门业务系统,把业务数据搬到基础信息交换系统内。确实是一个命令系统去“采集数据”的过程。但是我们要回过头来想一想:用例是“执行者用系统来干什么”。部门工作人员会怎么看待这个过程?他们会说,这是在“提供数据”,把数据提供出去,作为比对、交换的依据。...
更多的操作系统访问控制模式,Eduardo B. Fernandez、John C. Sinibaldi,droplet
......在计算环境中,进程会在运行过程中创建对象。有些对象在程序初始化时创建,而其他对象在进程运行时动态创建。进程对这些对象的访问权限需要在进程创建时就指定,否则进程可能会误用它们。...
远程认证者和授权者模式,Eduardo B. Fernandez、Reghu Warrier,杨德仁
......一个跨国公司在不同国家如美国和巴西有许多雇员。支持美国职员的认证和授权信息要保存在美国的服务器中,支持巴西职员的信息要保存在巴西的服务器中。现在假定一个美国职员旅行到巴西,需要访问巴西数据库服务器中的数据。有两种方法可以实现...
帐务模式,Windy J
......我们打电话,上网,然后在月底收到一张账单,上面写着这些活动产生的费用,类似的还有水电费,煤气费,有线电视服务费,购物账单等等等等,总之,在某个时候发生了一些事件,打了一个电话,上了一次网……,在这些事件里我们付出或者得到了某些东西(例如劳动,商品,服务等),然后这些付出或得到的东西产生了一些不同程度的费用条目...
《企业应用架构模式》评论,李巍
......这是我所发现的关于J2EE和.Net模式的最佳图书。我想它注定会成为经典。我发现关于「何时进行分布式,Unit Of Work,Domain Model和Data Mapper模式」的论述极为有用。它改变了我考虑企业应用的方式。...
【人件】
国内中文书对《人月神话》的引用精选(二),UMLChina
......Grady Booch:一颗濒于坍塌的行将死亡的恒星,一个正在识字中的小孩,一群对病毒发起攻击的白细胞:这些只不过是物质世界中少数涉及巨大复杂性的对象。软件也可能会牵扯到很复杂的元素,但这里所看到的复杂性却是根本不同的类型。正如Brooks指出的“爱因斯坦认为肯定有对自然的更简单的解释,因为上帝并不是反复无常和独断专行的,但这样的信念并不能安慰软件工程师。他所要对付的复杂性绝大多数都是任意性的”...

第32期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer32.pdf

【新闻】
INTELLIUN广邀专家一起探讨EXECUTABLE UML的未来
微软Whitehorse modeler的背后
业界领先的美国电信设备制造商选择Telelogic
IBM如何对待Rational工具
Wizdom Systems发布ProcessWorks! V.6支持UML
Scott W. Ambler谈敏捷的真相
【访谈】
敏捷方法争论,Ryan Chen
......Barry Boehm:嗯,Tom,我很高兴把你对“敏捷方法争论”的清晰描述用克劳斯威茨的对位法来做个比喻,就如军事行动中的装甲和机动性。不幸的, 我们在软件开发和军事行动中所看到的都是这么一种趋势:钟摆总是在两个极端之间摆动。然而在大多数情况下,我们需要在装甲和纪律、机动和活泼之间获得一个平衡。事实上,我要说敏捷和重型方法这两个阵营,它们的领导人的观点,其实都在各种各样的可靠的中间地带,只是那些狂热的追随者们过度地分割了“纪律”和“活泼”。 DeMarco:我很同意。幸运的是我们领域的实践者比学术的提倡者更懂得寻找有意义的中间地带。...
【方法】
模型驱动架构MDA介绍,袁峰
......模型驱动架构(MDA,Model Driven Architecture)是国际对象管理集团OMG目前力推的软件开发的新框架,它在模型定义、软件开发过程等领域必将产生深远的影响。本文从其定义、思想的来源、发展历史等方面对其进行了较为深入的介绍。 ...
使用模型驱动架构方法在J2EE平台上进行模型驱动开发,MIDDLEWARE,陈龙
......这一案例研究的目的就是验证或反驳关于基于MDA的开发工具可以提高软件开发生产效率的声明。两个团队开发同样的J2EE PetStore应用,一个团队使用了基于MDA的开发工具,而另一个团队使用传统的企业级集成开发环境(IDE)以代码为中心(code-centric)的开发方式开发。...
领会统一过程,Sinan Si Alhir,sunyanjia
......聚焦于“统一过程的精髓”而不是统一过程的形式。统一过程既不松散混乱,也不死板迟钝,而是具有很强的灵活性,动态性。统一过程仅仅是说明或建议开发人员应该如何决定和执行。如果无法平衡其中的关系,则表明过分的关注“统一过程的形式”,而不是“精髓”。这一点是很多过程工程师运用统一过程的通病,也就是说,他们无法平衡“形式”与“精髓”。...
扩展UML活动图实现生产系统中的工作流建模,Ricardo M. Bastos、Duncan Dubugras、A. Ruiz,Micheal.fly
......本文提出了一个使用工作流概念在生产系统中描述业务流程的方法。在此,我们对UML的活动图进行了扩展,提出了工作流活动图(Workflow Activity Diagram-WAD)的概念,它采用了C-WF模型概念。C-Wf模型描述了业务流程中涉及的结构性的和功能性的企业对象,如企业活动、人力资源、机器资源等等。WAD描述了一个工作流模型,该模型用来标识该工作流执行所需要的活动和资源,并定义了它们之间的关系和次序。通过UML用例的深入使用,我们的方法进一步增强了UML在业务建模方面的可用性。...
糟糕界面集锦(补遗),iarchitect,雷立辉
......微软似乎想将每一个打过的补丁的历史纪录版本号用分号分开显示在关于对话框里。也许是因为这是第五个开发版本,也许开发者没想到竟然有这么多的补丁要打所以没有预留足够的空间来显示补丁的信息。天哪! 那个对话框右下角灰色的东西是什么?噢,那是“OK”按钮。或许是什么原因吧,开发者将补丁的信息宽度和按钮的位置联系了起来,所以就变成那样了。如果Amit再多打一个补丁的话,他将和“OK”做最后的吻别了。 ......
【人件】
《人件》续篇--《人件集》样章,Larry L. Constantine,谢超
......但是,那种认为为开发者提供更安静、更宽松的办公空间就可以提高软件开发效率的观点也是不正确的,办公室布局与开发效率之间的关系远远要比这句话复杂的多。首先,从社会科学研究的角度来看,“原因-结果”之间的关系是很复杂的,很难说清哪个是因,哪个是果。高效的程序员有可能是在安静、宽松的办公环境下办公,但也可以说,正是由于他们的高效开发使得办公环境显得安静、宽松。...

第33期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer33.pdf

【新闻】
《财富》把《人月神话》列为CEO必读技术书籍之首
IDS Scheer North America发布ARIS UML Designer
IBM收购Rational一年总结
Grady Booch在IBM
Grady Booch加入Northface大学顾问委员会
【访谈】
Scott Ambler访谈,Clay Shannon,李巍
......这很奇怪。我发现“反敏捷(anti-agile)”者认为敏捷学家(agilist)是在宣扬「敏捷方法就是银弹」的言论,因此这些方法常常会被认定是一时兴起而被忽略。事实上就我所知,在敏捷社区内没有人声称他们已有魔法般的解决方案,并且时不时地叫嚷说「就像我这样地使用AM」。...
【方法】
CASE工具对用例的支持,Huseyin Angay,think
......用例建模长期以来被看作次于对象建模的二等公民,部分原因是需求分析工作比较单调,没有设计和实现那么有意思;另外的原因就是CASE工具支持不够,导致它没有对象建模那么流行。对象建模在现在之所以如此流行,过去几十年支持对象建模的工具持续改进是一个主要的原因。 ......
极限建模与可执行模型,Stephen J. Mellor,Ryan Chen
......会议一开始,我介绍自己为“间谍”,因为我的兴趣是在可执行模型:模型可以非常精确和详细,足以去执行。这样,那种认为代码是唯一感兴趣的产品、模型是多余的观点就会很奇怪了。当然,我们仍旧将把我们的注意力放在最终产品上,但是这个最终产品完全可以是一个可执行模型。...
适应性的实时分布嵌入式中间件的新兴模式,Joseph P. Loyall,Li Haiming
......假设有一架负责执行预先计划的任务的战斗机,和一架协同命令和控制(C2)飞机,主要用于当战斗机接近目标时不断更新战斗机的任务参数。特别地,C2可能想要把战斗机指引向一个新的更危险的目标或者警告战斗机在到达目标的途中有威胁,如图1所示。无论如何,这项从C2到战斗机的合作式的任务重计划必须处理资源的限制和争用,因为这两架飞机之间的无线网络的带宽是有限的,而飞机上的处理器同时还服务于其它可能的关键任务。由于任务重计划和有关数据的动态自然属性,通过静态地预分配足够的资源来支持这种合作是困难甚至是不可能的。如果系统依赖于资源总是可获得的和可预测的,它可能不能及时交换重要的任务计划信息并以此采取行动。...
一半是欣喜,一半是迷惑--XDE for .Net体验,Windy J
......安装的时候软件名是“Rational XDE Plus .net (Evaluation)”,看起来还是无可厚非的,但是,当我想到Rational网站上找一些相关介绍的时候,居然怎么也找不到这个软件,在琢磨了好大一会之后,才发现它的大名原来是“IBM Rational Rose XDE Developer”(.net版),与之遥相呼应的竟然是IBM Rational Rose XDE Modeler,Rose乎?XDE乎?IBM乎?Rational乎?Developer乎?Modeler乎?真不知道是厂家想把我们弄得晕头转向呢,还是他们自己已经被他们的产品弄得晕头转向了...
值得看的中译本UML相关书籍(截止至2004年1月),UMLChina
......现在,引进翻译的UML相关的书籍越来越多,在不可能一一阅读的情况下,开发人员面临着一个问题:哪些书能真正带来帮助?UMLChina的专家总结了2004年1月之前出版的所有UML相关书籍,根据自己的认识,“过滤”出以下优秀书单,按出版日期排序。不作任何评点,仅为一家之言,供大家参考。最后要说的是,就算读10000本书,如果没有将其中的知识用于你自己的实践,对你来说也是无用的。 ......
PEAA中译本精选(草稿),Martin Fowler,王怀民
......再接下来的问题是由“业务逻辑”带来的。我认为“业务逻辑”这个词儿很滑稽,因为很难再找出什么东西比“业务逻辑”更加不合逻辑。当我们构建一个操作系统时,总是尽可能地使得系统中的各种事物符合逻辑。而业务逻辑生来就是那样的,没有相当的政治力量不要想改变它,你所能做的只有照着它说的做。你必须面对很多奇怪的条件,而且这些条件相互作用的方式也非常怪异。这种情况很容易出现,比如,某个销售人员为了签下其客户几十万的一张单,可能会在商务谈判中与对方达成协议,将该项目的年终到帐时间推迟两天,因为这样才能够与该客户的帐务周期相吻合。成千上万的这类“一次性事件”最终导致了复杂的业务“逻辑”(其实不符合逻辑),也给商业软件开发带来了很大困难。 ......
【人件】
需求工程师的素质要求,Think
......目前,很多公司里,担任需求工程师角色的开发人员,同时也会承担着设计和编码的任务。实际上,这不是一种好的做法。需求工程师的任务是出题,需要把各种碎片捏合成题目(或者说,用例),需要强的综合能力;设计员程序员的任务是解题,需要强的分解能力。这两种能力方向是相反的,这也是程序员经常会“误用”用例的原因。一个好的程序员并不能自动成为好的需求工程师。...

第34期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer34.pdf

【新闻】
David S. Frankel“应用MDA”讲座举行
OMG Anaheim会议消息:四个新的小组成立;架构委员会选举
china-pub2003总结:UMLChina参与图书继续火爆
Gentleware在OOP展会上展示其首个集成UML2.0的工具
Compuware引导MDA主流
LogicLibrary书写Logidex的新篇章
Martin Fowler关于MDA的见解
Metamill软件公司和Innovative及Datraverse B.V.签订经销协议
【访谈】
Grady Booch访谈
......我的想法是把它的架构文档化,因此我们可以描述它,可以做一些比较性的研究。我正在考虑例如Word的架构,纽约交易所交易系统的架构,Prism 1000的架构,Prism 1000系统用于对人类DNA进行编码。因此这个想法是去真正得到某个软件系统的光谱,并提供如何建立这些架构的知识体。...
【方法】
个案研究:聊天室UML模型中的一致性问题,Thomas Huining Feng、Hans Vangheluwe,车皓阳
......本文从初始需求开始构建聊天室模型,以及对个案进行研究。在不同的开发阶段,分别要用到UML类图、时序图和状态图。这样,难免需要确定一致性问题,现在已经提出了许多仿真和方法,用来确保模型各个方面的一致性。我们关注内部一致性,即给定模型内部制品之间的一致性问题。 ......
使用基于组件开发和Web技术来支持分布式数据管理系统,M. BRAIN BLAKE、GAIL HAMILTON、JEFFREY HOYT,micheal
......当某架飞机从终点返航、离开跑道、降落到目的地跑道、最后进入航空港时,这一数据集记录了全部的“Out/Off/On/In”时间。图11就显示了一个与CRS分布式数据管理系统的观念相一致的查询窗体。...
一个课程管理分析模式,Xiaohong Yuan,Eduardo B. Fernandez
......本文讨论一个课程管理的分析模式,该模式描述了诸如学生注册、增加和取消课程、成绩管理等事件。模式可以推广到相似的应用中。本文包括两个相似的模式:课程注册模式和成绩管理模式,这两个模式都有各自的参考价值,适用于不同的场合。...
UML建模工具比较:Enterprise Architect和Rational Rose,Jie Zhao、Dunstan Thomas Consulting,ludingping
......在写本文时,EA企业版(最高版本支持SQL后台)的费用是$179.00(£111.58) 而Rational Rose企业版的费用是$5024(£3140),一天整套开发包(Rational Developer Suite)的费用是$8976(£5610)。...
SAIP和PEAA的对照与比较,Ramona,李巍
......一亿美金,五年的合同。Software Architecture in Practice(SAIP)和Patterns of Enterprise Application Architecture(PEAA)中会对这许多问题做出回答。尽管对于「如何创建架构」SAIP和PEAA有着不同的观点,但它们都有助于阐述架构创建的方式,以及强调其对于系统如此重要的原因。 ...
相识何必曾相逢,Think
......直到有一天,我在马桶上看Dean Leffingwell的书,这位Requisite公司的CEO、RequisitePro【1】的开发者在他的书中说,RequisitePro的思想起源于Donald Gause和Jerry Weinberg的著作,尤其是《探索需求:设计之前的质量》 ...
《探索需求》中译本(草稿)节选,Donald C. Gause、Gerald Weinberg,章柏幸
......另一个在问题描述中的危险词语是“组”,它暗示这些人将会有相互影响,但不知何故,这里也不清楚其究竟。表演“费加罗的婚礼”的演员们之间的相互影响与在费加罗咖啡馆喝咖啡的一群人之间的关系截然不同。为某个小组设计的建筑物将会和为其他人设计的完全不同。甚至是术语“建筑物”也带来了一大堆的含混性 ......

第35期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer35.pdf

【新闻】
Gerald Weinberg “探索需求”讲座举行
Scott W. Ambler“应用UML敏捷建模”讲座举行
Ian Graham“对象技术”讲座举行
MagicDraw UML工具增强报表功能
视频游戏公司采用SmartDraw进行标准化
Gorilla Logic发布Gorilla ExecutionEngine预览版本
I-Logix: 模型驱动开发理应有测试的一席之地
【访谈】
我思Argo在,Alan O' Callaghan,车皓阳
......近来,在贸易出版物的头版和专业会议当中,敏捷过程都非常火。它的基本思想是,软件开发过程自身应该灵活、适应、轻量。它与Jim Highsmith和Kent Beck(XP运动的领导者)等几个曝光率甚高的美国人有着莫大的关系。但是欧洲拥有自己的专家,敏捷过程并不象有些人想得那样新颖。我与Martine Devos[1]邂逅,她...
【方法】
当企业计算遭遇嵌入式系统,Micheal Kircher、Christa Schwanninger,车皓阳
......嵌入式设备中软件使用得越来越多,系统之间建立了连接,对在小型设备中增加功能的要求也一直在增长,这些都迫使供应商想尽办法来缩短开发周期。对于嵌入式系统来说,只有实现了复用,软件需求才能满足 ......
探索《探索需求》,Think
......你的工具好,恭喜你,同时也要提醒你,新层次的挑战来了。以前可以抱怨工具的理由如今已经不存在,你需要更加集中精力去面对真正的问题。――这也就是Weinberg说的“你的CASE工具越好,你就越是需要本书所讲的工具。”...
《UML风格》中译本节选,Scott W. Ambler,王少锋
......它不讲概念,它假设您已经懂了概念。它简单地告诉您“在递归关联上指明角色名”,不告诉您什么叫“递归”、“关联”和“角色”。这方面的知识,可以去看“UML Distilled”。
糟糕界面集锦—界面设计考虑要点,pixelcentric,雷立辉
......典型的举例来自程序TextEdit的图标,这个图标包含有一段文字。尽管少量细节丢失了,这个图标的文字块依然在48x48大小的图标中依然存在。不过,图标上页面上的横格细线看不见了。即使在16x16大小(图4.A最右的图标)图标尺寸最小的情况下这个文字块还是有一个墨色的轮廓依然保留,而最基本的元素信纸及笔依然可以辨认。...
批判索尼爱立信的手机设计,dozer
......通话清单中,如果是同一个号码多次拨打,例如一个未接来电拨打了四次,却只显示了最后一次拨打时间,这样的做法隐藏了重要的信息。因为用户有可能需要了解每次拨打的具体时间。一般而言,最新拨入的电话号码应该显示在通话清单的最上面。但是......
为什么伟大的技术不能制造出伟大的产品?,Scott Berkun,梁劲
......增加产品价值的最佳方式是增加它的功能却没有增加复杂性。当你想增加一个新的feature,是否有办法增加了它却没有为之增加一个用户界面?它能被可靠地自动化吗?或者,为了包含新的功能,是否可以通过新的、改进过的方式替代旧的,来调整、甚至去掉原先的功能?想一下汽车工业是怎么做的......
用UML进行超媒体建模,Peter Dolog、Maria Bielikova,车皓阳
......为了进行外观建模,在导航模型中我们定义了状态机,它是通过合并多余(可选的或并行的)状态而生成的,它表示不同形式的外观信息。规则根据用户知识水平表示适应性,规则由监视哨(guards)、条件、行为状态和转换来建模。...

第36期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer36.pdf

【新闻】
I-Logix Rhapsody 2004生成C代码
UML2意味着“模型驱动”的架构
IBM将让所有Rational工具基于Eclipse
微软的模型观点与众不同
Telelogic升级DOORS套件以改进定义软件需求的过程
Telelogic进军普通应用开发
【访谈】
UMLChina访谈温伯格“探索需求”
......最常见的例子就是我们发现某个人说,“我们需要一个快速的系统。”看,我们不知道“快”意味着什么。这个“快”和他们头脑中已有的某些速度有关。对某些人来说快的系统,对另外一些人却是慢的。所以,你必须找出更清楚的事实。...
【方法】
论银弹的存在(v0.3),张恂
......“颠覆软件工程[4][8]?软件工程是软件工业的立业之本,深深扎根于数百年来工业、产业和信息革命造就的肥沃土壤。某些人出于各种目的,提出颠覆软件工程,就像要颠覆建筑工程、土木工程、机械工程、装饰装修工程……一样荒唐幼稚, ......
UML 2.0新特性,Granville Miller,郝黎凯
......通信图就是过去的协作图(collaboration diagrams)。和序列图中的术语一样,通信图的结点被称作生命线(lifeline)。这些结点通过消息连接在一起,这些消息代表了交互作用发生的顺序。...
ChattaBox:使用UML和SDL设计并发通信软件系统,P S Kritzinger,车皓阳
......案例研究的主要目标是分析使用最佳工程实践和CASE工具创建这样的系统时,可能的软件工程路线。为了这个目的,我们设计并实现一套称为ChattaBox的VoIP系统。 ......
RUP的分析和设计工作流中的Aspect,Eduardo Kessler Piveta、Augusto Jun Devegili,samying
......本文主要考虑RUP的分析与设计工作流,并且确定这个过程由于AOSD(面向方面的软件开发)而作的改变。我们定义了一个新的角色,称之为“方面设计师”(Aspect Designer)...
在大型项目中使用XP实践,Lan Cao、Kannan Mohan、Peng Xu,李腾
......FinApp参与了一个复杂的企业级系统的开发,这个系统向银行,保险公司,信贷和经纪人提供金融服务。项目包含6大种类的1000多个业务对象 ......
糟糕界面集锦――应用程序点评,Pixelcentric,雷立辉
......“发送”按钮是一个巨大怪异的东西,它的高度竟然和文本输入框是一样的,甚至更大一些。回车和点击按钮都会发送输入的消息,所以让人觉得微软可能想用这种形式来强调这个按钮。想到苹果即将发布的iChat,这个软件就根本没有“发送”按钮...

第37期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer37.pdf

【新闻】
UML被SUN“本地化”
业务驱动开发者的趋势
Cutter会议:敏捷在升级
Select Business Solutions引导新的模型驱动架构解决方案
OASIS委员会通过通用业务语言(Universal Business Language)
Gentleware推出Poseidon for UML 2.3版本
Quocirca直言:编程已死?
【访谈】
MDA辩论,Axel Uhl、Scott W. Ambler,车皓阳
......Scott和我都认为建模总的来说是好的。但是,我不同意Scott所说的产生式MDD,或者说模型驱动架构是造成迷惑的原由。好多工业软件开发项目已经证实了这一点。比方说,德国银行Bauspar和澳大利亚国家铁路报告第一期MDA项目节约了40%...
【方法】
用例和方面——无缝的协作,Ivar Jacobson,Brian Sun
......人类通常是从对具体事物的理解中进行抽象。而与此相反,将抽象概念转换为具体事物,则需要近似于宗教般的信仰。在使抽象概念变得别人可以相信之前,需要为此反复宣传。这种工作多年来我已经做过无数次。当我们的实现环境还是汇编程序的时候,将组件和接口具体化几乎是不可能的, ......
电信行业的软件开发过程案例研究,WHM Theunissen、DG Kourie,李腾
......为了确定敏捷方法在电信行业的适用性,我们对一家电信公司的软件开发过程进行了研究。该案例中的电信公司Telkom SA Ltd.是目前南非唯一的固话运行商。作为第一个步骤,Telkom中同软件相关的一些部门被确定出来...
使用用例探索需求――一次解决需求问题的对话,think
......不,不是这个意思。我们经常看到有人讨论用例应该写得多细,用例的“粒度”应该多大的问题,实际上这些讨论是没有意义的。用例或者说需求不是面团,要怎么捏就怎么捏。这里面实际上就是四个字“实事求是” ......
七步搞死RUP,Craig Larman、Philippe Kruchten、Kurt Bittner,李涛
......RUP的作者并不认为RUP是重型的或者预见性的,这种认为RUP是重型的或者预见性的错误观点是由于加入了不正确的过程思想或者对RUP的误解,RUP本身提供的大量详细的过程文档也加剧了这种认识,以至于RUP被错误的刻画或者蹩脚的实现...
关于重构研究与实践的一次论述,Bart Du Bois、Pieter Van Corp、Tom Mens,风之影
......高级的MDA工具能够逆向工程,即把现有代码转变成抽象模型,从而实现平台集成[97]。显而易见地,这种解析方法只有在现有代码遵守一个预定义结构时才能工作。这样,重构能够被用来把现有代码转换为MDA工具所能理解的规格......
积极主动的软件工具使应用开发潜力最大化,fgonline,李胜利
......Ivar Jacobson发展了对UML和RUP的进化至关重要的“use case”(用例)的概念,他还在软件组件重用专题上发表了无数的文章,将重用概念应用于包装可重用的过程知识组件上。 ......

第38期下载>>
http://www.umlchina.com/xprogrammer/XProgrammer38.pdf

【新闻】
微软计划为Visual Studio增加测试建模等工具
IBM生命周期管理软件决胜Visual Studio 2005
Borland Together新版本推动.Net开发
Ivar Jacobson博士最近忙什么?
Bertrand Meyer“面向对象软件构造”讲座即将举行
【方法】
转化用例为设计,James Bielak,李胜利
......对许多UML和统一过程的从事者,特别是新手来说,从一个类似于故事的用例集生成详细的、充实的设计模型可以证明是相当漫长的一段路程。从陈述的需求建模类和组件之间的交互,这些类和组件每一个都具有各自的属性,方法和责任 ......
实用用例:事件建模使用例变得严密,David A. Ruble,王志航
......在过去的几年中,OCG参加了许多客户(的开发)。这些客户都使用用例作为主要的分析工具。通过使用用例模型的经历,我们发现了两个主要的问题。第一个问题是决定什么组成用例很困难。第二个是如何更好地使用文字描述你所关注的用例的细节。...
复发责任分析模式,Lubor Sesera,Trio
......保险公司和客户签订保险合同获取保费。该合同在一定期间内有效,而客户不必一次付清所有保费。保险公司需要时刻知道实际的保费总额和已经支付了多少。为使这项询问简单高效,查询保费的命令要能够在任何时候可执行(例如每天晚上)...
状态图模式语言,Sherif M. Yacoub、Hany H. Ammar,戴远志
......当实体从一个超级状态转移到另一个,又返回原先的超级状态时,进入的可能需要是其退出时的状态,而不是其缺省状态。我们可以使用状态图规约的历史属性做到这一点,具体实现时超级状态应知道它最后的状态对象。...
设计模式中的可分析性和可更改性,Javier Garzas、Mario Piattini,黄蕾
......既然设计质量可以通过指标来衡量,那么运用设计模式应该获得更好的指标。但是,许多面向对象设计的通用指标都显示运用模式的设计是低质量的设计。 Reibing曾说过,如果对于同一问题有两种类似的设计A和B,B使用了设计模式,A未使用,那么B的质量应比A高。...
UML之“四书五经”,think
......什么?推荐这本“烂书”?是的。这本书从原书内容到中文翻译,被人骂得太多了。问题在于刚听说UML、Rose等新字眼时,你以为人人都有耐心去“打基础”...
《敏捷数据》中译本样章(草稿),Scott W. Ambler,李巍
......数据无疑是基于软件的系统的一个重要方面――这为我们近十年来所共知,然而许多组织机构依然在与他们解决「其软件过程中的面向数据问题」的方法作斗争。敏捷数据(AD)方法的目标是定义「使IT专业人员在软件系统的数据方面能够相互有效工作」的策略。
业务建模 vs. 系统建模
......内容刊登于2004年7期《程序员》杂志...
UMLChina建模竞赛题大全-题目全文+分卷自测(10套100题)

《软件方法》书中自测题-题目全文+分卷自测(1-8章)16套111题

6月27-28、7月4-5晚网络软件需求设计方法学全程实例剖析公开课

建模示范视频(2020年6月)增加公开课真实案例-合同管理系统(催款)

UMLChina视频哔哩哔哩频道(20200322更新)


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存