Archive for 03月, 2007

删除数据库中的用户

有时备份数据库到另外的系统中时,会碰到无法添加原数据库中存在的用户,需先删除用户
方法1:
Use <database>
sp_configure ‘allow updates’,1 — To permit alter system tables
go
reconfigure with override
go
delete from sysusers where name=’guest’
go
sp_configure ‘allow updates’,0 — To deny alter system tables
go
reconfigure with override
go
方法2:
exec sp_revokedbaccess N’yourUserName’

方法1测试没问题,方法2没有测试

鲜为人知的软件项目管理原则

       软件开发的残酷的现实告诉我们:没有规则的软件开发过程带来的只可能是无法预料的结果。我们中的大多数项目管理人员在其个人简历中纷纷写到:”拥有多年的丰富的项目管理经验”,但在实际开发中,”丰富的”管理经验变成了软件开发人员可怕的梦魇。一次次的失败、一次次的返工,她所谓的项目管理经验只不过是再一次的游戏于”无间”(十八层地狱)。一次,在与不少项目管理者的交流中,大家纷纷提到的软件变更带来的可怕影响。但是正如完整的法律体制不能制止犯罪,但没有完整的法律体制犯罪会更加猖獗一样,频繁的软件变更固然可怕,但是没有一个完整的项目管理对应机制,我们无法相像项目最终会是一个什么样子。此外还有一次,笔者在求职时,招聘公司的技术主管(40-50岁左右),向我吹嘘公司按CMM4的过程规则来进行软件的开发和管理。殊不知,我一问下面开发人员,她们在经历无数的加班后正在给已经完成的软件项目添加软件概要设计书,这让我大吃一惊。如此这样形式主义的公司,不呆也罢。 记得一个格言曾经说过”人类最愚蠢的行为在于忘记常识”。另外一句较为相仿的格言则是”不知道历史的人必然会重蹈覆。作为项目管理来说亦为同样的道理。很可惜,我们中的大多数管理者口口声声”软件工程”,工作时”用程序代替用户需求”,极具政客的嘴脸。其结果必然如目前媒体”程序员生存状况”所言,以开发人员在时间的牺牲为代价来换取项目的结束,这是再为普遍不过的现象,在此不再妄加评论。
      如何改善我们的软件开发管理,一条便捷之道便是”尊重常识,尊重历史经验教训”。在软件项目管理中,有许多的原则和经验可以供我们借鉴。
一、 计划原则
      没有计划,你无从知道什么时候控制和变更。制定一个详尽的计划,以详细到开发人员可以理解的程度为宜。计划能够告诉你什么时候应该做什么。没有计划,你无从知道自己需要做什么。不少项目经理告诉组员需要做什么东西后扬长而去,丝毫没有一个相关任务(活动)之间的说明。由于没有计划或是计划太粗糙、不切实际,很多项目1/3甚至1/2的时间花在返工上面。因为计划中遗漏了某一项关键任务,项目就有可能宣告失败。试想一下,制定一个周密合理的计划需要耗费这么多的时间吗?需要付出项目失败的代价吗?还有很多项目管理人员常常错误认为”变化比计划快”,但实际的情况是,由于没有计划,你无法预测和估量变化给你的项目所带来影响,你所面临的将会是比面条还难以理清?混沌”状态。此外,对于开发人员来说,”目标导向(Objective Oriented)”是充分调动其工作积极性的最佳方法,每一个任务阶段的成果能够将员工的工作效率维持在一个较高的水平。因为近期目标总是比远期目标来说更容易看到和达到。为此,制定一个计划吧,让它符合目标导向(通过各个具体任务计划促使项目总计划的达成)。
二、 Brooks原则
      向一个已经滞后的项目添加人员,可能会使项目更加滞后。因为作为新加入的员工来说,相关培训、环境熟悉和人员之间的沟通通路的增加,迫使项目的工作效率急剧下跌。工作效率下降需要加班来进行弥补,但加班造成的疲劳会再次使工作效率降低。同时工作成本却不断的向上攀升。不过就目前来说,项目管理人员丝毫不会理会这一点,”人多力量大”也许更能引人入胜。不少项目管理人员抱怨到时间的急迫性,须知很多项目内时间的急迫性来自于项目管理人员不假思索和不基于常理的邀功表现,没有充分考虑的开发人员能力的多样性
所致。为此,正规的企业不得不耗费大量的加班费用于加班人员的津贴,同时亦要承担违反《劳动法》的潜在法律危险。现在一种万不得已的做法是,假设项目开发人员之间的任务的关联性不是太大的情况下,采取两班倒或是三班倒的方法来保证时间的延续性和相关开发人员的工作高效性。
三、 验收标准原则
      我们在进行某项任务,往往会为以何种结果为宜而感到困惑。不求质量的开发人员往往凭据经验草草了事,追求完美的开发人员则在该项任务上耗费太多的精力,但此番耗费未必针对该项任务,因而常常吃力不讨好。这是由于没有验收标准而导致的情景。因为没有验收标准,你无法知道你要进行的任务需要一个什么样的结果,需要达到什么样的质量标准。在很多情况下,你的活动会与期望结果背道而驰,而此时的你还在沉醉于自己的辛勤耕耘之中。作为项目经理来说,只有制定好每个任务的验收标准,才能够严格把好每一个质量关、同时了解项目的进度情况。
四、 默认无效原则
      你的项目成员理解和赞成项目的范围、目标和你所制定的项目策略吗?不少项目管理人员认为”沉默意味着同意”。实际上我们或多或少都会陷入这样的一个思维误区。试想一下,你作为职员或项目开发人员时的沉默完全代表你赞成你的领导的意见吗?不见得,这就是答案。这一点在项目沟通中极为重要,项目管理者切不可为沉默认为是同意,沉默在很大的程度上说明项目开发人员还尚未弄清楚项目的范围、任务和目标。为此项目管理者还需要同开发人员进行充分沟通,了解开发人员的想法。在对项目没有一个共同的一致的理解的前提下,一个团队是不可能成功的。
五、 80-20原则
      80-20原则在软件开发和项目管理方面有许多”实例”。其一便是我们在20%的项目要求上耗费了80%的时间。仔细分析一下,这些项目要求分为必须的非必须的,因此我们建议是压缩非必须的部分或是暂时将其放在一边不必太重视。软件项目开发事实告诉我们,开发人员在非必须的项目要求上耗费了太多的精力,用户的需求变更的大部分出现在”最好有”这一部分,实际上用户并不看重这些需求(即使去除这些需求),而我们所做的,往往是舍本求末。
      80-20原则的另外一个实例是我们项目中的20%的人员担当了80%的项目任务(这样讲在实际实施中一点都不过分)。考虑到开发人员能力的多样性,聪明的项目管理人员决不会采取任务均分的愚蠢做法,因为就系统论的观点来看,互补结构比对等结构要更稳定一些。此外作为项目管理人员来说,了解属下员工的能力特点,将其放在合适的位置上,会更有利于项目的顺利进行。很多管理人员常常抱怨属下能力问题,究其实质,往往是这些项目管理人员未能发现开发人员潜能所在之处。她们看待问题往往以”经验”这样的思维定势来做决定。导致的结果如系统论所言:由于”抱怨”的作用和反作用循环,结果是大家都不欢而散。
六、 帕金森原则
      帕金森原则原是用于反映政府部门机构臃肿,效率低下的代名词。不过它在软件开发中一样适用。没有时限限制的话,工作可能无限延期。在软件开发中,如果没有严格的时间限制,开发人员往往比较懈怠。这是人的天性所决定的。千万不要指望奇迹的发生DD”所有员工的思想觉悟异常崇高”。作为项目管理者而言,此时应充分考虑到员工的工作效率和项目变更带来的负面影响,制定合理的项目工期并鼓动开发人员尽快完成。
七、时间分配原则
      在项目计划编制过程中,我们常常将资源可用率(人、设备)等设置为100%,殊不知你曾想过,由于开发人员需要休息、吃饭、开会等,根本不可能把所有的时间放在项目开发工作上,而且这还不考虑到开发人员的工作效率是否保持在一恒定水平上。所谓一天8小时工时制实际上是徒有虚名。由于项目管理人员的”无知”,不少开发人员被迫拼命加班。结果依旧出现Brooks原则所出现问题。在实际开发中,开发员工的时间利用率能够达到80%就已经时很不错的了,我个人比较倾向于60%左右(黄金分割点)。一个常用的经验是如果项目人员不懂技术的话,项目时间可能是原计划(该计划没有考虑到资源可用率)的4/3-5/3。如果项目人员不懂技术、管理人员不懂管理的话,这个数字可能是2倍到3倍。现实就是这么严酷。这很大范围内”归功于项目管理人员。是的,我们的确没有必要责备开发人员,因为我们对资源可用率的判断完全违反常识。
八、变化原则
      也许有人问过你,在项目管理中唯一不变的东西是什么?我可以告诉你,项目中唯一不变的就是”变化”。在项目中不考虑可能发生的变化是不可思议的。不过在面对项目可能发生变化而带来的项目风险时,我们的项目管理人员往往会怀有逃避的态度。经济学里大名鼎鼎的风险规避原则便是项目管理人员心理的有效描述。作为项目管理人员来说,应该及早预测可能出现的风险,做好风险储备。虽然风险储备不能解决所有的问题,但预防胜于治疗”。可惜的是我们绝大多数人没有这方面的意识,否则医院的生意未必如此红火,项目开发之途未必如此坎坷。
九、作业标准原则
      一个团队要完成项目的开发需要有一定的章法。很可惜,在国内目前仍然以”作坊式”为主,高举”我们符合国际CMM X规范(ISO某某规范)”的环境下,未必有多少项目团队注意到这一点。我们曾经惊叹印度的高中生都能编程序,而国内却非本科、硕士不收眼帘。究其原因,在于没有开发章法或是章法粗糙,犹如牛皮圣旨一般。一个好的代码模板和代码规范能够解决大多数人编写程序随心所欲的问题,很可惜,没有多少项目管理人员有此意识,也没有多少人愿意去做这项基础任务。业务软件开发需要高超的开发技巧吗?不需要,那是故弄玄虚的开发人员的伎俩。软件开发的美在于其简洁性和规范性,不在于奇技淫巧。因为缺乏作业标准,我们付出的代价是客户的抱怨和无休止的返工。此外,对于那些以形式主意蒙人的项目团队来说,如果你实质如同你口头所说那样,也许你就不会是今天的这副狼狈相。
十、复用和组织变革原则-解决项目问题的未来之路
      如何解决日益突出的项目工期、成本、质量等问题,这是大多数项目管理者最为关心的问题。从实践来看加强复用的力度,建立项目复用体系和实施组织变革是效果较好的途径之一。复用能够提高项目的生产率,降低项目风险。通过复用,项目管理者能够快速的进入项目问题定义之中,减少项目开发人员的工作量,从而尽可能的解决项目在时间、资源方面的过载问题。另外一条途径是实施项目团队的组织变革(Moc),精简项目管理机构、重新定义工作职责,制定柔性的项目工作流程,改善项目开发人员的沟通状况,提高项目人员的开发效率,努力营造一个良好的项目开发环境。这样才能从根本上解决项目开发的种种棘手问题。
结论
      作为一个项目管理者来说,了解和运用上述原则是不够的,若要深入的掌握项目管理知识和技巧,还必须深入学习项目管理(建议参看PMI《PMBOK》)、管理心理学、质量管理学、组织变革、系统论等方面的知识,并在工作中不断的总结和实践。唯有如此,我们的项目管理人员看自己个人简历时方不会觉得脸红,才能在公司中树立自己的管理权威性,同样也才会有一个良好的职业经理生涯的开端。
来源:www.51testing.com  

性能测试

       性能测试是通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。负载测试和压力测试都属于性能测试,两者可以结合进行。通过负载测试,确定在各种工作负载下系统的性能,目标是测试当负载逐渐增加时,系统各项性能指标的变化情况。压力测试是通过确定一个系统的瓶颈或者不能接收的性能点,来获得系统能提供的最大服务级别的测试。
一、概述
       性能测试在软件的质量保证中起着重要的作用,它包括的测试内容丰富多样。中国软件评测中心将性能测试概括为三个方面:应用在客户端性能的测试、应用在网络上性能的测试和应用在服务器端性能的测试。通常情况下,三方面有效、合理的结合,可以达到对系统性能全面的分析和瓶颈的预测。
     ・应用在客户端性能的测试
  应用在客户端性能测试的目的是考察客户端应用的性能,测试的入口是客户端。它主要包括并发性能测试、疲劳强度测试、大数据量测试和速度测试等,其中并发性能测试是重点。
       并发性能测试是重点
  并发性能测试的过程是一个负载测试和压力测试的过程,即逐渐增加负载,直到系统的瓶颈或者不能接收的性能点,通过综合分析交易执行指标和资源监控指标来确定系统并发性能的过程。负载测试(Load Testing)是确定在各种工作负载下系统的性能,目标是测试当负载逐渐增加时,系统组成部分的相应输出项,例如通过量、响应时间、CPU负载、内存使用等来决定系统的性能。负载测试是一个分析软件应用程序和支撑架构、模拟真实环境的使用,从而来确定能够接收的性能过程。压力测试(Stress Testing)是通过确定一个系统的瓶颈或者不能接收的性能点,来获得系统能提供的最大服务级别的测试。
  并发性能测试的目的主要体现在三个方面:以真实的业务为依据,选择有代表性的、关键的业务操作设计测试案例,以评价系统的当前性能;当扩展应用程序的功能或者新的应用程序将要被部署时,负载测试会帮助确定系统是否还能够处理期望的用户负载,以预测系统的未来性能;通过模拟成百上千个用户,重复执行和运行测试,可以确认性能瓶颈并优化和调整应用,目的在于寻找到瓶颈问题。
  当一家企业自己组织力量或委托软件公司代为开发一套应用系统的时候,尤其是以后在生产环境中实际使用起来,用户往往会产生疑问,这套系统能不能承受大量的并发用户同时访问? 这类问题最常见于采用联机事务处理(OLTP)方式数据库应用、Web浏览和视频点播等系统。这种问题的解决要借助于科学的软件测试手段和先进的测试工具。
       举例说明:电信计费软件
  众所周知,每月20日左右是市话交费的高峰期,全市几千个收费网点同时启动。收费过程一般分为两步,首先要根据用户提出的电话号码来查询出其当月产生费用,然后收取现金并将此用户修改为已交费状态。一个用户看起来简单的两个步骤,但当成百上千的终端,同时执行这样的操作时,情况就大不一样了,如此众多的交易同时发生,对应用程序本身、操作系统、中心数据库服务器、中间件服务器、网络设备的承受力都是一个严峻的考验。决策者不可能在发生问题后才考虑系统的承受力, 预见软件的并发承受力, 这是在软件测试阶段就应该解决的问题。
  目前,大多数公司企业需要支持成百上千名用户,各类应用环境以及由不同供应商提供的元件组装起来的复杂产品,难以预知的用户负载和愈来愈复杂的应用程序,使公司担忧会发生投放性能差、用户遭受反应慢、系统失灵等问题。其结果就是导致公司收益的损失。
  如何模拟实际情况呢? 找若干台电脑和同样数目的操作人员在同一时刻进行操作,然后拿秒表记录下反应时间? 这样的手工作坊式的测试方法不切实际,且无法捕捉程序内部变化情况,这样就需要压力测试工具的辅助。
  测试的基本策略是自动负载测试,通过在一台或几台PC机上模拟成百或上千的虚拟用户同时执行业务的情景,对应用程序进行测试,同时记录下每一事务处理的时间、中间件服务器峰值数据、数据库状态等。通过可重复的、真实的测试能够彻底地度量应用的可扩展性和性能,确定问题所在以及优化系统性能。预先知道了系统的承受力,就为最终用户规划整个运行环境的配置提供了有力的依据。
       并发性能测试前的准备工作
  测试环境:配置测试环境是测试实施的一个重要阶段,测试环境的适合与否会严重影响测试结果的真实性和正确性。测试环境包括硬件环境和软件环境,硬件环境指测试必需的服务器、客户端、网络连接设备以及打印机/扫描仪等辅助硬件设备所构成的环境;软件环境指被测软件运行时的操作系统、数据库及其他应用软件构成的环境。
  一个充分准备好的测试环境有三个优点:一个稳定、可重复的测试环境,能够保证测试结果的正确;保证达到测试执行的技术需求;保证得到正确的、可重复的以及易理解的测试结果。
  测试工具:并发性能测试是在客户端执行的黑盒测试,一般不采用手工方式,而是利用工具采用自动化方式进行。目前,成熟的并发性能测试工具有很多,选择的依据主要是测试需求和性能价格比。著名的并发性能测试工具有QALoad、LoadRunner、Benchmark Factory和Webstress等。这些测试工具都是自动化负载测试工具,通过可重复的、真实的测试,能够彻底地度量应用的可扩展性和性能,可以在整个开发生命周期、跨越多种平台、自动执行测试任务,可以模拟成百上千的用户并发执行关键业务而完成对应用程序的测试。
  测试数据:在初始的测试环境中需要输入一些适当的测试数据,目的是识别数据状态并且验证用于测试的测试案例,在正式的测试开始以前对测试案例进行调试,将正式测试开始时的错误降到最低。在测试进行到关键过程环节时,非常有必要进行数据状态的备份。制造初始数据意味着将合适的数据存储下来,需要的时候恢复它,初始数据提供了一个基线用来评估测试执行的结果。
  在测试正式执行时,还需要准备业务测试数据,比如测试并发查询业务,那么要求对应的数据库和表中有相当的数据量以及数据的种类应能覆盖全部业务。
  模拟真实环境测试,有些软件,特别是面向大众的商品化软件,在测试时常常需要考察在真实环境中的表现。如测试杀毒软件的扫描速度时,硬盘上布置的不同类型文件的比例要尽量接近真实环境,这样测试出来的数据才有实际意义。
       并发性能测试的种类与指标
  并发性能测试的种类取决于并发性能测试工具监控的对象,以QALoad自动化负载测试工具为例。软件针对各种测试目标提供了DB2、DCOM、ODBC、ORACLE、NETLoad、Corba、QARun、SAP、SQLServer、Sybase、Telnet、TUXEDO、UNIFACE、WinSock、WWW、Java Script等不同的监控对象,支持Windows和UNIX测试环境。
  最关键的仍然是测试过程中对监控对象的灵活应用,例如目前三层结构的运行模式广泛使用,对中间件的并发性能测试作为问题被提到议事日程上来,许多系统都采用了国产中间件,选择Java Script监控对象,手工编写脚本,可以达到测试目的。
  采用自动化负载测试工具执行的并发性能测试,基本遵循的测试过程有:测试需求与测试内容,测试案例制定,测试环境准备,测试脚本录制、编写与调试,脚本分配、回放配置与加载策略,测试执行跟踪,结果分析与定位问题所在,测试报告与测试评估。
  并发性能测试监控的对象不同,测试的主要指标也不相同,主要的测试指标包括交易处理性能指标和UNIX资源监控。其中,交易处理性能指标包括交易结果、每分钟交易数、交易响应时间(Min:最小服务器响应时间;Mean:平均服务器响应时间;Max:最大服务器响应时间;StdDev:事务处理服务器响应的偏差,值越大,偏差越大;Median:中值响应时间;90%:90%事务处理的服务器响应时间)、虚拟并发用户数。
       应用实例:“新华社多媒体数据库 V1.0”性能测试
  中国软件评测中心(CSTC)根据新华社技术局提出的《多媒体数据库(一期)性能测试需求》和GB/T 17544《软件包质量要求和测试》的国家标准,使用工业标准级负载测试工具对新华社使用的“新华社多媒体数据库 V1.0”进行了性能测试。
  性能测试的目的是模拟多用户并发访问新华社多媒体数据库,执行关键检索业务,分析系统性能。
  性能测试的重点是针对系统并发压力负载较大的主要检索业务,进行并发测试和疲劳测试,系统采用B/S运行模式。并发测试设计了特定时间段内分别在中文库、英文库、图片库中进行单检索词、多检索词以及变检索式、混合检索业务等并发测试案例。疲劳测试案例为在中文库中并发用户数200,进行测试周期约8小时的单检索词检索。在进行并发和疲劳测试的同时,监测的测试指标包括交易处理性能以及UNIX(Linux)、Oracle、Apache资源等。
  测试结论:在新华社机房测试环境和内网测试环境中,100M带宽情况下,针对规定的各并发测试案例,系统能够承受并发用户数为200的负载压力,最大交易数/分钟达到78.73,运行基本稳定,但随着负载压力增大,系统性能有所衰减。
  系统能够承受200并发用户数持续周期约8小时的疲劳压力,基本能够稳定运行。
  通过对系统UNIX(Linux)、Oracle和Apache资源的监控,系统试茨芄宦 闵鲜霾⒎⒑推@托阅苄枨螅 蚁低秤布 试瓷杏薪洗罄 糜嗟亍?/FONT>
  当并发用户数超过200时,监控到HTTP 500、connect和超时错误,且Web服务器报内存溢出错误,系统应进一步提高性能,以支持更大并发用户数。
  建议进一步优化软件系统,充分利用硬件资源,缩短交易响应时间。
       疲劳强度与大数据量测试
  疲劳测试是采用系统稳定运行情况下能够支持的最大并发用户数,持续执行一段时间业务,通过综合分析交易执行指标和资源监控指标来确定系统处理最大工作量强度性能的过程。
  疲劳强度测试可以采用工具自动化的方式进行测试,也可以手工编写程序测试,其中后者占的比例较大。
  一般情况下以服务器能够正常稳定响应请求的最大并发用户数进行一定时间的疲劳测试,获取交易执行指标数据和系统资源监控数据。如出现错误导致测试不能成功执行,则及时调整测试指标,例如降低用户数、缩短测试周期等。还有一种情况的疲劳测试是对当前系统性能的评估,用系统正常业务情况下并发用户数为基础,进行一定时间的疲劳测试。
  大数据量测试可以分为两种类型:针对某些系统存储、传输、统计、查询等业务进行大数据量的独立数据量测试;与压力性能测试、负载性能测试、疲劳性能测试相结合的综合数据量测试方案。大数据量测试的关键是测试数据的准备,可以依靠工具准备测试数据。
  速度测试目前主要是针对关键有速度要求的业务进行手工测速度,可以在多次测试的基础上求平均值,可以和工具测得的响应时间等指标做对比分析。
       ・应用在网络上性能的测试
  应用在网络上性能的测试重点是利用成熟先进的自动化技术进行网络应用性能监控、网络应用性能分析和网络预测。
       网络应用性能分析
  网络应用性能分析的目的是准确展示网络带宽、延迟、负载和TCP端口的变化是如何影响用户的响应时间的。利用网络应用性能分析工具,例如Application Expert,能够发现应用的瓶颈,我们可知应用在网络上运行时在每个阶段发生的应用行为,在应用线程级分析应用的问题。可以解决多种问题:客户端是否对数据库服务器运行了不必要的请求?当服务器从客户端接受了一个查询,应用服务器是否花费了不可接受的时间联系数据库服务器?在投产前预测应用的响应时间;利用Application Expert调整应用在广域网上的性能;Application Expert能够让你快速、容易地仿真应用性能,根据最终用户在不同网络配置环境下的响应时间,用户可以根据自己的条件决定应用投产的网络环境。
       网络应用性能监控
  在系统试运行之后,需要及时准确地了解网络上正在发生什么事情;什么应用在运行,如何运行;多少PC正在访问LAN或WAN;哪些应用程序导致系统瓶颈或资源竞争,这时网络应用性能监控以及网络资源管理对系统的正常稳定运行是非常关键的。利用网络应用性能监控工具,可以达到事半功倍的效果,在这方面我们可以提供的工具是Network Vantage。通俗地讲,它主要用来分析关键应用程序的性能,定位问题的根源是在客户端、服务器、应用程序还是网络。在大多数情况下用户较关心的问题还有哪些应用程序占用大量带宽,哪些用户产生了最大的网络流量,这个工具同样能满足要求。
       网络预测
  考虑到系统未来发展的扩展性,预测网络流量的变化、网络结构的变化对用户系统的影响非常重要。根据规划数据进行预测并及时提供网络性能预测数据。我们利用网络预测分析容量规划工具PREDICTOR可以作到:设置服务水平、完成日网络容量规划、离线测试网络、网络失效和容量极限分析、完成日常故障诊断、预测网络设备迁移和网络设备升级对整个网络的影响。
  从网络管理软件获取网络拓扑结构、从现有的流量监控软件获取流量信息(若没有这类软件可人工生成流量数据),这样可以得到现有网络的基本结构。在基本结构的基础上,可根据网络结构的变化、网络流量的变化生成报告和图表,说明这些变化是如何影响网络性能的。 PREDICTOR提供如下信息:根据预测的结果帮助用户及时升级网络,避免因关键设备超过利用阀值导致系统性能下降;哪个网络设备需要升级,这样可减少网络延迟、避免网络瓶颈;根据预测的结果避免不必要的网络升级。
       ・应用在服务器上性能的测试
  对于应用在服务器上性能的测试,可以采用工具监控,也可以使用系统本身的监控命令,例如Tuxedo中可以使用Top命令监控资源使用情况。实施测试的目的是实现服务器设备、服务器操作系统、数据库系统、应用在服务器上性能的全面监控,测试原理如下图。
UNIX资源监控指标和描述
  监控指标 描述
  平均负载 系统正常状态下,最后60秒同步进程的平均个数
  冲突率 在以太网上监测到的每秒冲突数
  进程/线程交换率 进程和线程之间每秒交换次数
  CPU利用率 CPU占用率(%)
  磁盘交换率 磁盘交换速率
  接收包错误率 接收以太网数据包时每秒错误数
  包输入率 每秒输入的以太网数据包数目
  中断速率 CPU每秒处理的中断数
  输出包错误率 发送以太网数据包时每秒错误数
  包输入率 每秒输出的以太网数据包数目
  读入内存页速率 物理内存中每秒读入内存页的数目
  写出内存页速率 每秒从物理内存中写到页文件中的内存页数
   目或者从物理内存中删掉的内存页数目
  内存页交换速率 每秒写入内存页和从物理内存中读出页的个数
  进程入交换率 [...]

单元测试

       单元测试(模块测试)是开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确。通常而言,一个单元测试是用于判断某个特定条件(或者场景)下某个特定函数的行为。例如,你可能把一个很大的值放入一个有序list 中去,然后确认该值出现在list 的尾部。或者,你可能会从字符串中删除匹配某种模式的字符,然后确认字符串确实不再包含这些字符了。
       单元测试是由程序员自己来完成,最终受益的也是程序员自己。可以这么说,程序员有责任编写功能代码,同时也就有责任为自己的代码编写单元测试。执行单元测试,就是为了证明这段代码的行为和我们期望的一致。
       工厂在组装一台电视机之前,会对每个元件都进行测试,这,就是单元测试。
  其实我们每天都在做单元测试。你写了一个函数,除了极简单的外,总是要执行一下,看看功能是否正常,有时还要想办法输出些数据,如弹出信息窗口什么的,这,也是单元测试,老纳把这种单元测试称为临时单元测试。只进行了临时单元测试的软件,针对代码的测试很不完整,代码覆盖率要超过70%都很困难,未覆盖的代码可能遗留大量的细小的错误,这些错误还会互相影响,当BUG暴露出来的时候难于调试,大幅度提高后期测试和维护成本,也降低了开发商的竞争力。可以说,进行充分的单元测试,是提高软件质量,降低开发成本的必由之路。
  对于程序员来说,如果养成了对自己写的代码进行单元测试的习惯,不但可以写出高质量的代码,而且还能提高编程水平。
  要进行充分的单元测试,应专门编写测试代码,并与产品代码隔离。老纳认为,比较简单的办法是为产品工程建立对应的测试工程,为每个类建立对应的测试类,为每个函数(很简单的除外)建立测试函数。首先就几个概念谈谈老纳的看法。
  一般认为,在结构化程序时代,单元测试所说的单元是指函数,在当今的面向对象时代,单元测试所说的单元是指类。以老纳的实践来看,以类作为测试单位,复杂度高,可操作性较差,因此仍然主张以函数作为单元测试的测试单位,但可以用一个测试类来组织某个类的所有测试函数。单元测试不应过分强调面向对象,因为局部代码依然是结构化的。单元测试的工作量较大,简单实用高效才是硬道理。
  有一种看法是,只测试类的接口(公有函数),不测试其他函数,从面向对象角度来看,确实有其道理,但是,测试的目的是找错并最终排错,因此,只要是包含错误的可能性较大的函数都要测试,跟函数是否私有没有关系。对于C++来说,可以用一种简单的方法区隔需测试的函数:简单的函数如数据读写函数的实现在头文件中编写(inline函数),所有在源文件编写实现的函数都要进行测试(构造函数和析构函数除外)。
为什么要使用单元测试
     我们编写代码时,一定会反复调试保证它能够编译通过。如果是编译没有通过的代码,没有任何人会愿意交付给自己的老板。但代码通过编译,只是说明了它的语法正确;我们却无法保证它的语义也一定正确,没有任何人可以轻易承诺这段代码的行为一定是正确的。
     幸运,单元测试会为我们的承诺做保证。编写单元测试就是用来验证这段代码的行为是否与我们期望的一致。有了单元测试,我们可以自信的交付自己的代码,而没有任何的后顾之忧。
  什么时候测试?单元测试越早越好,早到什么程度?XP开发理论讲究TDD,即测试驱动开发,先编写测试代码,再进行开发。在实际的工作中,可以不必过分强调先什么后什么,重要的是高效和感觉舒适。从老纳的经验来看,先编写产品函数的框架,然后编写测试函数,针对产品函数的功能编写测试用例,然后编写产品函数的代码,每写一个功能点都运行测试,随时补充测试用例。所谓先编写产品函数的框架,是指先编写函数空的实现,有返回值的随便返回一个值,编译通过后再编写测试代码,这时,函数名、参数表、返回类型都应该确定下来了,所编写的测试代码以后需修改的可能性比较小。
  由谁测试?单元测试与其他测试不同,单元测试可看作是编码工作的一部分,应该由程序员完成,也就是说,经过了单元测试的代码才是已完成的代码,提交产品代码时也要同时提交测试代码。测试部门可以作一定程度的审核。
  关于桩代码,老纳认为,单元测试应避免编写桩代码。桩代码就是用来代替某些代码的代码,例如,产品函数或测试函数调用了一个未编写的函数,可以编写桩函数来代替该被调用的函数,桩代码也用于实现测试隔离。采用由底向上的方式进行开发,底层的代码先开发并先测试,可以避免编写桩代码,这样做的好处有:减少了工作量;测试上层函数时,也是对下层函数的间接测试;当下层函数修改时,通过回归测试可以确认修改是否导致上层函数产生错误。
     在一种传统的结构化编程语言中,比如C,要进行测试的单元一般是函数或子过程。在象C++这样的面向对象的语言中, 要进行测试的基本单元是类。对Ada语言来说,开发人员可以选择是在独立的过程和函数,还是在Ada包的级别上进行单元测试。单元测试的原则同样被扩展到第四代语言(4GL)的开发中,在这里基本单元被典型地划分为一个菜单或显示界面。
  单元测试不仅仅是作为无错编码一种辅助手段在一次性的开发过程中使用,单元测试必须是可重复的,无论是在软件修改,或是移植到新的运行环境的过程中。因此,所有的测试都必须在整个软件系统的生命周期中进行维护。
  经常与单元测试联系起来的另外一些开发活动包括代码走读(Code review),静态分析(Static analysis)和动态分析(Dynamic analysis)。静态分析就是对软件的源代码进行研读,查找错误或收集一些度量数据,并不需要对代码进行编译和执行。动态分析就是通过观察软件运行时的动作,来提供执行跟踪,时间分析,以及测试覆盖度方面的信息。
一些流行的误解
  在明确了什么是单元测试以后,我们可以进行”反调论证”了。在下面的章节里,我们列出了一些反对单元测试的普遍的论点。然后用充分的理由来证明这些论点是不足取的。
       它浪费了太多的时间
  一旦编码完成,开发人员总是会迫切希望进行软件的集成工作,这样他们就能够看到实际的系统开始启动工作了。 这在外表上看来是一项明显的进步,而象单元测试这样的活动也许会被看作是通往这个阶段点的道路上的障碍, 推迟了对整个系统进行联调这种真正有意思的工作启动的时间。
  在这种开发步骤中,真实意义上的进步被外表上的进步取代了。系统能够正常工作的可能性是很小的,更多的情况是充满了各式各样的Bug。在实践中,这样一种开发步骤常常会导致这样的结果:软件甚至无法运行。更进一步的结果是大量的时间将被花费在跟踪那些包含在独立单元里的简单的Bug上面,在个别情况下,这些Bug也许是琐碎和微不足道的,但是总的来说,他们会导致在软件集成为一个系统时增加额外的工期, 而且当这个系统投入使用时也无法确保它能够可靠运行。
  在实践工作中,进行了完整计划的单元测试和编写实际的代码所花费的精力大致上是相同的。一旦完成了这些单元测试工作,很多Bug将被纠正,在确信他们手头拥有稳定可靠的部件的情况下,开发人员能够进行更高效的系统集成工作。这才是真实意义上的进步,所以说完整计划下的单元测试是对时间的更高效的利用。而调试人员的不受控和散漫的工作方式只会花费更多的时间而取得很少的好处。
  使用AdaTEST和Cantata这样的支持工具可以使单元测试更加简单和有效。但这不是必须的,单元测试即使是在没有工具支持的情况下也是一项非常有意义的活动。
       它仅仅是证明这些代码做了什么
  这是那些没有首先为每个单元编写一个详细的规格说明而直接跳到编码阶段的开发人员提出的一条普遍的抱怨, 当编码完成以后并且面临代码测试任务的时候,他们就阅读这些代码并找出它实际上做了什么,把他们的测试工作基于已经写好的代码的基础上。当然,他们无法证明任何事情。所有的这些测试工作能够表明的事情就是编译器工作正常。是的,他们也许能够抓住(希望能够)罕见的编译器Bug,但是他们能够做的仅仅是这些。
  如果他们首先写好一个详细的规格说明,测试能够以规格说明为基础。代码就能够针对它的规格说明,而不是针对自身进行测试。这样的测试仍然能够抓住编译器的Bug,同时也能找到更多的编码错误,甚至是一些规格说明中的错误。好的规格说明可以使测试的质量更高,所以最后的结论是高质量的测试需要高质量的规格说明。
  在实践中会出现这样的情况: 一个开发人员要面对测试一个单元时只给出单元的代码而没有规格说明这样吃力不讨好的任务。你怎样做才会有更多的收获,而不仅仅是发现编译器的Bug?第一步是理解这个单元原本要做什么, — 不是它实际上做了什么。 比较有效的方法是倒推出一个概要的规格说明。这个过程的主要输入条件是要阅读那些程序代码和注释, 主要针对这个单元, 及调用它和被它调用的相关代码。画出流程图是非常有帮助的,你可以用手工或使用某种工具。 可以组织对这个概要规格说明的走读(Review),以确保对这个单元的说明没有基本的错误, 有了这种最小程度的代码深层说明,就可以用它来设计单元测试了。
       我是个很棒的程序员, 我是不是可以不进行单元测试?
  在每个开发组织中都至少有一个这样的开发人员,他非常擅长于编程,他们开发的软件总是在第一时间就可以正常运行,因此不需要进行测试。你是否经常听到这样的借口?
  在真实世界里,每个人都会犯错误。即使某个开发人员可以抱着这种态度在很少的一些简单的程序中应付过去。 但真正的软件系统是非常复杂的。真正的软件系统不可以寄希望于没有进行广泛的测试和Bug修改过程就可以正常工作。
  编码不是一个可以一次性通过的过程。在真实世界中,软件产品必须进行维护以对操作需求的改变作出反应, 并且要对最初的开发工作遗留下来的Bug进行修改。你希望依靠那些原始作者进行修改吗? 这些制造出这些未经测试的原始代码的资深专家们还会继续在其他地方制造这样的代码。在开发人员做出修改后进行可重复的单元测试可以避免产生那些令人不快的负作用。
       不管怎样, 集成测试将会抓住所有的Bug
  我们已经在前面的讨论中从一个侧面对这个问题进行了部分的阐述。这个论点不成立的原因在于规模越大的代码集成意味着复杂性就越高。如果软件的单元没有事先进行测试,开发人员很可能会花费大量的时间仅仅是为了使软件能够运行,而任何实际的测试方案都无法执行。
  一旦软件可以运行了,开发人员又要面对这样的问题: 在考虑软件全局复杂性的前提下对每个单元进行全面的测试。 这是一件非常困难的事情,甚至在创造一种单元调用的测试条件的时候,要全面的考虑单元的被调用时的各种入口参数。在软件集成阶段,对单元功能全面测试的复杂程度远远的超过独立进行的单元测试过程。
  最后的结果是测试将无法达到它所应该有的全面性。一些缺陷将被遗漏,并且很多Bug将被忽略过去。
  让我们类比一下,假设我们要清洗一台已经完全装配好的食物加工机器!无论你喷了多少水和清洁剂,一些食物的小碎片还是会粘在机器的死角位置,只有任其腐烂并等待以后再想办法。但我们换个角度想想,如果这台机器是拆开的, 这些死角也许就不存在或者更容易接触到了,并且每一部分都可以毫不费力的进行清洗。
       它的成本效率不高
  一个特定的开发组织或软件应用系统的测试水平取决于对那些未发现的Bug的潜在后果的重视程度。这种后果的严重程度可以从一个Bug引起的小小的不便到发生多次的死机的情况。这种后果可能常常会被软件的开发人员所忽视(但是用户可不会这样),这种情况会长期的损害这些向用户提交带有Bug的软件的开发组织的信誉,并且会导致对未来的市场产生负面的影响。相反地,一个可靠的软件系统的良好的声誉将有助于一个开发组织获取未来的市场。
  很多研究成果表明,无论什么时候作出修改都要进行完整的回归测试,在生命周期中尽早地对软件产品进行测试将使效率和质量得到最好的保证。Bug发现的越晚,修改它所需的费用就越高,因此从经济角度来看, 应该尽可能早的查找和修改Bug。在修改费用变的过高之前,单元测试是一个在早期抓住Bug的机会。
  相比后阶段的测试,单元测试的创建更简单,维护更容易,并且可以更方便的进行重复。从全程的费用来考虑, 相比起那些复杂且旷日持久的集成测试,或是不稳定的软件系统来说,单元测试所需的费用是很低的。
       一些图表
  这些图表摘自<<实用软件度量>>(Capers Jones,McGraw-Hill 1991),它列出了准备测试,执行测试,和修改缺陷所花费的时间(以一个功能点为基准),这些数据显示单元测试的成本效率大约是集成测试的两倍 系统测试的三倍(参见条形图)。

(术语域测试(Field test)意思是在软件投入使用以后,针对某个领域所作的所有测试活动)
  这个图表并不表示开发人员不应该进行后阶段的测试活动,这次测试活动仍然是必须的。它的真正意思是尽可能早的排除尽可能多的Bug可以减少后阶段测试的费用。
  其他的一些图表显示高达50%的维护工作量被花在那些总是会有的Bug的修改上面。如果这些Bug在开发阶段被排除掉的话,这些工作量就可以节省下来。当考虑到软件维护费用可能会比最初的开发费用高出数倍的时候,这种潜在的对50%软件维护费用的节省将对整个软件生命周期费用产生重大的影响。
结论
  经验表明一个尽责的单元测试方法将会在软件开发的某个阶段发现很多的Bug,并且修改它们的成本也很低。在软件开发的后期阶段,Bug的发现并修改将会变得更加困难,并要消耗大量的时间和开发费用。无论什么时候作出修改都要进行完整的回归测试,在生命周期中尽早地对软件产品进行测试将使效率和质量得到最好的保证。 在提供了经过测试的单元的情况下,系统集成过程将会大大地简化。开发人员可以将精力集中在单元之间的交互作用和全局的功能实现上,而不是陷入充满很多Bug的单元之中不能自拔。
  使测试工作的效力发挥到最大化的关键在于选择正确的测试策略,这其中包含了完全的单元测试的概念,以及对测试过程的良好的管理,还有适当地使用象AdaTEST和Cantata这样的工具来支持测试过程。这些活动可以产生这样的结果:在花费更低的开发费用的情况下得到更稳定的软件。更进一步的好处是简化了维护过程并降低了生命周期的费用。有效的单元测试是推行全局质量文化的一部分,而这种质量文化将会为软件开发者带来无限的商机。
单元测试的优点
1、它是一种验证行为。
     程序中的每一项功能都是测试来验证它的正确性。它为以后的开发提供支缓。就算是开发后期,我们也可以轻松的增加功能或更改程序结构,而不用担心这个过程中会破坏重要的东西。而且它为代码的重构提供了保障。这样,我们就可以更自由的对程序进行改进。
2、它是一种设计行为。
     编写单元测试将使我们从调用者观察、思考。特别是先写测试(test-first),迫使我们把程序设计成易于调用和可测试的,即迫使我们解除软件中的耦合。
3、它是一种编写文档的行为。
     单元测试是一种无价的文档,它是展示函数或类如何使用的最佳文档。这份文档是可编译、可运行的,并且它保持最新,永远与代码同步。
4、它具有回归性。
     自动化的单元测试避免了代码出现回归,编写完成之后,可以随时随地的快速运行测试。 [...]

每日一句:Clothes make the man.( 3.08 )

Clothes make the man. 
人要衣装。 
————————————————————————————————— 
  动词make的原意是“做”,在口语中有“成为”的意思。 
例句:If you work hard, you will make a good athlete. 如果你肯努力, 你将成为一个好运动员。 
 
 
 
 
 

SourceFormatX 2.56 的注册破解版

SourceFormatX ™ 万能源代码格式化工具 V2.56 是什么? SourceFormatX 是一款强大的多语言源代码格式化工具和源代码美化工具,它支持 C/C++, Java, C#, Delphi (Object Pascal), Visual Basic (VB), VB.NET (VB DotNet), VBScript (VB Script), JavaScript (JScript / Java Script), PHP, ASP, JSP, HTML, XML, HTML Components (HTC), 80×86 汇编语言 (8086 Assembly), 8051 汇编语言 (8051 Assembly), Objective-C 和 CORBA IDL 编程语言。
下载SourceFormatX 2.56 的破解版: 点击这里下载>>
注:有网友说有病毒,但我一直用着没问题的.如果担心就不要下载了。

(转)关于Norton 2006的激活问题

在Norton Internet Security 2007还未破解的情况下,Norton Internet Security 2006的破解问题在讨论区内好像一直没有得到解决。大家的论调一直都是认为Norton Internet Security 2006没有完美破解。
说到Norton Internet Security 2006的破解问题,我觉得我还是有那么一点点发言权的,2006年4月14日,本人不小心发现替换两个DLL文件竟然可以重新激活资源更新后导致不能使用的Norton Internet Security 2006,在几个网友的证实下,本人在诺顿贴吧以“如萤之火”的用户名发表了《完美解决Norton Internet Security激活,顶顶顶!!! 》与《完美解决Norton SystemWorks 2006许可证过期,顶顶顶!!! 》的文章,得到了广大网友的热烈响应,很高兴,大家又可以用上Norton Internet Security 2006和Norton SystemWorks 2006了。然而,今日在讨论区里看了看,发现由于一些网友的操作方法不对,导致不能使用Norton Internet Security 2006,对替换DLL文件的方法嗤之以鼻,真的是很遗憾。
现在,我想说那么几点,希望消除讨论区各位网友对替换DLL文件的方法的误会:
1、替换DLL文件的方法从今年4月至今,是可以真正的完美解决Norton Internet Security激活问题的,这点本人和一批网友一直正常使用中,没有任何问题。
2、一些人会遇到一种特殊的情况,激活后可能会碰到订购期限的问题, 你需要重新激活。
3、关于替换DLL文件是否让2006变成2004,可以说,这完全是谣言,诺顿通过更新scanmgr.dll文件(12.2.0.13更换掉12.0.0.94)改变了扫描方式,当时我敏感的认为,不管变没变2004,替换回scanmgr.dll(12.0.0.94)文件回到原来的扫描方式是比较安全的,于是大家又开始替换scanmgr.dll文件,导致前段时间有些网友不能更新,因为诺顿又发布了新版的scanmgr.dll(12.6.0.1)文件,在升级过程中不能自动替换掉最老版的scanmgr.dll(12.0.0.94),没有做12.2.0.13备份的朋友就无法升级,导致我在诺顿贴吧不停的发新版的scanmgr.dll邮件给他们,这样他们又继续更新了。总的来说,替换scanmgr.dll文件绝对是一次画蛇添足的。现在全新安装的Norton Internet Security 2006升级后是最新的scanmgr.dll文件,完全没有问题,对于scanmgr.dll大家可以不用讨论了。
4、一些曾经装过Norton Internet Security 2007试用之后,又重装Norton Internet Security 2006是无论如何都不能再激活的,替换都没用,会出现一些网友所说的-1天的情况,除非你卸载得相当的彻底。全新系统安装Norton Internet Security 2006,使用是完全没有问题的。
5、曾经装过Norton Internet Security 2007的也会导致Norton SystemWorks 2006不能激活。
6、Norton Internet Security 2006除了耗内存以外,是个很好很安全的产品,在Norton Internet Security 2007没有破解的情况下,还是值得大家使用的。
另外为了让更多的诺顿爱好者真正使用上Norton Internet Security 2006,我总结一下Norton Internet Security 2006的激活方法,里面有些新的东西,可能对某些网友来说完全是陈词滥调,但对一些初次接触Norton Internet Security的朋友来说应该是有帮助的。说到底,我的初衷是让更多的诺顿爱好者能够正常的使用上诺顿的产品,因为长久以来,使用诺顿的产品有了感情,看到愈来愈多的人加入卡巴(破解比较方便)的大军心里真的很不是滋味。
Norton Internet Security 2006资源更新后导致不能激活,主要是替换了已激活Norton Internet Security里的两个文件: 
C(X):\Program Files\Norton Internet Security\ISSTE.dll 
C(X):\Program Files\Norton Internet Security\SymUIHlp.dll 
这两个文件的原来的版本是6.0.0.81,发行日期是09/24/2005。 
而被Norton Internet Security资源更新后导致不能激活主要原因是这两个文件被替换了,版本号变成了6.0.1.95, 发行日期是01/16/2006。
如果你的Norton Internet Security 2006资源更新后不能激活,首先要找到安装程序――镜像文件或安装盘均可。到以下文件夹找到那两个文件。 
XP 2000系统 
X(虚拟光驱或安装盘):\WINNT\Setup\Setup\APP\ISSTE.dll 
X(虚拟光驱或安装盘):\WINNT\Setup\SymLT\SymUIHlp.dll 
9X 系统     
X(虚拟光驱或安装盘):\WIN9X\Setup\Setup\APP\ISSTE.dll 
X(虚拟光驱或安装盘):\WIN9X\Setup\SymLT\SymUIHlp.dll 
复制ISSTE.dll和SymUIHlp.dll,放到别的地方保存起来。 
重启电脑按F8进入安全模式,复制原来保存的那两个文件(版本是6.0.0.81),粘贴到安装目录如C:\Program Files\Norton Internet Security\中替换掉导致不能激活的那两个文件(版本号6.0.1.95),重启,进入系统,马上打开Norton Internet Security,点击LiveUpdate,在“LiveUpdate”运行的过程中,Norton Internet Security会自动回到激活状态。
激活后可能导致电子邮件扫描错误,重启后可解决。 
有一种特殊的情况:激活后可能会碰到订购期限的问题。 
你需要重新激活,如:点击帮助和技术支持-激活-下一步-安装序号JDVXB-2MMFW-WTWC2-RRDTP-C8GMJ--“关闭网络”--耐心等待直至出现”电话激活”画面-全部输入数字0,最后一组后三位改为999(例如000000,000000,000000,000000,000999) 
经过这一步后,你的问题即可解决。
还有完美解决Norton SystemWorks 2006许可证过期
Norton SystemWorks 2006运行LiveUpdate后更新Norton SystemWorks导致许可证过期,主要是替换了已激活的Norton SystemWorks 2006里的两个文件: 
C(X):\Program Files\Norton SystemWorks\NSWSTE.dll 
C(X):\Program Files\Norton SystemWorks\SymUIHlp.dll 
这两个文件的原来的版本是6.0.0.85,发行日期是09/30/2005。 
而被Norton SystemWorks更新后导致不能激活主要原因是这两个文件被替换了,版本号变成了6.0.1.95, 发行日期是01/16/2006。
如果你的Norton SystemWorks 2006运行LiveUpdate后更新Norton SystemWorks导致许可证过期,请找出你的Norton SystemWorks 2006简体中文版,安装光盘或镜像文件均可,复制以下两个文件:   
X(虚拟光驱或安装盘):\NSW\NSWSTE.DLL(6.0.0.85版本)   
X(虚拟光驱或安装盘):\NAV\SYMLT\NORTON\SYMUIHLP.DLL(6.0.0.80版本)   
之后到你的Norton SystemWorks 2006简体中文版的安装目录如C:\Program Files\Norton SystemWorks里,用你复制的那两个文件替换由于你更新了Norton SystemWorks而导致你许可证过期的那两个文件,即:NSWSTE.dll(6.0.1.95);SymUIHlp.dll(6.0.1.95),再运行Norton SystemWorks,即可激活。

全新安装Norton SystemWorks 2006 需注意: 
两种情况 
1、安装了Norton Internet Security 2006,再安装Norton SystemWorks 2006 
安装(安装序号:WK2WK-4T7B8-TPFGX-27JJC-6D8MX),电话激活后(关闭网络,耐心等待直至出现”电话激活”画面,全部输入数字0,最后一组后三位改为999,例如000000,000000,000000,000000,000999),联网前到“选项”关闭自动更新LiveUpdate,联网,手动LiveUpdate,第一次手动更新,全部更新后,手动更新第二次(这里说的“第二次”是建立在第一次成功更新的基础上的,实际情况可能有所不同)会看到有“Norton SystemWorks”更新,这里注意,关闭Norton SystemWorks 2006,更新“Norton SystemWorks”后,马上将两个Dll文件替换到Norton SystemWorks 2006的安装文件夹。之后运行Norton SystemWorks 2006,可以看到Norton SystemWorks 2006仍然会是是激活状态,打开自动更新,日后可任意更新。这个方法的好处是一直可以使软件保持在激活状态,避免了产品许可证出现问题需要重新激活后造成的各种错误。 
如果你由于各种原因,更新“Norton SystemWorks”前没有及时关闭Norton SystemWorks 2006,更新后的没有及时进Norton SystemWorks 2006的安装文件夹更换两个DLL文件,重新运行Norton SystemWorks 2006后导致产品许可证出现问题,之后再更换两个DLL文件,Norton SystemWorks 2006仍然是可以自动激活的。 
2、没有安装Norton Internet Security 2006,单独安装Norton SystemWorks 2006 
安装(安装序号:WK2WK-4T7B8-TPFGX-27JJC-6D8MX),电话激活后(关闭网络,耐心等待直至出现”电话激活”画面,全部输入数字0,最后一组后三位改为999,例如000000,000000,000000,000000,000999),联网前到“选项”关闭自动更新LiveUpdate,联网,手动LiveUpdate,第一次手动更新会有很多内容,全部更新后(内容较多,容易导致下载中断,可能需要重复连接数次),重启。手动更新第二次(这里说的“第二次”是建立在第一次成功更新的基础上的,实际情况可能有所不同)会看到有“Norton SystemWorks”更新,这里注意,关闭Norton SystemWorks 2006,之后更新“Norton SystemWorks”,这时会提示重启,暂时不要重启,马上将两个Dll文件替换到Norton SystemWorks 2006的安装文件夹,之后再重启。运行Norton SystemWorks 2006,可以看到Norton SystemWorks 2006仍然会是是激活状态,打开自动更新,日后可任意更新。这个方法的好处是一直可以使软件保持在激活状态,避免了产品许可证出现问题需要重新激活后造成的各种错误。 
如果你由于各种原因,更新后没有及时进Norton SystemWorks 2006的安装文件夹更换两个DLL文件,重新启动后,请马上按F8进安全模式更换两个DLL文件,重启后仍然会是是激活状态。如果你连这次机会也错过,重启系统后运行Norton SystemWorks 2006导致产品许可证出现问题,之后再更换两个DLL文件,虽然这时会有很大机会可以让Norton SystemWorks 2006重新激活,但是偶尔也会出现不能激活的情况。因此,请谨慎操作。

Visual Basic中如何判断一个数组为空数组?

 方法一:Error方法
就是采用通用的错误捕获功能
On Error Goto 行号       ’遇到错误,转到行号处处理
On Error Resume Next ’忽略错误,继续执行
On Error Goto 0           ’强制取消错误捕获功能
方法二:CopyMemory方法
VB的数组都是安全数组,通过访问一个结构来确定 数组内容保存位置,上标下标和维数
安全数组结构的地址可以用 
Private Declare Function VarPtrArray Lib ”msvbvm60.dll” Alias ”VarPtr” (ByRef Ptr() As Any) As Long

Private Declare Sub CopyMemory Lib ”kernel32.dll” Alias ”RtlMoveMemory” _
             (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)
获得
安全数组的头两位就保存着维数信息
Option Explicit
Private Declare Function VarPtrArray Lib ”msvbvm60.dll” Alias ”VarPtr” (ByRef Ptr() As Any) As Long
Private Declare Sub CopyMemory Lib ”kernel32.dll” Alias ”RtlMoveMemory” (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)
Private Sub Form_Load()
    Dim MyArr() As Long
    Dim pMyarr As Long
    Dim nDims As Integer
    
    ’从数据指针得到SafeArray结构的指针
    CopyMemory pMyarr, ByVal VarPtrArray(MyArr), 4
    If pMyarr = 0 Then
        MsgBox ”这个数组是空数组”
    Else
        ’再从这个指针所指地址的头两个字节取出cDims
        CopyMemory nDims, ByVal pMyarr, 2
        MsgBox ”这个数组有” & nDims & ”维”
    End If
End Sub 

每日一句:Time is running out.( 3.05 )

Time is running out. 
没时间了。 
————————————————————————————————— 
  run out 有“用光,用完”的意思。 
例句: 
1、用完;耗尽:Our supplies finally ran out. 我们的供给终于耗尽了。 
2、逐出;强使离去;驱逐:We ran him out of town.. 我们把他驱逐出镇子。 

系统敏感端口真正的关闭大法

大致的敏感端口有:23、135、137-139、445、1433、3389等等。 
  23端口关闭大法:开始-运行-CMD.net stop telnet; 
  135端口关闭大法:控制面版-管理工具-服务-找到 remote procedure call(rpc)右击-属性-服务状态-禁用,OK; 
  137-138.445端口关闭大法:右击-网上邻居-属性/本地连接 -属性,在microsoft 网络客户端前的小勾去掉, 这就关掉了445。 接着也把 microsoft 网络的文件和打印机共享的小勾也去掉,就关掉了137-138。 
  139端口关闭大法:这个可是大头,我用扫描鸡扫了一次,竟然可以看到用户等信息!139..右点-网上邻居-属性-本地连接-属性,点击 internet协议/(TCP/IP) ,接着点下面的属性,接着点高级。在出现的栏的上端出现IP设置/ DNS/WINS/选项,接着点 WINS,在下下面有NETBIOS设置,把默认改到禁用 TCP/IP上的NETBIOS,确定。搞定139。