问自己今天是否比明天进步了 !

发布新日志

  • Python学习记录

    2013-03-05 22:05:04

    I am learning python  , the following is some problems that I  met 

    one  :
    "cannot interpret character" 

    answer: 

    add code at beginning of  the program  

    "
    import sys
    reload(sys)
    sys.setdefaultencoding( "utf-8" )
    "


     


  • 丰子恺先生学外语的“笨方法

    2012-12-18 13:34:30

    首先:让我们来看看他读外语的“笨法子”。丰子恺对英语、日语都很熟悉,根据他的经验认为:

           我以为要通一国的国语,须学得三种要素,即构成其国语的材料、方法以及其语言的腔调。材料就是“单语”,方法就是“文法”,腔调就是“会话”。我要学得这三种要素,都非用机械的方法而下笨功不可。

           他所说的“单语”,就是我们现在所说的“单词”和生字。在他看来,“‘单语’是一个国语的根底,任凭你何等的聪明,不记单语是绝不能读外文书的,学生们对 于学科要求伴着趣味,但谙记生字极少有趣味可伴,只得劳你费点心了。”他的办法是把所有的生字写成纸牌,放在小匣子里,每天拿出来记诵一遍。然后把已经熟 记掌握的纸牌抽出放在一边,未记熟的放在另一边,以便明天再记诵,直到全部记住,才开始读书,顿觉痛快流畅,趣味甚足。

         丰子恺学外语的“文法”,方法也很特别,他也自称为“笨法子”。他坦率地说:“我不读文法教科书,我的机械的方法是‘对读’。”所谓对读,就是拿一本英文 经典著作和中文版的并列在书桌上,一句一句地对读。不仅经典著作,即使是其他的英文名著和著名译本,他也常拿来对读。长期坚持,即能“积起经验来,便可实 际理解英文的构造和各种词句的腔调。”不过,丰子恺还提醒道:“但对读书的态度当然要非常认真,须一句一字地对斟,不理解的地方不可轻松通过,必须明白了 全句的组织,然后前进。我相信认真地对读几部名著,其功效足可抵得学校中数年的英文教科书。”

            丰子恺所说的“会话”,就是关于外语的腔调的学习。由于当时不像现在有录音带,他也没法到国外,也缺少与外国人共处的语言环境,全靠自己摸索。于是,他所 采取的唯一的办法就是“熟读”。如何熟读?用他自己的话,具体操作是:“我选定了一册良好而完整的会话书,每日熟读一课,超期读完。熟读的办法更笨,说来 也许要惹人笑。我每天自己上一课新书,规定读十遍。计算遍数,用选举开票的方法,每读一遍,用铅笔在书的下端划一笔,便凑成一个字。不过所凑成的不是选举 开票用的‘正’字,而是一个‘讀……’‘讀’字共有二十二笔,故每课共读二十二遍,即生书读十遍,然后第二天温五遍,第三天又温五遍,第四天再温两遍。故 我的旧书中,都有铅笔画成的‘讀’字,每课下面有一个完整的‘讀’字,即表示已经熟读了。这办法有些好处,分四天温习,屡次反复,容易读熟。”

          在不具备各种外语会话的条件下自学外语,他的这种笨法子不失为学外语会话的方法之一。

          接下来,让我们来看看他对于知识学科的书的读法。在丰子恺看来:“我们读史地理化等书,亦无非欲知道事实。凡一种事实,必有一个系统。分门别类,原原本 本,然后成为一册知识学科的书。”因而,他视“把握系统,是读知识学科书籍的第一要点。”具体方法叙述如下:“凡读一书,能处处注意其系统,而在自己的头 脑中分门别类,作成井然的条理。虽未看到书中详细叙事的地方,亦能知道这详叙位在全系统中的哪一门类哪一条之下,及其在全部中重要程度如何。这仿佛在读者 的头脑中画出全书的一览表,我认为这是知识书籍的最良的读法。”

            丰子恺先生刻苦自学俄语的精神更令人敬佩。他开始自学俄语时,已经53岁了。他用得课本是《俄语一月通》。这本书是从日文的“四周间”(即“四星期通”) 翻译过来的。读完了这种课本,他就找一些俄文原著,对照着中译本读起来。使人吃惊的是,他学俄文学了9个月就开始阅读托尔斯泰的长篇小说《战争与和平》的 原著了,全书9个月读完。以后他就动手翻译屠格涅夫的《猎人笔记》,31万字,5个月译完。从开始学俄语到动手译《猎人笔记》,还不到2年呢!而且他当时 还有作画,编书等任务以及种种社会活动。学俄语还是业余的。丰子恺先生学外语,尤其是俄语,既没有老师,也没有完备的教材,全靠自己刻苦钻研,竟能在这么 短的时间内取得这么大的成绩,这不能不令人肃然起敬!

  • Excel中测试用例导入Testlink方法(转,很不错)

    2012-10-17 10:44:09

    感谢贡献者分享给我们!!!                                                                     

    图片还没有完全插入,有时间逐步完善。

    现在我们的测试用例基本都是在excel中撰写的,一些已存在的测试用例大部分也是以excel表格的形式存在的。如何将excel中的测试用例导入到testlink数据库中呢?使用复制和粘贴固然可以,但是那样做确实辛苦并且很低效,现在介绍将excel表格中的数据导入到testlink中的方法。导入的方法分为两步1、制作XML文档2、导入XMl文档

    1.1. 制作XML文档

    Testlink导入数据时只接受*.xml格式的文件,所以第一步要做的是,制作符合testlink格式要求的xml格式的文档,制作方法有两种。下面分别介绍一下

    1.1.1.    制作XML文档方法1

    Step1:首先从testlink中导出一个或多个xml文档,以获得满足testlink要求的XMl格式。如:选择图片浏览,选择export test cases

    Excel中测试用例导入Testlink方法(转,很不错)

           Step2:将导出文件保存。testcases.xml的文件保存。

     

        Step3:打开一个空白表格文档,打开菜单:数据/XML/导入 ,将保本的testcase.xml

    导入

     

     

        Step4:在选择数据放置的位置时,选择现有的工作表的xml列表。下面的表格中添入$A$1,然后确定。

     

        Step5:这样我们可以得到类似下面的文档,在文档的左端是我们设计的用例,主要是namesummarystepsexpected results。右边显示的是该文档的树形格式XML映射。

     

     

       Step6:现在我们可以在这个深成的表格上编辑我们的用例了,在编辑完之后选择令存为*.xml格式就可以了。

       Step7:在保存之后,打开文档档检查一下,文档的格式应与下图类似。这样我们就可以导入了。

     

    1.1.2.    制作XML文档方法二:

    方法一首先是设计好一个模版,在模版上输入数据来保存的。适用于还没有编辑测试用例的情况。那么如果已经把测试用例保存为一个普通的*.xls格式的文档了,该如何导入呢?是不是要复制、粘贴到上面制造好的模版里呢?答案当然是否定的,下面介绍另一种把已存在的.xls文档制作为*.xml文档的方法。

    Step1:从testlink中导出一个满足格式要求的xml文档,和方法1中的方法一样。如果有保存的xml文档了,这步就可以省略了。

    Step2:打开已经编辑好的*.xls的文档,比如打开笔者随便编辑的一个文档

     

    Step3:在表格中选择菜单:数据/XML/XML源,在弹出的框中选择xml映射

     

    Step4:在弹出的对话框中选择添加,找到刚刚保存的testcase.xml的标准格式文档,单击打开。

     

     

    Step5:在弹出的对话框中可以看到我们刚刚添加的映射名称等,点击确定

     

    Step6:这时在文档的右边可以看到刚刚添加的映射源的树形xml格式文档:

     

    Step7:将xml源映射到文档中:

    如想要把下面的命名为1234的列,分别映射namesummarystepsexpectedresults项上。建立映射有两种方法:

    法一:

    点击要映射的项,如点击1;再在选择XML源中的要映射的项,如name;双击概要映射项name。这样就可以把name映射到表格的第一列了。这样依次对summarystepsexpectedresults完成映射操作即可。

    这里要注意的是:每一列的第一行必须为该列名字,名字你可以随便取,但不能是测试用例内容,因为这样的话第一行的测试例将不能被正确的生成。类似于下图。

     

    法二:

    把相应的映射项拖放到相应的要映射的列上去制作映射。如我们可以用鼠标左键点击name,然后把它拖放到1上去,这样也可以完成映射。

     

    如果映射错误了可以在相应的映射项上右键取消。如在name上右键选择取消映射就可以了。

    Step8:把这个表格存为XML格式的文档。

    Step9:打开刚刚制作的XML文档,看看其内容格式是否和我们要求的格式相符。

    1.2. XML格式文档导入到testlink

    上面我们介绍了两种制作满足testlink的格式要求的xml文档的方法,下面我们介绍下如何把文档导入到testlink中:

    Step1:登陆到testlink中,在下拉列表中选择你的测试项目

     

    2.点击import Test Cases),找到刚刚制作的XML文档,将其上传就可以了。

  • 敏捷测试

    2012-10-09 18:03:05

    1.敏捷测试必须有单元测试和自动化测试, 开发人员要参与测试
    2.最好做一个重要的功能列表
    3.不重要的文档不需要写
    4.测试人员进行复杂的业务逻辑测试和UAT测试


  • (转)how to use Mindmanger

    2012-08-27 14:06:44

    MindManager使用说明

            我在《思维导图分享》中介绍了思维导图的一些情况,接下来分享一下我使用MindManager的一些经验和体会。

            MindManager是一款很好实现思维导图的软件,唯一有些遗憾的是它并不是免费的,而且价格还不菲。

            image

            MindManager的官方网站是http://www.mindjet.com,当前最新的版本是MindManager8.0,下面的分享中使用的也是这个版本,官方网站上提供了MindManager的30天试用下载以及一些模板。针对于初学者,官网上提供了一些教程和视频。

     

    初识MindManager

            正确安装好MindManager之后,打开软件,会发现MindManager使用的是和Office 2007同样的Ribbon风格的界面。除了界面上相像之外,MindManager和Office的互操作性非常好,使用习惯也是尽量贴近Office。下图是MindManager的界面。

            image

     

     

            Ribbon界面将常用的功能都列在界面上,方便使用,而且大量的图标的运用,使得即使E文稍差的人也能方便的使用。

            MindManager最常用的操作是Enter,Insert和鼠标的拖曳操作,所以说上手非常快,这也克服了很多人的畏难心理,我能保证大家一个小时就会使用,一周就能成为MindManager的专家级用户。

            image

     

    首次使用

            对于第一次使用MindManager的朋友,强烈建议使用MindManager提供的Interactive Quick Start(快速开始)功能,这个功能通过教学的方式一步一步引导我们熟悉MindManager的各种功能,虽然里面是英文,但都是大白话,基本大家都能看明白,我最初就是通过这个功能来学习使用的。

            实际上,这篇博文是写给实在不想看英文和不愿意使用Interactive Quick Start的朋友看的:)

            Interactive Quick Start功能在软件界面的标签导航栏里面,如下:

    image 

            Tips

            在界面右边的标签导航栏中,提供了一些常用的功能,平时是收缩的,只有当选中标签的时候才弹出页面。下面是各个页面的含义,暂时不需要详细记住,只了解大概即可,甚至不需要了解大概,知道interactive Quick Start在哪找到就行了:)

     

            My Maps:可以将一些常用的思维导图放在这里,类似于快捷方式;

            Map Markers:给思维导图加上一些特性标记,比如进度,紧急程度等等;

            Task Info:对一些任务设置一些信息,比如开始时间,结束时间,负责人,进度等等;

            Map Parts:提供了一些预定义的功能,比如选择一个头脑风暴的结点,它会自动给你加上描述、作者等提示信息供你选择;

            Library:资源库,里面保存一些图标等资源,可以在做思维导图的时候使用。也可以将自己的图标加入里面;

            Search:提供查找功能;

            Learning提供一些学习的资料,我们要使用的快速学习功能就在这个里面;

            Browser:浏览器,在使用MindManager的时候可以使用它来浏览网页,不用再开浏览器了,不过,估计没有多少人会用它来看网页。

     

     

     

     

     

     

     

     

     

            选择“Interactive Quick Start”之后,系统新建教程,如下图:

    image

            在屏幕的左边是练习内容的介绍,右边是练习区,刚开始的时候只有一个叫做“Central Topic”(中心主题)的矩形方块,表示思维导图的主题。选择“Next>>”后直到下面的界面,教程会介绍中心主题:

    image

            由上图可以看到教程介绍了中心主题,以一个“周会”作为主题让我们练习。按照要求输入并按“Next>>”后会继续下个功能的介绍。

            MindManager这种采用边教边练的方式能使我们很快上手这个软件。

            这个教程很简单,一路“Next”下去就可以了,所以不再介绍了,大家可以试一下。

            接下来我使用一个完整的例子来分享一下我的主要使用方法。

     

    案例背景介绍

            在参加公司“管理五环”培训的时候,我们曾经使用了一个策划羽毛球比赛的案例,这个案例比较简单,所以在这里也尝试使用这个案例进行说明。这种项目式的工作在我们的日常工作生活中很常见,所以有一点代表性。同时这篇博文的主题是MindManager的使用,在这个过程中我尽量多使用一些软件的功能和元素。

            我们的虚拟案例是学校要举办一场羽毛球比赛,而我们作为这个项目的负责人,负责这个项目的所有工作。

            我们使用MindManager8来完成这个项目的规划。

     

    新建工程

            在工具栏的左上角依次选择“开始”->“New”->“Default Map”,将建立一个新的思维导图工程,如下图:

    image

     

    Tips

    在新建思维导图中,提供了三种新建的方式:

    Default Map:这个是默认方式,提供了一个标准的思维导图样式;

    From Template or Style:选择模板或者样式,在此基础上新建思维导图。MindManager预先定义了很多模板,例如头脑风暴的模板,会议记录的模板等等,这些模板可以方便我们在类似项目中应用。预先定义的模板是英文的,这点需要注意。当然我们可以将我们自己做的思维导图作为模板保存下来,也可以从网上下载适合我们的模板来应用,在后面的讲解中会讲模板的用法,这里只需要有概念即可。

    Style是思维导图的风格,或者说是样式,Style可以在使用的过程中进行更改,我们同样可以将自己或者网上下载的Style保存下来供使用。在下面的例子里也会讲到Style的使用。

    From Existing Map:从之前的思维导图开始完成本次思维导图,这个比较少用,可以认为是一种自定义的模板。

     

     

     

      

            打开后,在窗体的最中间有个矩形——Central Topic,上面是Ribbon工具栏,右边是标签浏览器,下面是这个思维导图的标签(MindManager可以同时打开多个思维导图文件,使用标签区分),整个界面和Word 2007类似,具体的页面构成就不介绍了,在下面的例子中介绍里面一些工具的用法。

    image

     

     

     

     

     

    增加结点

            在“Central Topic”中输入“羽毛球比赛策划”,然后按键盘的“Insert”键新建一个结点,在里面输入“制定方案”,然后按回车“Enter”确认刚才输入的内容,再按回车“Enter”,将新建一个和刚才结点层次相同的结点,在里面输入“宣传”如下图:

    image   image    image    

    image   image

     

            总结一下:

            选中一个结点,按“Insert”键将建下一级结点,按“Enter”键,若该结点处于输入状态则确认输入的文字,否则将新建和该结点相同级别的结点。

            选中一个结点,按“Delete”键将删除这个结点。

            使用MindManager创建思维导图,就是这么简单。

            通过上面的方法,继续添加结点,直到下面的样子:

    image

     

    更改主题样式

            思维导图的概念是尽量使用图形来表达含义,MindManager也能使用图形来修饰结点。在工具栏上依次选择“Format”->“Format Topic...”,软件弹出选择主题格式的对话框,如下图的有图所示:

    image       image

     

            从对话框中可以看到,软件提供了很多样式,比如我们选择“Custom Image”,选定一副图片,那么在这个结点中能添加这幅图片,如下图:

    image

            还有其他的样式,MindManager几乎都提供了预览图,可以试试他们的不同。

     

    更改Map样式

            前面提到,我们可以在过程中更改思维导图的样式,在工具栏中选择“Format”->“Map Style”,如下图:

    image

     

            弹出下拉窗体,里面用图形描述了每种样式的简图,我们能很容易选择一种样式:

    image

     

            选择一种样式后,思维导图立刻变成下面的样子:

    image

     

    加入备注

            在MindManager中可以为每个节点加入备注,加入备注有两个作用:

            1)对节点进行解释;

            2)在导入到Word中可以成为标题下的正文。

            MindManager提供的备注具有类似于Word的表现形式,可以输入文字、图片、表格等等,而且所有的操作和Word一致。

            在MindManager中选择一个要加入备注的节点,比如选择“编写方案”节点。在工具栏中选择“Home”->“Notes”,在导图的右侧出现Memo编辑区,如下图所示:

    image 

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

            在备注栏中的操作和图标都和Word保持一致,例如我们可以在里面输入以下内容:

    image

     

            输入备注之后,在节点右边会出现备注图标,将鼠标放在该图标上,会出现对备注的提示,点击这个备注图标可以打开或者关闭右边的备注编辑区。

    image

            加入备注,就是这么简单。

     

    加入任务信息

            对于项目,使用思维导图可以做项目计划,在节点中添加相应的任务信息。

            选中一个节点,比如选中“编写方案”,然后在工具栏中选择“Home”->“Task Info”,在思维导图的右边出现任务信息编辑区。

    image

     

            Tips

            下面将几个常用的功能做个介绍:

            Priority:选择重要性,用不同的图标表示;

            Start date:选择任务的开始时间;

            Due date:选择任务的预计完成时间;

            Complete:选择进度;

            Duration:输入工作量;

            Resources:选择资源,比如这个项目分派给谁来完成;

     

     

     

     

     

     

            我们给“编写方案”输入任务信息,在这个节点上会出现一些图标标记这个任务当前的状态,如下图:

    image

     

    加入图标

            对于节点,我们还可以加入一些我们自己定义的标记。在工具栏中选择“Home”->“Icon Markers”,软件提供了一些图标供选择。

    image             

            比如我们可以为“头脑风暴”加入一个图标,表明这个任务的重要性:

    image

     

     

    建立关系

            两个节点之间可能存在着某些关系,例如一个节点是另外一个节点的支撑,或者一个节点要在另一个节点之后进行,我们可以通过一些曲线来标注这些关系。在工具栏中的“Home”->“Relationship”功能能在节点之间建立关系。

            我们上面的例子,“宣传”要在“制定方案”之后进行,我们点击一下“Relationship”按钮,然后选择“宣传”,再选择“制定方案”,MindManager会在两个节点之间建立一个关系:

    image

            通过用鼠标拉动两个黄色的菱形小方块可以调整曲线的弧度。双击曲线,可以设置曲线的颜色、形状、箭头等信息,如下图:

    image     image

     

    加入编号

            可以给节点加上编号,这对于生成Word文档特别有用,先介绍加入编号的方法,后面生成Word文档的时候可以看到相应的效果。

            在工具栏上选择“Format”->“Numbering”,MindManager自动给所有的几点按照创建的先后顺序和层次关系建立编号,加编号的操作和效果如下图所示:

            1)选择编号按钮,点击下拉按钮:

    image

            2)配置数字显示信息,在对话框中选择“Numbering Options...”:

    image

            3)配置数字级别等信息,比如我们可以修改成如下配置:

    image

            4)确定,配置后显示如下:

    image

     

     

     

     

    加入推理图样

            在平时的工作中,我们常常遇到一种情况,几个任务经过汇总,得出一个结论,这种情况使用MindManager也可以很好的表现:

            1)选中一个节点,例如要汇总宣传节点下的三个节点,我们就选中“宣传”节点;

            2)在工具栏上选择“Home”->“Boundary”,然后再选择一个图样,如下图所示:

    image

            3)选择之后,思维导图立刻显示如下样式:

    image

            4)双击“大括号”,弹出对话框,可以设置一些属性:

    image

     

     

     

     

            5)加入说明,在工具栏上选择“Home”->“Callout”,如图:

    image

            最终,效果如下图所示:

    image

     

     

    导出

            MindManager能够将思维导图导出成Word、Pdf、PPT、Excel、网页、Visio、Project、图片等格式,在工具栏的“Export”页上提供了相应的工具按钮。这部分的操作比较简单,一般选择默认即可。

    image

            下面是导出成网页、Word文档和Project文档的例子。

            导出为网页:

    image

     

            导出为Word:

    image

     

     

            导出为Project文档:

    image

     

    添加模板

            MindManager支持添加模板,我们可以将常用的思维导图制成模板,也可以从网上下载成熟的模板使用。

            在工具栏上选择“Tools”->“Map Templates”->“Add New Map Template”。

    image

     

            继续选择“From Existing Template”。

    image

     

            在弹出的对话框中选择一个模板,比如我选择了一个我下载的叫做“项目会议”的一个模板:

    image

     

            安装好这个模板之后可以在新建思维导图的时候选择从模板建立:

    image   image

     

     

     

     

     

            点击“确定”后,MindManager根据模板新建一个思维导图:

    image

  • (转)Android客户端为什么要进行适配测试

    2012-04-16 13:49:22

    Android客户端为什么要进行适配测试

    在正式开始android客户端的适配测试点整理之前,先给大家看几个数据。

    下面是随机抽取某个android客户端在2月份的用户使用情况。

    【Android不同系统版本下的分布情况】

    【客户端在不同手机分辨率下被使用的分布情况】

    【客户端在不同机型中被使用的分布情况】

    从上面的图标,很容易看出:android客户端应用环境之复杂多样。所以在测试过程中,测试用例需要全面覆盖到不同的场景,通过全面的适配测试保证流过我们手中的产品质量OK,上图中不同人群对产品的体验完美。

    二、         Android客户端的适配测试主要从几个方面覆盖

    在测试中:我们需要尽量逼真用户的使用场景、作为产品的第一用户来使用来测试。适配测试:主要是从手机分辨率和系统版本两个方面入口;结合最开始我给大家看的几个图,可以总结出我们在日常测试中的需要覆盖的范围。

    (1)手机分辨率:320*240 、480*320、800*480、854*480、960*540等;

    (2)手机系统覆盖:2.3.*、2.2、4.0;在测试计划中:需要安排单独的时间用于android不同系统的兼容性测试,包括2.0以下版本和 3.*、4.0版本等;

    (3)手机网络:要覆盖到wifi\2G\3G、net\wap、电信\移动\联通, 所有可能的组合进行测试。 


    net  and  wap   是中国移动分的一个网段 ,net  是适用于笔记本,pad 等   

    wap 主要是手机等 主要是资费不一样 , wap 主要支持的协议是 http协议  和 wap 协议 !


       http://www.360doc.com/content/09/1210/23/95778_10830212.shtml

    原则:尽可能全面覆盖用户的使用场景,测试用例中需要包含不同网络排列组合的各种可能;

    (4) 测试用例—跟手机之间的交互性测试点:

    ◆安装、卸载【重复安装与卸载】—-安装、卸载:手机内配置项的写、读、和删除;

    ◆客户端界面在不同大小手机屏幕的展现、横竖屏展现;

    ◆手机控件触发:触屏按钮、滚球、按键;有些情况:在对话框手机系统会自动添加:取消按钮。 要注意取消按钮的测试:有些需要开发进行按钮处理。

    ◆手机事件交互性适配及状态保持:

    后台运行后—–是否记忆当前状态;多程序交叉后台运行;

    断电、中途关机—–是否记忆当前状态;

    闹铃、接电话看短信等—–是否会记忆当前状态,程序能否正常进行;

    待机小段时间、待机很长时间—-是否正常运行,并记忆当前状态

    拔插手机数据线—–对正在使用的客户端的影响中途按手机拍照键、打开手机音乐播放器:比如手机音乐播放器对Android客户端语音搜索的影响;拍照对手机条形码搜索的影响;

    手机快捷键的处理:拨电话键、挂电话键、回退键、home键:客户端在中途使用过程这些键的响应处理。

    三 、 Android客户端除了适配测试外,还有哪些测试范围

    (1)Android应用的测试范围


    (2)   稳定性测试:需要根据应用程序的大小和复杂度来定义稳定性衡量指标;比如:只有一个acitivtiy用于显示hello world的应用,其稳定性和一个复杂应用的稳定性指标是不同的。在确定指标之前,可以先对自己测试的应用进行多次摸底,求平均定义。

    总结自己从事客户端测试的经验如上,望对大家有帮助。


  • 在Eclipse中设置Android模拟器屏幕大小(转)

    2012-04-03 18:19:24

    在Eclipse中设置Android模拟器屏幕大小
    2011-09-07 15:18

    方法一、选择"Android SDK and AVD Manager",选中相应的AVD,

    点击右侧的"Starts the selected AVD"按钮

    如图,在"Screen Size (in)"中填入你需要的屏幕尺寸,然后"Launch",OK

    但是这种方法对我们点击“运行”后的模拟器没有影响。

    方法二、同样选择"Android SDK and AVD Manager",选中相应的AVD,

    点击右侧“Edit”,在"Built-in:"右侧下拉菜单选择相应选项,该方法对我们运行android应用程序时启动的模拟器大小有效。

    方法三、选择“运行配置”,选“Target”标签页,在“Additional Emulator Command Line Options”里填入“-scale 0.8”,后面的数字根据自己需要改变,个人感觉这里应该是对默认模拟器屏幕尺寸的缩放,如果填入"-scale 1",则在运行时模拟器尺寸是默认大小。

    命令行是:emulator -avd android2.2 -scale 0.8 ,要在DOS中进入到C:\Android\android-sdk\tools目录下运行。android2.2是你建立的AVD名称。


    补充:今天偶然看到一片同类的百度博文,里面对屏幕分辨率的分类很详细,这里给出链接

    蜗牛博客:http://hi.baidu.com/ssdate/blog/item/b9ff79a7b9096a8dd043584a.html

    一:Android模拟器大小分类
    1)320×480, portrait : emulator -skin HVGA-P (default)
    2)320×240, landscape: emulator -skin QVGA-L
    3)480×320, landscape: emulator -skin HVGA-L
    4)240×320, portrait : emulator -skin QVGA-P
    5)480*320,WQVGA432
    6)800*480 WVGA800
    7)800*540 WVGA854

    模拟器分辨率收集

    QVGA = 320 * 240;
    WQVGA = 320 * 480;
    WQVGA2 = 400 * 240;
    WQVGA3 = 432 * 240;
    HVGA = 480 * 320;
    VGA = 640 * 480;
    WVGA = 800 * 480;
    WVGA2 = 768 * 480;
    FWVGA = 854 * 480;
    DVGA = 960 * 640;
    PAL = 576 * 520;
    NTSC = 486 * 440;
    SVGA = 800 * 600;
    WSVGA = 1024 * 576;
    XGA = 1024 * 768;
    XGAPLUS = 1152 * 864;
    HD720 = 1280 * 720;
    WXGA = 1280 * 768;
    WXGA2 = 1280 * 800;
    WXGA3 = 1280 * 854;
    SXGA = 1280 * 1024;
    WXGA4 = 1366 * 768;
    SXGAMINUS = 1280 * 960;
    SXGAPLUS = 1400 * 1050;
    WXGAPLUS = 1440 * 900;
    HD900 = 1600 * 900;
    WSXGA = 1600 * 1024;
    WSXGAPLUS = 1680 * 1050;
    UXGA = 1600 * 1200;
    HD1080 = 1920 * 1080;
    QWXGA = 2048 * 1152;
    WUXGA = 1920 * 1200;
    TXGA = 1920 * 1400;
    QXGA = 2048 * 1536;
    WQHD = 2560 * 1440;
    WQXGA = 2560 * 1600;
    QSXGA = 2560 * 2048;
    QSXGAPLUS = 2800 * 2100;
    WQSXGA = 3200 * 2048;
    QUXGA = 3200 * 2400;
    QFHD = 3840 * 2160;
    WQUXGA = 3840 * 2400;
    HD4K = 4096 * 2304;
    HXGA = 4096 * 3072;
    WHXGA = 5120 * 3200;
    HSXGA = 5120 * 4096;
    WHSXGA = 6400 * 4096;
    HUXGA = 6400 * 4800;
    SHV = 7680 * 4320;
    WHUXGA = 7680 * 4800;


    我自己的测试的设备是手机 ,分辨率是800*480 但是我的电脑的最大的分辨率是1366*768 所以就在虚拟机上看不到全屏,所以找方法 ,我用的方法是在doc 窗口下  ,进入 c:/android-sdk-windows/tools然后输入命令 emulator -avd EMC_iptv -scale 0.8  

    这样就同比例的缩小了  !  

  • 压力测试小方法(转)

    2012-02-16 17:58:32

    接口代码开发自己测试完毕后,最后的步骤就是和对端厂商进行压力测试,以便考验代码性能情况(这里面包含了代码,硬件,

    中间件部署等性能的测试)。这个是最烦人的步骤,尤其是你的对端厂商没有测试环境,更是令人闹心,要等到很晚系统本身不

    用的时候进行环境切换,如果测试顺利通过还行,如果不能通过要每晚都加班才能进行测试。一般处理并发量比较大的程序,都

    是通过多路硬件方式并发共同调用一个接口,以达到模拟大规模信息量的处理过程。硬件不是随时都具备的,当然也可以用流行

    的压测框架,但是部署太复杂。无奈之下,自己只好动手写了简单脚本,这里利用主进程里面启动多线程,每个线程里面循环多

    次的原理,也就是不断向自己接口端发送数据请求。代码如下:

      一、主进程代码:

       package bss.intf.thread;

    /**
     * 压测小脚本
     * @author zhangyp
     * @version 2009-02-28
     *
     */
    public class MainControl {
     private static long sucessNum = 1;
     private static long shiNum = 1;

     public static void main(String[] args) {

      int i = 0;
      int num = 100;
      while (i < num) {
       i++;
       ThreadClient client = new ThreadClient();
       client.setNum(i);
       System.out.println("^^^^^^^^^线程" + i + "启动^^^^^^^^^^^^");
       client.start();//启动线程
      }
     }
    }

      二、线程脚本:

    package bss.intf.thread;
    import java.rmi.RemoteException;
    import crmwsi.crm.WSSPortTypeProxy;

    /**
     * @author zhangyp
     * @version 2009-02-28
     */
    public class ThreadClient extends Thread {
     int num;
     public void setNum(int n) {
      this.num = n;
     }

    //在run里面变动业务处理的逻辑
     public void run() {
      int i = 0;
      String accNbr = "18920020202";
      int accNbrType = 4;
      String password = "111";

      int passwordType = 1;
      int encryptFlag = 1;
      String areaCode = "022";

      String channelId = "-10000";
      String staffCode = "-10000";

      String utXml = "";
      while (i < 40) {
       System.out.println("==========第"+ num + "线程里面,第"+ i + "次请求START=======");
       WSSPortTypeProxy proxy = new WSSPortTypeProxy();
       proxy.setEndpoint(
        "http://136.64.44.237:9010/BssCrmWebService/services/CustomerService_B");
       try {
        utXml =
         proxy.checkPassword(
          accNbr,
          accNbrType,
          password,
          passwordType,
          encryptFlag,
          areaCode,
          channelId,
          staffCode);

        System.out.println(" utXml=" + outXml);
        i++;
        System.out.println(
         "***********第" + num + "线程里面,第" + i + "次请求END*****");
       } catch (RemoteException e) {
        System.out.println("ERROR");
        e.printStackTrace();
       }

      }

     }
     public static void main(String[] args) {
     }
    }

      说明:这个是模拟客户端调用webservice的时候的测试脚本,效果很好的。大家也可以对run部分进行修改,我曾经测试过自

    己写的脚本,当线程启动是1000个,每个线程是里面循环100次的时候机器(小型机的配置24个CPU,40G的内存,中间件用的是

    weblogic8.1,数据库 ORACLE9i)就会被压垮(不是机子挂掉,只是很多队列都塞满了,主机进程有死锁的),这时客户端就会

    报超时。未优化应用前,只要启动50个线程,每个线程里面循环10次,客户端就会报告超时。

      相同硬件效果的对比度:一般来说当启动200个线程循环100次,就相当于一秒钟200次业务处理量,也就是基本上可以硬件上

    一秒并发200次的效果,这个是做过测试的,我的客户需要一秒处理60次业务量,未优化前一秒30次都达不到,可是优化我先用

    这个脚本测试通过后,和华为(我的对端厂商,他们一般都用硬件进行压力测)测试后不仅达到他们的要求,而且一秒200次的

    并发量都没有问题

      缺点:没有加载时间,没有统计失败和成功次数,这个用的时候可以自己加上。不能够测试业务处理比较复杂的接口,正在

    改进!大家有好的想法也可以说下哈~!

  • java,激活压力测试 !

    2012-02-16 17:44:08

    激活功能测试代码: 
    package com.jieless.publiclib;
    //import java.rmi.RemoteException;

    import java.io.IOException;
    import java.io.UnsupportedEncodingException;

    import org.apache.http.HttpEntity;
    import org.apache.http.HttpResponse;
    import org.apache.http.HttpStatus;
    import org.apache.http.NameValuePair;
    import org.apache.http.client.ClientProtocolException;
    import org.apache.http.client.CookieStore;
    import org.apache.http.client.HttpClient;
    import org.apache.http.client.entity.UrlEncodedFormEntity;
    import org.apache.http.client.methods.HttpPost;
    import org.apache.http.client.params.ClientPNames;
    import org.apache.http.client.params.CookiePolicy;
    import org.apache.http.entity.mime.MultipartEntity;
    import org.apache.http.entity.mime.content.ContentBody;
    import org.apache.http.entity.mime.content.FileBody;
    import org.apache.http.entity.mime.content.StringBody;
    import org.apache.http.impl.client.DefaultHttpClient;
    import org.apache.http.message.BasicNameValuePair;
    import org.apache.http.protocol.HTTP;                                                                            
    import org.apache.http.util.EntityUtils;

    import android.net.ParseException;

    public class ActivityThreadClient extends Thread  {
    int num;
    public void setNum(int n) {
     this.num = n;
    }
    //在run里面变动业务处理的逻辑
    public void run() {
    int i=0;
    String requestxml="<xmedia>"+
    "<sysInfo>"+
    "<device>test</device>"+
    "<os__arch>test</os__arch>"+
    "<os__name>test</os__name>"+
    "<os__version>test</os__version>"+
    "<sdkVersion>test</sdkVersion>"+
    "<sdkInt>test</sdkInt>"+
    "<codename>test</codename>"+
    "<incremental>test</incremental>"+
    "<release>test</release>"+
    "<model>test</model>"+
    "<product>test</product>"+
    "<language>中文</language>"+
    "<screen>300X200</screen>"+
    "</sysInfo>"+
    "<activationInfo>"+
    "<license>670AB5E2439459FC00DEB7D6E0128ADD</license>"+
    "<hwid>test_" + i * 10+ "</hwid>"+
    "<sequence></sequence>"+
    "</activationInfo>"+
    "</xmedia>";
    String apptype = "xmedia";
     while (i < 10) {
      System.out.println("==========第"+ num + "线程里面,第"+ i + "次请求START=======");
      DefaultHttpClient httpClient = new DefaultHttpClient(); 
    HttpPost httppost = new HttpPost("http://service.wujiecn.com/xservice/deviceActive/active");
    MultipartEntity reqEntity = new MultipartEntity();  
           try {
    reqEntity.addPart("requestxml", new StringBody(requestxml));
    } catch (UnsupportedEncodingException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
           //设置请求  
           httppost.setEntity(reqEntity);  
           //执行  
           HttpResponse response = null;
    try {
    response = httpClient.execute(httppost);
    } catch (ClientProtocolException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
           if(HttpStatus.SC_OK == response.getStatusLine().getStatusCode()){  
               HttpEntity entity = response.getEntity();  
               //显示内容  
               if (entity != null) {  
                   try {
    System.out.println(EntityUtils.toString(entity));
    } catch (ParseException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }  
               }  else{
                System.out.println("Erro");
               }
               if (entity != null) {  
                   try {
    entity.consumeContent();
    } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }  
               }  
           }else{
                System.out.println("Erro");
                }
           
           httpClient.getConnectionManager().shutdown();
     }
     
       i++;
       System.out.println(
        "***********第" + num + "线程里面,第" + i + "次请求END*****");
       
     

     }



     
    /**
    * @param args
    */
    public static void main(String[] args) {

    }

    }


    创建log代码:



    package com.jieless.publiclib;

    import java.io.File;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.OutputStreamWriter;
    import java.io.UnsupportedEncodingException;


    public class CreateLog {

    final String FILENAME = "/PressureTest";
    final String SUFFIX = ".log";
    String foldername = "D:";
    public CreateLog() {

    }

    public void CreateFile() {
    String filename = foldername + FILENAME + SUFFIX;
    File folder = new File(filename);
    if (folder.exists()) {
    folder.delete();
    try {
    folder.createNewFile();
    } catch (IOException e) {
    e.printStackTrace();
    }
    } else if (!folder.exists()) {
    try {
    folder.createNewFile();
    } catch (IOException e) {
    e.printStackTrace();
    }
    }

    }

    public void WriteLog(String sb) {
    String stringToWrite = sb.toString();
    String targetPath = foldername + FILENAME + SUFFIX;
    File targetFile = new File(targetPath);
    if (targetFile != null) {
    OutputStreamWriter osw;
    try {
    osw = new OutputStreamWriter(new FileOutputStream(targetFile,
    true), "utf-8");
    try {
    osw.write(stringToWrite + "\r\n");
    osw.flush();
    osw.close();
    } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    } catch (UnsupportedEncodingException e1) {
    // TODO Auto-generated catch block
    e1.printStackTrace();
    } catch (FileNotFoundException e1) {
    // TODO Auto-generated catch block
    e1.printStackTrace();
    }
    }
    }
    }

    具体详情请参照:附件 !




  • android 测试中用到相关 !

    2012-02-16 15:39:45

    首先android测试会用到adb命令 ! 
    adb是android debug bridge  ! 是pc机和模拟器和设备的桥梁 !  

    方法 : 
    1.把android 的sdk里面tools下的adb.exe 和adbwinapi.dll拷贝到系统盘的windows/system32下面 
    2.在运行下面的输入cmd ,然后adb 就可以了 
    常用的命令 : 

    adb shell  进入能用shell 命令 ,比如  cp ,rm   
    adb install <apk的安装路径>  
    有的适合会出现 没有足够的空间 , 你可以设置一下空间的大小 这个具体的可以查一下  

    adb uninstall  <apk安装路径>  

    adb devices  查看所有的设备   

    android wifi 功能开关命令: 

    adb shell svc wifi enable

    adb shell svc wifi disable



    1. 显示系统中全部Android平台: 

        android list targets 

    2. 显示系统中全部AVD(模拟器): 

        android list avd 

    3. 创建AVD(模拟器): 

        android create avd --name 名称 --target 平台编号 

    4. 启动模拟器: 

        emulator -avd 名称 -sdcard ~/名称.img (-skin 1280x800) 

    5. 删除AVD(模拟器): 

        android delete avd --name 名称 

    6. 创建SDCard: 

        mksdcard 1024M ~/名称.img 

    7. AVD(模拟器)所在位置: 

        Linux(~/.android/avd)      Windows(C:\Documents and Settings\Administrator\.android\avd) 

    8. 启动DDMS: 

        ddms 

    9. 显示当前运行的全部模拟器: 

        adb devices 

    10. 对某一模拟器执行命令: 

          abd -s 模拟器编号 命令 

    11. 安装应用程序: 

          adb install -r 应用程序.apk 

    12. 获取模拟器中的文件: 

          adb pull <remote> <local> 

    13. 向模拟器中写文件: 

          adb push <local> <remote> 

    14. 进入模拟器的shell模式: 

          adb shell 

    15. 启动SDK,文档,实例下载管理器: 

          android 

    16. 缷载apk包: 

          adb shell 

          cd data/app 

          rm apk包 

          exit 

          adb uninstall apk包的主包名 

          adb install -r apk包 

    17. 查看adb命令帮助信息: 

          adb help 

    18. 在命令行中查看LOG信息: 

          adb logcat -s 标签名 

    19. adb shell后面跟的命令主要来自: 

          源码\system\core\toolbox目录和源码\frameworks\base\cmds目录。 

    20. 删除系统应用: 

          adb remount (重新挂载系统分区,使系统分区重新可写)。 

          adb shell 

          cd system/app 

          rm *.apk 

    21. 获取管理员权限: 

          adb root 

    22. 启动Activity: 

          adb shell am start -n 包名/包名+类名(-n 类名,-a action,-d date,-m MIME-TYPE,-c category,-e 扩展数据,等)。 

    23、发布端口: 

        你可以设置任意的端口号,做为主机向模拟器或设备的请求端口。如: 
    adb forward tcp:5555 tcp:8000 

    24、复制文件: 

        你可向一个设备或从一个设备中复制文件, 
         复制一个文件或目录到设备或模拟器上: 
      adb push <source> <destination></destination></source> 
          如:adb push test.txt /tmp/test.txt 
         从设备或模拟器上复制一个文件或目录: 
         adb pull <source> <destination></destination></source> 
         如:adb pull /addroid/lib/libwebcore.so . 

    25、搜索模拟器/设备的实例: 

         取得当前运行的模拟器/设备的实例的列表及每个实例的状态: 
        adb devices 

    26、查看bug报告: 
    adb bugreport 
    27、记录无线通讯日志: 

        一般来说,无线通讯的日志非常多,在运行时没必要去记录,但我们还是可以通过命令,设置记录: 
        adb shell 
        logcat -b radio 

    28、获取设备的ID和序列号: 

         adb get-product 
         adb get-serialno 

    29、访问数据库SQLite3 

         adb shell 
         sqlite3 

    busybox 

    BusyBox 是标准 Linux 工具的一个单个可执行实现。BusyBox 包含了一些简单的工具,例如 cat 和 echo,还包含了一些更大、更复杂的工具,例如 grep、find、mount 以及 telnet。有些人将 BusyBox 称为 Linux 工具里的瑞士军刀.简单的说BusyBox就好像是个大工具箱,它集成压缩了 Linux 的许多工具和命令。 

    1、 BusyBox 的诞生 
      BusyBox 最初是由 Bruce Perens 在 1996 年为 Debian GNU/Linux 安装盘编写的。其目标是在一张软盘上创建一个可引导的 GNU/Linux 系统,这可以用作安装盘和急救盘。 
      2、busybox的用法 
      可以这样用busybox 
      #busybox ls 
      他的功能就相当运行ls命令 
      最常用的用法是建立指向busybox的链接,不同的链接名完成不同的功能. 
      #ln -s busybox ls 
      #ln -s busybox rm 
      #ln -s busybox mkdir 
      然后分别运行这三个链接: 
      #./ls 
      #./rm 
      #./mkdir 
      就可以分别完成了ls rm 和mkdir命令的功能.虽然他们都指向同一个可执行程序busybox,但是只要链接名不同,完成的功能就不同,很多linux网站都提供busybox的源代码下载。 
      3、配置busybox 
      busybox的配置程序和linux内核菜单配置方式简直一模一样.熟悉用make menuconfig方式配置linux内核的朋友很容易上手. 
      #cp busybox-1.00.tar.gz /babylinux 
      #cd /babylinux 
      #tar xvfz busybox-1.00.tar.gz 
      #cd busybox-1.00 
      #make menuconfig 
      下面是需要编译进busybox的功能选项。 
      General Configuration应该选的选项 
      Show verbose applet usage messages 
      Runtime SUID/SGID configuration via /etc/busybox.conf 
      Build Options 
      Build BusyBox as a static binary (no shared libs) 
      这个选项是一定要选择的,这样才能把busybox编译成静态链接的可执行文件,运行时才独立于其他函数库.否则必需要其他库文件才能运行,在单一个linux内核不能使它正常工作. 
      Installation Options 
      Don't use /usr 
      这个选项也一定要选,否则make install 后busybox将安装在原系统的/usr下,这将覆盖掉系统原有的命令.选择这个选项后,make install后会在busybox目录下生成一个叫_install的目录,里面有busybox和指向它的链接. 
      其它选项都是一些linux基本命令选项,自己需要哪些命令就编译进去,一般用默认的就可以了,配置好后退出并保存。 
      4、编译并安装busybox 
      #make 
      #make install 
      编译好后在busybox目录下生成子目录_install,里面的内容: 
      drwxr-xr-x 2 root root 4096 11月 24 15:28 bin 
      rwxrwxrwx 1 root root 11 11月 24 15:28 linuxrc -> bin/busybox 
      drwxr-xr-x 2 root root 4096 11月 24 15:28 sbin 
      其中可执行文件busybox在bin目录下,其他的都是指向他的符号链接. 

    Android系统在超级终端下必会的命令大全(二) 

    一、安装和登录命令 
    reboot 
    1.作用 
    reboot命令的作用是重新启动计算机,它的使用权限是系统管理者。 
    2.格式 
    reboot [-n] [-w] [-d] [-f] [-i] 
    3.主要参数 
    -n: 在重开机前不做将记忆体资料写回硬盘的动作。 
    -w: 并不会真的重开机,只是把记录写到/var/log/wtmp文件里。 
    -d: 不把记录写到/var/log/wtmp文件里(-n这个参数包含了-d)。 
    -i: 在重开机之前先把所有与网络相关的装置停止。 
    mount 
    1.作用 
    mount命令的作用是加载文件系统,它的用权限是超级用户或/etc/fstab中允许的使用者。 
    2.格式 
    mount -a [-fv] [-t vfstype] [-n] [-rw] [-F] device dir 
    3.主要参数 
    -h:显示辅助信息。 
    -v:显示信息,通常和-f用来除错。 
    -a:将/etc/fstab中定义的所有文件系统挂上。 
    -F:这个命令通常和-a一起使用,它会为每一个mount的动作产生一个行程负责执行。在系统需要挂上大量NFS文件系统时可以加快加载的速度。 
    -f:通常用于除错。它会使mount不执行实际挂上的动作,而是模拟整个挂上的过程,通常会和-v一起使用。 
    -t vfstype:显示被加载文件系统的类型。 
    -n:一般而言,mount挂上后会在/etc/mtab中写入一笔资料,在系统中没有可写入文件系统的情况下,可以用这个选项取消这个动作。 
    4.应用技巧 
    在 Linux和Unix系统上,所有文件都是作为一个大型树(以/为根)的一部分访问的。要访问CD-ROM上的文件,需要将CD-ROM设备挂装在文件树中的某个挂装点。如果发行版安装了自动挂装包,那么这个步骤可自动进行。在Linux中,如果要使用硬盘、光驱等储存设备,就得先将它加载,当储存设备挂上了之后,就可以把它当成一个目录来访问。挂上一个设备使用mount命令。在使用mount这个指令时,至少要先知道下列三种信息:要加载对象的文件系统类型、要加载对象的设备名称及要将设备加载到哪个目录下。 
    (1)Linux可以识别的文件系统 
    ◆ Windows 95/98常用的FAT 32文件系统:vfat ; 
    ◆ Win NT/2000 的文件系统:ntfs ; 
    ◆ OS/2用的文件系统:hpfs; 
    ◆ Linux用的文件系统:ext2、ext3; 
    ◆ CD-ROM光盘用的文件系统:iso9660。 
    虽然vfat是指FAT 32系统,但事实上它也兼容FAT 16的文件系统类型。 
    (2)确定设备的名称 
    在Linux中,设备名称通常都存在/dev里。这些设备名称的命名都是有规则的,可以用“推理”的方式把设备名称找出来。例如,/dev/hda1这个 
    IDE设备,hd是Hard Disk(硬盘)的,sd是SCSI Device,fd是Floppy Device(或是Floppy 
    Disk?)。a代表第一个设备,通常IDE接口可以接上4个IDE设备(比如4块硬盘)。所以要识别IDE硬盘的方法分别就是hda、hdb、hdc、 
    hdd。hda1中的“1”代表hda的第一个硬盘分区 
    (partition),hda2代表hda的第二主分区,第一个逻辑分区从hda5开始,依此类推。此外,可以直接检查/var/log/messages文件,在该文件中可以找到计算机开机后系统已辨认出来的设备代号。 
    (3)查找挂接点 
    在决定将设备挂接之前,先要查看一下计算机是不是有个/mnt的空目录,该目录就是专门用来当作挂载点(MountPoint)的目录。建议在/mnt里建几个/mnt/cdrom、/mnt/floppy、/mnt/mo等目录,当作目录的专用挂载点。举例而言,如要挂载下列5个设备,其执行指令可能如下 (假设都是Linux的ext2系统,如果是Windows XX请将ext2改成vfat): 
    软盘 ===>mount -t ext2 /dev/fd0 /mnt/floppy 
    cdrom ===>mount -t iso9660 /dev/hdc /mnt/cdrom 
    SCSI cdrom ===>mount -t iso9660 /dev/sdb /mnt/scdrom 
    SCSI cdr ===>mount -t iso9660 /dev/sdc /mnt/scdr 
    不过目前大多数较新的Linux发行版本(包括红旗 Linux、中软Linux、Mandrake Linux等)都可以自动挂装文件系统,但Red Hat Linux除外。 
    umount 
    1.作用 
    umount命令的作用是卸载一个文件系统,它的使用权限是超级用户或/etc/fstab中允许的使用者。 
    2.格式 
    unmount -a [-fFnrsvw] [-t vfstype] [-n] [-rw] [-F] device dir 
    3.使用说明 
    umount 
    命令是mount命令的逆操作,它的参数和使用方法和mount命令是一样的。Linux挂装CD-ROM后,会锁定CD—ROM,这样就不能用CD- 
    ROM面板上的Eject按钮弹出它。但是,当不再需要光盘时,如果已将/cdrom作为符号链接,请使用umount/cdrom来卸装它。仅当无用户 
    正在使用光盘时,该命令才会成功。该命令包括了将带有当前工作目录当作该光盘中的目录的终端窗口。 
    exit 
    1.作用 
    exit命令的作用是退出系统,它的使用权限是所有用户。 
    2.格式 
    exit 
    3.参数 
    exit命令没有参数,运行后退出系统进入登录界面。 




    -------------------------------------------------------------------------------- 
    作者: ☆-☆    时间: 2010-6-8 11:52 

    Android系统在超级终端下必会的命令大全(三) 
    二、文件处理命令 
    mkdir 
    1.作用 
    mkdir命令的作用是建立名称为dirname的子目录,与MS DOS下的md命令类似,它的使用权限是所有用户。 
    2.格式 
    mkdir [options] 目录名 
    3.[options]主要参数 
    -m, --mode=模式:设定权限,与chmod类似。 
    -p, --parents:需要时创建上层目录;如果目录早已存在,则不当作错误。 
    -v, --verbose:每次创建新目录都显示信息。 
    --version:显示版本信息后离开。 
    4.应用实例 
    在进行目录创建时可以设置目录的权限,此时使用的参数是“-m”。假设要创建的目录名是“tsk”,让所有用户都有rwx(即读、写、执行的权限),那么可以使用以下命令: 
    $ mkdir -m 777 tsk 
    grep 
    1.作用 
    grep命令可以指定文件中搜索特定的内容,并将含有这些内容的行标准输出。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。 
    2.格式 
    grep [options] 
    3.主要参数 
    [options]主要参数: 
    -c:只输出匹配行的计数。 
    -I:不区分大小写(只适用于单字符)。 
    -h:查询多文件时不显示文件名。 
    -l:查询多文件时只输出包含匹配字符的文件名。 
    -n:显示匹配行及行号。 
    -s:不显示不存在或无匹配文本的错误信息。 
    -v:显示不包含匹配文本的所有行。 
    pattern正则表达式主要参数: 
    \:忽略正则表达式中特殊字符的原有含义。 
    ^:匹配正则表达式的开始行。 
    $: 匹配正则表达式的结束行。 
    \:到匹配正则表达式的行结束。 
    [ ]:单个字符,如[A]即A符合要求 。 
    [ - ]:范围,如[A-Z],即A、B、C一直到Z都符合要求 。 
    。:所有的单个字符。 
    * :有字符,长度可以为0。 
    正则表达式是Linux/Unix系统中非常重要的概念。正则表达式(也称为“regex”或“regexp”)是一个可以描述一类字符串的模式(Pattern)。如果一个字符串可以用某个正则表达式来描述,我们就说这个字符和该正则表达式匹配(Match)。这和DOS中用户可以使用通配符 
    “*”代表任意字符类似。在Linux系统上,正则表达式通常被用来查找文本的模式,以及对文本执行“搜索-替换”操作和其它功能。 
    4.应用实例 
    查询DNS服务是日常工作之一,这意味着要维护覆盖不同网络的大量IP地址。有时IP地址会超过2000个。如果要查看nnn.nnn网络地址,但是却忘了第二部分中的其余部分,只知到有两个句点,例如nnn nn..。要抽取其中所有nnn.nnn IP地址,使用[0-9 ]\{3 
    \}\.[0-0\{3\}\。含义是任意数字出现3次,后跟句点,接着是任意数字出现3次,后跟句点。 
    $grep ’[0-9 ]\{3 \}\.[0-0\{3\}\’ ipfile 
    补充说明,grep家族还包括fgrep和egrep。fgrep是fix grep,允许查找字符串而不是一个模式;egrep是扩展grep,支持基本及扩展的正则表达式,但不支持\q模式范围的应用及与之相对应的一些更加规范的模式。 
    dd 
    1.作用 
    dd命令用来复制文件,并根据参数将数据转换和格式化。 
    2.格式 
    dd [options] 
    3.[opitions]主要参数 
    bs=字节:强迫 ibs=及obs=。 
    cbs=字节:每次转换指定的。 
    conv=关键字:根据以逗号分隔的关键字表示的方式来转换文件。 
    count=块数目:只复制指定的输入数据。 
    ibs=字节:每次读取指定的。 
    if=文件:读取内容,而非标准输入的数据。 
    obs=字节:每次写入指定的。 
    of=文件:将数据写入,而不在标准输出显示。 
    seek=块数目:先略过以obs为单位的指定的输出数据。 
    skip=块数目:先略过以ibs为单位的指定的输入数据。 
    4.应用实例 
    dd命令常常用来制作Linux启动盘。先找一个可引导内核,令它的根设备指向正确的根分区,然后使用dd命令将其写入软盘: 
    $ rdev vmlinuz /dev/hda 
    $dd if=vmlinuz of=/dev/fd0 
    上面代码说明,使用rdev命令将可引导内核vmlinuz中的根设备指向/dev/hda,请把“hda”换成自己的根分区,接下来用dd命令将该内核写入软盘。 



    find 
    1.作用 
    find命令的作用是在目录中搜索文件,它的使用权限是所有用户。 
    2.格式 
    find [path][options][expression] 
    path指定目录路径,系统从这里开始沿着目录树向下查找文件。它是一个路径列表,相互用空格分离,如果不写path,那么默认为当前目录。 
    3.主要参数 
    [options]参数: 
    -depth:使用深度级别的查找过程方式,在某层指定目录中优先查找文件内容。 
    -maxdepth levels:表示至多查找到开始目录的第level层子目录。level是一个非负数,如果level是0的话表示仅在当前目录中查找。 
    -mindepth levels:表示至少查找到开始目录的第level层子目录。 
    -mount:不在其它文件系统(如Msdos、Vfat等)的目录和文件中查找。 
    -version:打印版本。 
    [expression]是匹配表达式,是find命令接受的表达式,find命令的所有操作都是针对表达式的。它的参数非常多,这里只介绍一些常用的参数。 
    —name:支持统配符*和?。 
    -atime n:搜索在过去n天读取过的文件。 
    -ctime n:搜索在过去n天修改过的文件。 
    -group grpoupname:搜索所有组为grpoupname的文件。 
    -user 用户名:搜索所有文件属主为用户名(ID或名称)的文件。 
    -size n:搜索文件大小是n个block的文件。 
    -print:输出搜索结果,并且打印。 
    4.应用技巧 
    find命令查找文件的几种方法: 
    (1)根据文件名查找 
    例如,我们想要查找一个文件名是lilo.conf的文件,可以使用如下命令: 
    find / -name lilo.conf 
    find命令后的“/”表示搜索整个硬盘。 
    (2)快速查找文件 
    根据文件名查找文件会遇到一个实际问题,就是要花费相当长的一段时间,特别是大型Linux文件系统和大容量硬盘文件放在很深的子目录中时。如果我们知道了这个文件存放在某个目录中,那么只要在这个目录中往下寻找就能节省很多时间。比如smb.conf文件,从它的文件后缀“.conf”可以判断这是一个配置文件,那么它应该在/etc目录内,此时可以使用下面命令: 
    find /etc -name smb.conf 
    这样,使用“快速查找文件”方式可以缩短时间。 
    (3)根据部分文件名查找方法 
    有时我们知道只某个文件包含有abvd这4个字,那么要查找系统中所有包含有这4个字符的文件可以输入下面命令: 
    find / -name ’*abvd*’ 
    输入这个命令以后,Linux系统会将在/目录中查找所有的包含有abvd这4个字符的文件(其中*是通配符),比如abvdrmyz等符合条件的文件都能显示出来。 
    (4) 使用混合查找方式查找文件 
    find命令可以使用混合查找的方法,例如,我们想在/etc目录中查找大于500000字节,并且在24小时内修改的某个文件,则可以使用-and (与)把两个查找参数链接起来组合成一个混合的查找方式。 
    find /etc -size +500000c -and -mtime +1 
    mv 
    1.作用 
    mv命令用来为文件或目录改名,或者将文件由一个目录移入另一个目录中,它的使用权限是所有用户。该命令如同DOS命令中的ren和move的组合。 
    2.格式 
    mv[options] 源文件或目录 目标文件或目录 
    3.[options]主要参数 
    -i:交互方式操作。如果mv操作将导致对已存在的目标文件的覆盖,此时系统询问是否重写,要求用户回答“y”或“n”,这样可以避免误覆盖文件。 
    -f:禁止交互操作。mv操作要覆盖某个已有的目标文件时不给任何指示,指定此参数后i参数将不再起作用。 
    4.应用实例 
    (1)将/usr/cbu中的所有文件移到当前目录(用“.”表示)中: 
    $ mv /usr/cbu/ * . 
    (2)将文件cjh.txt重命名为wjz.txt: 
    $ mv cjh.txt wjz.txt  
    ls 
    1.作用 
    ls命令用于显示目录内容,类似DOS下的dir命令,它的使用权限是所有用户。 
    2.格式 
    ls [options][filename] 
    3.options主要参数 
    -a, --all:不隐藏任何以“.” 字符开始的项目。 
    -A, --almost-all:列出除了“ . ”及 “.. ”以外的任何项目。 
    --author:印出每个文件著作者。 
    -b, --escape:以八进制溢出序列表示不可打印的字符。 
    --block-size=大小:块以指定的字节为单位。 
    -B, --ignore-backups:不列出任何以 ~ 字符结束的项目。 
    -f:不进行排序,-aU参数生效,-lst参数失效。 
    -F, --classify:加上文件类型的指示符号 (*/=@| 其中一个)。 
    -g:like -l, but do not list owner。 
    -G, --no-group:inhibit display of group information。 
    -i, --inode:列出每个文件的inode号。 
    -I, --ignore=样式:不印出任何符合Shell万用字符的项目。 
    -k:即--block-size=1K。 
    -l:使用较长格式列出信息。 
    -L, --dereference:当显示符号链接的文件信息时,显示符号链接所指示的对象,而并非符号链接本身的信息。 
    -m:所有项目以逗号分隔,并填满整行行宽。 
    -n, --numeric-uid-gid:类似-l,但列出UID及GID号。 
    -N, --literal:列出未经处理的项目名称,例如不特别处理控制字符。 
    -p, --file-type:加上文件类型的指示符号 (/=@| 其中一个)。 
    -Q, --quote-name:将项目名称括上双引号。 
    -r, --reverse:依相反次序排列。 
    -R, --recursive:同时列出所有子目录层。 
    -s, --size:以块大小为序。 
    4.应用举例 
    ls 
    命令是Linux系统使用频率最多的命令,它的参数也是Linux命令中最多的。使用ls命令时会有几种不同的颜色,其中蓝色表示是目录,绿色表示是可执 
    行文件,红色表示是压缩文件,浅蓝色表示是链接文件,加粗的黑色表示符号链接,灰色表示是其它格式文件。ls最常使用的是ls- l。 
    文 
    件类型开头是由10个字符构成的字符串。其中第一个字符表示文件类型,它可以是下述类型之一:-(普通文件)、d(目录)、l(符号链接)、b(块设备文件)、c(字符设备文件)。后面的9个字符表示文件的访问权限,分为3组,每组3位。第一组表示文件属主的权限,第二组表示同组用户的权限,第三组表示其他用户的权限。每一组的三个字符分别表示对文件的读(r)、写(w)和执行权限(x)。对于目录,表示进入权限。s表示当文件被执行时,把该文件的UID 或GID赋予执行进程的UID(用户ID)或GID(组ID)。t表示设置标志位(留在内存,不被换出)。如果该文件是目录,那么在该目录中的文件只能被超级用户、目录拥有者或文件属主删除。如果它是可执行文件,那么在该文件执行后,指向其正文段的指针仍留在内存。这样再次执行它时,系统就能更快地装入该文件。接着显示的是文件大小、生成时间、文件或命令名称。 
    Android系统在超级终端下必会的命令大全(四) 
    diff 
    1.作用 
    diff命令用于两个文件之间的比较,并指出两者的不同,它的使用权限是所有用户。 
    2.格式 
    diff [options] 源文件 目标文件 
    3.[options]主要参数 
    -a:将所有文件当作文本文件来处理。 
    -b:忽略空格造成的不同。 
    -B:忽略空行造成的不同。 
    -c:使用纲要输出格式。 
    -H:利用试探法加速对大文件的搜索。 
    -I:忽略大小写的变化。 
    -n --rcs:输出RCS格式。 
    cmp 
    1.作用 
    cmp(“compare”的缩写)命令用来简要指出两个文件是否存在差异,它的使用权限是所有用户。 
    2.格式 
    cmp[options] 文件名 
    3.[options]主要参数 
    -l: 将字节以十进制的方式输出,并方便将两个文件中不同的以八进制的方式输出。 
    cat 
    1.作用 
    cat(“concatenate”的缩写)命令用于连接并显示指定的一个和多个文件的有关信息,它的使用权限是所有用户。 
    2.格式 
    cat [options] 文件1 文件2…… 
    3.[options]主要参数 
    -n:由第一行开始对所有输出的行数编号。 
    -b:和-n相似,只不过对于空白行不编号。 
    -s:当遇到有连续两行以上的空白行时,就代换为一行的空白行。 
    4.应用举例 
    (1)cat命令一个最简单的用处是显示文本文件的内容。例如,我们想在命令行看一下README文件的内容,可以使用命令: 
    $ cat README  
    (2)有时需要将几个文件处理成一个文件,并将这种处理的结果保存到一个单独的输出文件。cat命令在其输入上接受一个或多个文件,并将它们作为一个单独的文件打印到它的输出。例如,把README和INSTALL的文件内容加上行号(空白行不加)之后,将内容附加到一个新文本文件File1 中: 
    $ cat README INSTALL File1 
    (3)cat 还有一个重要的功能就是可以对行进行编号。这种功能对于程序文档的编制,以及法律和科学文档的编制很方便,打印在左边的行号使得参考文档的某一部分变得容易,这些在编程、科学研究、业务报告甚至是立法工作中都是非常重要的。对行进行编号功能有-b(只能对非空白行进行编号)和-n(可以对所有行进行编号)两个参数: 
    $ cat -b /etc/named.conf 
    ln 
    1.作用 
    ln命令用来在文件之间创建链接,它的使用权限是所有用户。 
    2.格式 
    ln [options] 源文件 [链接名] 
    3.参数 
    -f:链结时先将源文件删除。 
    -d:允许系统管理者硬链结自己的目录。 
    -s:进行软链结(Symbolic Link)。 
    -b:将在链结时会被覆盖或删除的文件进行备份。 
    链接有两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link)。默认情况下,ln命令产生硬链接。硬连接指通过索引节点来进行的连接。在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(InodeIndex)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种连接就是硬连接。硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬连接到重要文件,以防止“误删”的功能。其原因如上所述,因为对应该目录的索引节点有一个以上的连接。只删除一个连接并不影响索引节点本身和其它的连接,只有当最后一个连接被删除后,文件的数据块及目录的连接才会被释放。也就是说,文件才会被真正删除。与硬连接相对应,Lnux系统中还存在另一种连接,称为符号连接(Symbilc Link),也叫软连接。软链接文件有点类似于Windows的快捷方式。它实际上是特殊文件的一种。在符号连接中,文件实际上是一个文本文件,其中包含的有另一文件的位置信息。 
    -------------------------------------------------------------------------------- 
    作者: ☆-☆    时间: 2010-6-8 11:55 

    本帖最后由 ☆-☆ 于 2010-6-8 11:59 编辑 

    Android系统在超级终端下必会的命令大全(五) 
    系统管理命令 
    df 
    1.作用 
    df命令用来检查文件系统的磁盘空间占用情况,使用权限是所有用户。 
    2.格式 
    df [options] 
    3.主要参数 
    -s:对每个Names参数只给出占用的数据块总数。 
    -a:递归地显示指定目录中各文件及子目录中各文件占用的数据块数。若既不指定-s,也不指定-a,则只显示Names中的每一个目录及其中的各子目录所占的磁盘块数。 
    -k:以1024字节为单位列出磁盘空间使用情况。 
    -x:跳过在不同文件系统上的目录不予统计。 
    -l:计算所有的文件大小,对硬链接文件则计算多次。 
    -i:显示inode信息而非块使用量。 
    -h:以容易理解的格式印出文件系统大小,例如136KB、254MB、21GB。 
    -P:使用POSIX输出格式。 
    -T:显示文件系统类型。 
    4.说明 
    df 命令被广泛地用来生成文件系统的使用统计数据,它能显示系统中所有的文件系统的信息,包括总容量、可用的空闲空间、目前的安装点等。超级权限用户使用df 命令时会发现这样的情况:某个分区的容量超过了100%。这是因为Linux系统为超级用户保留了10%的空间,由其单独支配。也就是说,对于超级用户而言,他所见到的硬盘容量将是110%。这样的安排对于系统管理而言是有好处的,当硬盘被使用的容量接近100%时系统管理员还可以正常工作。 
    5.应用实例 
    Linux支持的文件系统非常多,包括JFS、ReiserFS、ext、ext2、ext3、ISO9660、XFS、Minx、vfat、MSDOS等。使用df -T命令查看磁盘空间时还可以得到文件系统的信息: 
    #df -T 
    文件系统 类型 容量 已用 可用 已用% 挂载点 
    /dev/hda7 reiserfs 5.2G 1.6G 3.7G 30% / 
    /dev/hda1 vfat 2.4G 1.6G 827M 66% /windows/C 
    /dev/hda5 vfat 3.0G 1.7G 1.3G 57% /windows/D 
    /dev/hda9 vfat 3.0G 2.4G 566M 82% /windows/E 
    /dev/hda10 NTFS 3.2G 573M 2.6G 18% /windows/F 
    /dev/hda11 vfat 1.6G 1.5G 23M 99% /windows/G 
    从上面除了可以看到磁盘空间的容量、使用情况外,分区的文件系统类型、挂载点等信息也一览无遗。 
    top 
    1.作用 
    top命令用来显示执行中的程序进程,使用权限是所有用户。 
    2.格式 
    top [-] [d delay] [q] [c] [S] [n] 
    3.主要参数 
    d:指定更新的间隔,以秒计算。 
    q:没有任何延迟的更新。如果使用者有超级用户,则top命令将会以最高的优先序执行。 
    c:显示进程完整的路径与名称。 
    S:累积模式,会将己完成或消失的子行程的CPU时间累积起来。 
    s:安全模式。 
    i:不显示任何闲置(Idle)或无用(Zombie)的行程。 
    n:显示更新的次数,完成后将会退出top。 
    4.说明 
    top命令是Linux系统管理的一个主要命令,通过它可以获得许多信息。 
    下面列出了详细解释。 
    PID(Process ID):进程标示号。 
    USER:进程所有者的用户名。 
    PR:进程的优先级别。 
    NI:进程的优先级别数值。 
    VIRT:进程占用的虚拟内存值。 
    RES:进程占用的物理内存值。 
    SHR:进程使用的共享内存值。 
    S:进程的状态,其中S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值是负数。 
    %CPU:该进程占用的CPU使用率。 
    %MEM:该进程占用的物理内存和总内存的百分比。 
    TIME+:该进程启动后占用的总的CPU时间。 
    Command:进程启动的启动命令名称,如果这一行显示不下,进程会有一个完整的命令行。 
    top命令使用过程中,还可以使用一些交互的命令来完成其它参数的功能。这些命令是通过快捷键启动的。 
    :立刻刷新。 
    P:根据CPU使用大小进行排序。 
    T:根据时间、累计时间排序。 
    q:退出top命令。 
    m:切换显示内存信息。 
    t:切换显示进程和CPU状态信息。 
    c:切换显示命令名称和完整命令行。 
    M:根据使用内存大小进行排序。 
    W:将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。 
    可以看到,top命令是一个功能十分强大的监控系统的工具,对于系统管理员而言尤其重要。但是,它的缺点是会消耗很多系统资源。 


    free 
    1.作用 
    free命令用来显示内存的使用情况,使用权限是所有用户。 
    2.格式 
    free [-b|-k|-m] [-o] [-s delay] [-t] [-V] 
    3.主要参数 
    -b -k -m:分别以字节(KB、MB)为单位显示内存使用情况。 
    -s delay:显示每隔多少秒数来显示一次内存使用情况。 
    -t:显示内存总和列。 
    -o:不显示缓冲区调节列。 
    4.应用实例 
    free命令是用来查看内存使用情况的主要命令。和top命令相比,它的优点是使用简单,并且只占用很少的系统资源。通过-S参数可以使用free命令不间断地监视有多少内存在使用,这样可以把它当作一个方便实时监控器。 
    #free -b -s5 
    使用这个命令后终端会连续不断地报告内存使用情况(以字节为单位),每5秒更新一次。 

    chown 
    1.作用 
    更改一个或多个文件或目录的属主和属组。使用权限是超级用户。 
    2.格式 
    chown [选项] 用户或组 文件 
    3.主要参数 
    --dereference:受影响的是符号链接所指示的对象,而非符号链接本身。 
    -h, --no-dereference:会影响符号链接本身,而非符号链接所指示的目的地(当系统支持更改符号链接的所有者,此选项才有效)。 
    --from=目前所有者:目前组只当每个文件的所有者和组符合选项所指定的,才会更改所有者和组。其中一个可以省略,这已省略的属性就不需要符合原有的属性。 
    -f, --silent, --quiet:去除大部分的错误信息。 
    -R, --recursive:递归处理所有的文件及子目录。 
    -v, --verbose:处理任何文件都会显示信息。 
    4.说明 
    chown 将指定文件的拥有者改为指定的用户或组,用户可以是用户名或用户ID;组可以是组名或组ID;文件是以空格分开的要改变权限的文件列表,支持通配符。系统管理员经常使用chown命令,在将文件拷贝到另一个用户的目录下以后,让用户拥有使用该文件的权限。 
    5.应用实例 
    1.把文件shiyan.c的所有者改为wan 
    $ chown wan shiyan.c 
    2.把目录/hi及其下的所有文件和子目录的属主改成wan,属组改成users。 
    $ chown - R wan.users /hi 
    chattr 
    1.作用 
    修改ext2和ext3文件系统属性(attribute),使用权限超级用户。 
    2.格式 
    chattr [-RV] [-+=AacDdijsSu] [-v version] 文件或目录 
    3.主要参数 
    -R:递归处理所有的文件及子目录。 
    -V:详细显示修改内容,并打印输出。 
    -:失效属性。 
    +:激活属性。 
    = :指定属性。 
    A:Atime,告诉系统不要修改对这个文件的最后访问时间。 
    S:Sync,一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘。 
    a:Append Only,系统只允许在这个文件之后追加数据,不允许任何进程覆盖或截断这个文件。如果目录具有这个属性,系统将只允许在这个目录下建立和修改文件,而不允许删除任何文件。 
    i:Immutable,系统不允许对这个文件进行任何的修改。如果目录具有这个属性,那么任何的进程只能修改目录之下的文件,不允许建立和删除文件。 
    D:检查压缩文件中的错误。 
    d:No dump,在进行文件系统备份时,dump程序将忽略这个文件。 
    C:Compress,系统以透明的方式压缩这个文件。从这个文件读取时,返回的是解压之后的数据;而向这个文件中写入数据时,数据首先被压缩之后才写入磁盘。 
    s:Secure Delete,让系统在删除这个文件时,使用0填充文件所在的区域。 
    u:Undelete,当一个应用程序请求删除这个文件,系统会保留其数据块以便以后能够恢复删除这个文件。 
    4.说明 
    chattr 
    命令的作用很大,其中一些功能是由Linux内核版本来支持的,如果Linux内核版本低于2.2,那么许多功能不能实现。同样-D检查压缩文件中的错误 
    的功能,需要2.5.19以上内核才能支持。另外,通过chattr命令修改属性能够提高系统的安全性,但是它并不适合所有的目录。chattr命令不能 
    保护/、/dev、/tmp、/var目录。 
    5.应用实例 
    1.恢复/root目录,即子目录的所有文件 
    # chattr -R +u/root 
    2.用chattr命令防止系统中某个关键文件被修改 
    在Linux下,有些配置文件(passwd ,fatab)是不允许任何人修改的,为了防止被误删除或修改,可以设定该文件的“不可修改位(immutable)”,命令如下: 
    # chattr +i /etc/fstab 
    ps 
    1.作用 
    ps显示瞬间进程 (process) 的动态,使用权限是所有使用者。 
    2.格式 
    ps [options] [--help] 
    3.主要参数 
    ps的参数非常多, 此出仅列出几个常用的参数。 
    -A:列出所有的进程。 
    -l:显示长列表。 
    -m:显示内存信息。 
    -w:显示加宽可以显示较多的信息。 
    -e:显示所有进程。 
    a:显示终端上的所有进程,包括其它用户的进程。 
    -au:显示较详细的信息。 
    -aux:显示所有包含其它使用者的进程。 
    4.说明 
    要 
    对进程进行监测和控制,首先要了解当前进程的情况,也就是需要查看当前进程。ps命令就是最基本、也是非常强大的进程查看命令。使用该命令可以确定有哪些 
    进程正在运行、运行的状态、进程是否结束、进程有没有僵尸、哪些进程占用了过多的资源等。图2给出了ps-aux命令详解。大部分信息都可以通过执行该命 
    令得到。最常用的三个参数是u、a、x。下面就结合这三个参数详细说明ps命令的作用:ps aux 
    图2 ps-aux命令详解 
    图2第2行代码中,USER表示进程拥有者;PID表示进程标示符;%CPU表示占用的CPU使用率;%MEM占用的物理内存使用率;VSZ表示占用的虚拟内存大小;RSS为进程占用的物理内存值;TTY为终端的次要装置号码。 
    STAT 
    表示进程的状态,其中D为不可中断的静止(I/O动作);R正在执行中;S静止状态;T暂停执行;Z不存在,但暂时无法消除;W没有足够的内存分页可分 
    配;高优先序的进程;N低优先序的进程;L有内存分页分配并锁在内存体内 (实时系统或 
    I/O)。START为进程开始时间。TIME为执行的时间。COMMAND是所执行的指令。 
    4.应用实例 
    在进行系统维护时,经常会出现内存使用量惊人,而又不知道是哪一个进程占用了大量进程的情况。除了可以使用top命令查看内存使用情况之外,还可以使用下面的命令: 
    ps aux | sort +5n 
    -------------------------------------------------------------------------------- 
    作者: ☆-☆    时间: 2010-6-8 11:58 

    Android系统在超级终端下必会的命令大全(十) 
    六、其他命令 
    tar 
    1.作用 
    tar命令是Unix/Linux系统中备份文件的可靠方法,几乎可以工作于任何环境中,它的使用权限是所有用户。 
    2.格式 
    tar [主选项+辅选项] 文件或目录 
    3.主要参数 
    使用该命令时,主选项是必须要有的,它告诉tar要做什么事情,辅选项是辅助使用的,可以选用。 
    主选项: 
    -c 创建新的档案文件。如果用户想备份一个目录或是一些文件,就要选择这个选项。 
    -r 把要存档的文件追加到档案文件的未尾。例如用户已经做好备份文件,又发现还有一个目录或是一些文件忘记备份了,这时可以使用该选项,将忘记的目录或文件追加到备份文件中。 
    -t 列出档案文件的内容,查看已经备份了哪些文件。 
    -u 更新文件。就是说,用新增的文件取代原备份文件,如果在备份文件中找不到要更新的文件,则把它追加到备份文件的最后。 
    -x 从档案文件中释放文件。 
    辅助选项: 
    -b 该选项是为磁带机设定的,其后跟一数字,用来说明区块的大小,系统预设值为20(20×512 bytes)。 
    -f 使用档案文件或设备,这个选项通常是必选的。 
    -k 保存已经存在的文件。例如把某个文件还原,在还原的过程中遇到相同的文件,不会进行覆盖。 
    -m 在还原文件时,把所有文件的修改时间设定为现在。 
    -M 创建多卷的档案文件,以便在几个磁盘中存放。 
    -v 详细报告tar处理的文件信息。如无此选项,tar不报告文件信息。 
    -w 每一步都要求确认。 
    -z 用gzip来压缩/解压缩文件,加上该选项后可以将档案文件进行压缩,但还原时也一定要使用该选项进行解压缩。 
    4.应用说明 
    tar 是Tape Archive(磁带归档)的缩写,最初设计用于将文件打包到磁带上。如果下载过Linux的源代码,或许已经碰到过tar文件 
    请注意,不要忘了Linux是区分大小写的。例如,tar命令应该总是以小写的形式执行。命令行开关可以是大写、小写或大小写的混合。例如,-t和-T执行不同的功能。文件或目录名称可以混合使用大小写,而且就像命令和命令行开关一样是区分大小写的。 
    5.应用实例 
    tar是一个命令行的工具,没有图形界面。使用Konsole打开一个终端窗口,接下来是一个简单的备份命令(在/temp目录中创建一个back.tar的文件,/usr目录中所有内容都包含在其中。): 
    $tar cvf - /usr > /temp/back.tar 
    另 
    外,tar命令支持前面第三讲中讲过的crontab命令,可以用crontab工具设置成基于时间的有规律地运行。例如,每晚6点把/usr目录备份到 
    hda—第一个IDE接口的主驱动器 (总是位于第一个硬盘)中,只要将下面语句添加到root的crontab中即可: 
    $00 06 * * * tar cvf /dev/hda1/usrfiles.tar - /usr 
    一般情况下,以下这些目录是需要备份的: 
    ◆/etc 包含所有核心配置文件,其中包括网络配置、系统名称、防火墙规则、用户、组,以及其它全局系统项。 
    ◆ /var 包含系统守护进程(服务)所使用的信息,包括DNS配置、DHCP租期、邮件缓冲文件、HTTP服务器文件、dB2实例配置等。 
    ◆/home 包含所有默认用户的主目录,包括个人设置、已下载的文件和用户不希望失去的其它信息。 
    ◆/root 根(root)用户的主目录。 
    ◆/opt 是安装许多非系统文件的地方。IBM软件就安装在这里。OpenOffice、JDK和其它软件在默认情况下也安装在这里。 
    有些目录是可以不备份的: 
    ◆ /proc 应该永远不要备份这个目录。它不是一个真实的文件系统,而是运行内核和环境的虚拟化视图,包括诸如/proc/kcore这样的文件,这个文件是整个运行内存的虚拟视图。备份这些文件只是在浪费资源。 
    ◆/dev 包含硬件设备的文件表示。如果计划还原到一个空白的系统,就可以备份/dev。然而,如果计划还原到一个已安装的Linux 系统,那么备份/dev是没有必要的。 
    unzip 
    1.作用 
    unzip 
    命令位于/usr/bin目录中,它们和MS DOS下的pkzip、pkunzip及MS 
    Windows中的Winzip软件功能一样,将文件压缩成.zip文件,以节省硬盘空间,当需要的时候再将压缩文件用unzip命令解开。该命令使用权 
    限是所有用户。 
    2.格式 
    unzip [-cflptuvz][-agCjLMnoqsVX][-P ][.zip文件][文件][-d ][-x ] 
    3.主要参数 
    -c:将解压缩的结果显示到屏幕上,并对字符做适当的转换。 
    -f:更新现有的文件。 
    -l:显示压缩文件内所包含的文件。 
    -p:与-c参数类似,会将解压缩的结果显示到屏幕上,但不会执行任何的转换。 
    -t:检查压缩文件是否正确。 
    -u:与-f参数类似,但是除了更新现有的文件外,也会将压缩文件中的其它文件解压缩到目录中。 
    -v:执行是时显示详细的信息。 
    -z:仅显示压缩文件的备注文字。 
    -a:对文本文件进行必要的字符转换。 
    -b:不要对文本文件进行字符转换。 
    -C:压缩文件中的文件名称区分大小写。 
    -j:不处理压缩文件中原有的目录路径。 
    -L:将压缩文件中的全部文件名改为小写。 
    -M:将输出结果送到more程序处理。 
    -n:解压缩时不要覆盖原有的文件。 
    -o:不必先询问用户,unzip执行后覆盖原有文件。 
    -P:使用zip的密码选项。 
    -q:执行时不显示任何信息。 
    -s:将文件名中的空白字符转换为底线字符。 
    -V:保留VMS的文件版本信息。 
    -X:解压缩时同时回存文件原来的UID/GID。 
    [.zip文件]:指定.zip压缩文件。 
    [文件]:指定要处理.zip压缩文件中的哪些文件。 
    -d:指定文件解压缩后所要存储的目录。 
    -x:指定不要处理.zip压缩文件中的哪些文件。 
    -Z unzip:-Z等于执行zipinfo指令。在Linux中,还提供了一个叫zipinfo的工具,能够察看zip压缩文件的详细信息。 
    gunzip 
    1.作用 
    gunzip命令作用是解压文件,使用权限是所有用户。 
    2.格式 
    gunzip [-acfhlLnNqrtvV][-s ][文件...] 
    或者 
    gunzip [-acfhlLnNqrtvV][-s ][目录] 
    3.主要参数 
    -a或--ascii:使用ASCII文字模式。 
    -c或--stdout或--to-stdout:把解压后的文件输出到标准输出设备。 
    -f或-force:强行解开压缩文件,不理会文件名称或硬连接是否存在,以及该文件是否为符号连接。 
    -h或--help:在线帮助。 
    -l或--list:列出压缩文件的相关信息。 
    -L或--license:显示版本与版权信息。 
    -n或--no-name:解压缩时,若压缩文件内含有原来的文件名称及时间戳记,则将其忽略不予处理。 
    -N或--name:解压缩时,若压缩文件内含有原来的文件名称及时间戳记,则将其回存到解开的文件上。 
    -q或--quiet:不显示警告信息。 
    -r或--recursive:递归处理,将指定目录下的所有文件及子目录一并处理。 
    -S或--suffix:更改压缩字尾字符串。 
    -t或--test:测试压缩文件是否正确无误。 
    -v或--verbose:显示指令执行过程。 
    -V或--version:显示版本信息。 
    4.说明 
    gunzip是个使用广泛的解压缩程序,它用于解开被gzip压缩过的文件,这些压缩文件预设最后的扩展名为“.gz”。事实上,gunzip就是gzip的硬连接,因此不论是压缩或解压缩,都可通过gzip指令单独完成。gunzip最新版本是1.3.3 。
  • android自动化测试相关的学习资料下载 !

    2012-02-16 10:49:02

    1.定义

    robotium 是基于android软件的功能测试的自动化框架工具 ,可以通过框架里面的函数进行自动化测试 !

    2.相关网站:

    Android自动化测试

    1、安装JDK 6、Android SDK 2.3

     

    2、安装Eclipse 3.5.2、ADT8.0.1
    https://dl-ssl.google.com/android/eclipse/

     

    3、HelloAndroid
    E:\Program Files\Android\android-sdk-windows\docs\resources\tutorials\hello-world.html

     

    4、Android UnitTest
    hello testing:
    E:\Program Files\Android\android-sdk-windows\docs\resources\tutorials\testing\helloandroid_test.html

    Activity testing:
    E:\Program Files\Android\android-sdk-windows\docs\resources\tutorials\testing\activity_test.html

     

    5、Robotium
    Tutorial:
    D:\Android\robotium\RobotiumForBeginners.pdf
    http://code.google.com/p/robotium/wiki/Getting_Started

    example:
    http://wiebe-elsinga.com/blog/?p=300
    D:\Android\robotium\ExampleTestProject_v2.0.zip

    Robotium API帮助文档:
    robotium-solo-2.0.2-javadoc

     

    6、Monkey
    UI/Application Exerciser Monkey
    E:\Program Files\Android\android-sdk-windows\docs\guide\developing\tools\monkey.html

    monkey源代码:
    http://fanfq.javaeye.com/blog/781694
    Android SDK源代码:
    http://www.oschina.net/code/explore/android-2.2-froyo

     

    7、MonkeyRunner
    E:\Program Files\Android\android-sdk-windows\docs\guide\developing\tools\monkeyrunner_concepts.html

     

    8、adb shell sendevent
    http://blog.csdn.net/roger_ge/archive/2010/05/03/5552740.aspx


    9、辅助工具
    hierarchyviewer
    ddms
    adb

     

     

     

    -------------------------------------------------------------------------------------------------------------

     

     

     

    Android相关测试工具:

    robotium:
    http://code.google.com/p/robotium/

    autoAndroid:
    http://code.google.com/p/autoandroid/

    Android Scripting Environment:
    http://code.google.com/p/android-scripting/

     

    BSQUARE TestQuest CountDown and TestQuest Pro:
    http://www.bsquare.com/automated-testing-tools.aspx

    Jamo:
    http://www.jamosolutions.com/documents/android.html

    Test Automation for Smart Devices - Mobile Test Automation:
    http://www.deviceanywhere.com/mobile-application-testing-smart-devices.html

    QTP+SeeTest:
    http://experitest.com/download/
    http://experitest.com/support/tutorial/how-to/set-up-new-project/connect-an-external-device-e-g-android/
    http://www.advancedqtp.com/knowledge-base/articles/environment-techniques-id15/mobile-id777/test-android-with-qtp/


     

     

    ---------------------------------------------------------------------------------------------------------------------------

     

     

    测试手段1: CTS

    用来确保某设备符合Android兼容性规范。
     

     

    测试手段2: Monkey


    1) 应用程序的开发者可以测试自己应用的鲁棒性。

    [鲁棒是Robust的音译,也就是健壮和强壮的意思。
    鲁棒性(robustness)就是系统的健壮性。它是在异常和危险情况下系统生存的关键。比如说,计算机软件在输入错误、磁盘故障、网络过载或有意攻击情况下,能否不死机、不崩溃,就是该软件的鲁棒性。所谓“鲁棒性”,是指控制系统在一定(结构,大小)的参数摄动下,维持某些性能的特性。根据对性能的不同定义,可分为稳定鲁棒性和性能鲁棒性。以闭环系统的鲁棒性作为目标设计得到的固定控制器称为鲁棒控制器。 ]

    2) 设备制造商可以使用猴子对自己的设配施行压力测试。看设备能坚持多久。

    Monkey测试即可以针对全局,也可以正对某个局部(某个 Category, package等等)。
    执行简单,效果明显。

     


    测试手段3: ASE

    ASE 意思为 Android 脚本环境, 即我们可以通过脚本(比如 Python)调用 Android 的功能,从而定制一些测试。比如打电话,发短信,浏览网页,等。

    我们可以扩充它的API(Java 部分), 并用python 脚本调用这些 API, 从而实现丰富的测试功能。
    用于API 部分可以访问到Android全部API, python又能灵活部署测试,所以 ASE 的扩展性非常好。

     

     

    测试手段4: Robotium


    该工具用于黑盒的自动化测试。可以在有源码或者只有APK的情况下对目标应用进行测试。

    Robotimu 提供了模仿用户操作行为的API,比如在某个控件上点击,输入 Text 等等。

     

     

    测试手段5: 单元测试

    Android 本身带有很多单元测试例子,我们可以按需要模仿它们,针对某个应用进行单元测试。

    注意 Android 的Instrument机制功能非常强大,可以测试 UI。

    总结

    对于 CTS/Monkey, 我们不需要开发,只要执行测试就可以了。

    对于 ASE, 我们可以扩充它的现有API(Java), 用Python调用这些API实现丰富的测试功能。

    Robotium 模仿普通用户行为,可以试着把一些原来由测试工程师做的测试变成Robotium自动化实现。

     

     

    -------------------------------------------------------------------------------------------

     

     

    android 2.3 hierarchyviewer.bat problems

    http://www.androiddevelopers.info/android-discussions/android-2-3-hierarchyviewer-bat-problems/

     

    In android 2.3 sdk, the hierarchyviewer.bat don’t work, it shows

    ” Failed to get the adb version: Cannot run program “adb.exe” ”

    after I put all “platform-tools” dir files to “tools” dir, it works fine.

  • 性能测试总结

    2012-01-04 10:23:03

    性能分析 : 
    1.average response time  :  平均响应时间  
    2.90% responsse time  : 90% 用户响应时间 ,  

    如果响应时间的运行很平滑 ,那么取  average response time  和 90% response time  是一样的 ,但是如果曲线比较波折那么就取 90% response time 比较好  ! 

    操作系统注意的是 : 

    windows 一般在 2000 个并发  
    liunx 一般在 1000个并发 ! 
     
    tomcat 的性能调试 : 
    tomcat 是不能独立运行的,它会依赖虚拟机 ,所以jvm 要调整一下  :  
    xms <size> : 初始化堆的大小 , xmx 是jvm的堆的最大值 ,  因为这些只在小并发的情况下没有什么作用 ,所以只有在大并发的情况下才有作用 ,所以一般把 xms 和 xmx 设成一般大 ,一般是设成物理内存的 80%,lr监控jvm要
    调用 API java.lang.management  接口 ,开发监控平台 ,  因为如堆的设很大 ,那么它的垃圾时间就会很长  ,一般垃圾时间要在 2-3 s 为最好 !  
    tomcat 也有 xms 和 xmx  ,最小内存  64 mb 和 最大内存  512  mb  
    tomcat 有msprocess  和 maxprocess  ,这个不通的系统 ,不同的脚本要不测试调优 !

    关于性能方面主要做了如下的项目 :  
    1. 石头网的性能测试  ,主要采用的是录制脚本的形式 ,采用的是tomcat+mysql+apache  
    首先进行性能调优 : 
    1) tomcat主要进行了 jvm虚拟机的调试 ,调试初始化内存 和最大可用内存 ,一般是初始化内存和最大可用内存一般在物理内存的 80% ,  (通过中间件比如tomcat 和weblogic里面的启动脚本来更改 ) 因为初始化内存在小的并发情况下没有什么作用,只有在大并发情况下有作用 所以一本初始化内存=最大可用内存 
    2)tomcat 方面调试了最大的线程池数量 ,这个要根据机器的配置等进行调整  ,我在这个项目中设置450个  !  
    3)apacha的性能调优 ,调试 一个连接最大的请求数 ,MaxKeepAliveRequests 10000  
          每个子进程完成的最大的请求数 :MaxRequestsPerChild 10000 
    4)mysql 最大连接数 max-connections      250 个   一般用户的最大连接数是设置的 85% 左右为合理  

    然后对系统进行了压力测试  ,   主要的目的是现有的配置的情况下 我们最大的并发数是多少 ! 为以后的设备的扩展做准备  , 是采用的loadrunner 录制登录模式  ,  
    主要加的计数器有 ,  
    1) average response time   :   平均响应时间
    2) 90% response time  :   90%用户的响应时间  
     当响应时间比较平滑的时候 ,那么用平均响应时间 ,如果响应时间不平滑 那么用 90% 响应时间 
    3)average throuhput (bytes /seconds) 系统的吞吐量   !   
    4) hits per seconds   反应了客户每秒向服务器发出的请求量   
    一般请求量越大那么 系统的吞吐量越大  ! 
    5) process time   cup的用量 ,一般在 80% 最高 ,如果超过这个就不合理  
    6) available  mbytes ,可用的物理内存  
    7) % disk time  所选磁盘为读或者写入请求服务 所用的时间百分比  
    8)bytes total /sec  : 发送和接受字节的速率 ,这个主要是考察网络的 !   
    采用了 ip欺骗的技术  ,一台应用服务器 ,一台数据库服务器  , 10m独享带宽  
      
    这个每秒最大的并发数是 450 个  !    
     

    linux 的 一般看top 值 , 用ps 调出各个进程 所占用的资源量  , 一般看 cup的用量 如果持续在 85 %的那么就是有问题 ,   % user time 如果这个一直很高  ,就说明 里面有复杂的算法程序需要优化  ! 






     


     
  • 在linux_ubuntu下设置gvim !

    2011-12-28 17:07:25

    让自己习惯 : 

    1.安装 vmware 虚拟机软件  
    2.下载了 linux_ubuntu 10.10  
    3.在vmware中建立虚拟机  , 选择镜像文件,建立了linux虚拟机  
    4.然后在ubuntu中——ubuntu software center 中输入你得用户名 ,然后就可以安装gvim了 
    5.然后就是配置gvim的为python ide的过程  
    6.首先是gvim的 gvimrc 和vimrc 文件在 /usr/share/vim  中 ,经我的实验 ,在两个中修改 ,对编辑器都有用 
    只是一个gvim 一个是vim ! 发现vim 7.02中菜单的工具栏中有很多设置 还是蛮好用得    
    7.不过找到了 配置文件 ,然后按照网上设置一下就好了 ! 

    我设置了 :
    "设置语法高亮  
    set  syntax on 
    "显示数字行号  
    set nu!  

    参考网站是 http://linux-wiki.cn/wiki/%E9%85%8D%E7%BD%AE%E5%9F%BA%E4%BA%8EVim%E7%9A%84Python%E7%BC%96%E7%A8%8B%E7%8E%AF%E5%A2%83   

    有些配置还要研究 ,先写到这吧  ,发现用惯了 window 对 liunx 还是不是很习惯 ,慢慢来吧 !
  • 最近在完linux的相关东东 ,记录一下 !

    2011-12-28 10:42:38

    1.用到的基本命令记录 
    1)想查找到linux上软件的相关的目录 : whereis 软件名称  如: whereis gvim  ,查找gvim的安装路径  
    不过一般软件安装的路径都在 /usr/local  Or /usr/share 里面 ! 

    2)如何运行一个软件 ,比如运行gvim :要进入程序的目录  ,然后在命令行下面直接输入gvim 就可以了 !   

    3)如何更改一个文件的权限 : 最方便的是用sudo ,来改换文件的权限 : 

    Ubuntu的许多操作是在终端中进行的,通过sudo命令管理的文件是由root持有权限的,一般用户是无法改变的。在图形界面上,我们可以通过属性中的权限选项夹进行操作。但是一旦文件的属性显示当前用户没有读写权力时,无法在图形界面上修改权限。
    M6JLinux联盟
    常用方法如下:
    M6JLinux联盟
    sudo chmod 600 ××× (只有所有者有读和写的权限)
    sudo chmod 644 ××× (所有者有读和写的权限,组用户只有读的权限)
    sudo chmod 700 ××× (只有所有者有读和写以及执行的权限)
    sudo chmod 666 ××× (每个人都有读和写的权限)
    sudo chmod 777 ××× (每个人都有读和写以及执行的权限)
    M6JLinux联盟
    其中×××指文件名(也可以是文件夹名,不过要在chmod后加-ld)。
    M6JLinux联盟
    解释一下,其实整个命令的形式是
    sudo chmod -(代表类型)×××(所有者)×××(组用户)×××(其他用户)
    M6JLinux联盟
    三位数的每一位都表示一个用户类型的权限设置。取值是0~7,即二进制的[000]~[111]。
    M6JLinux联盟
    这个三位的二进制数的每一位分别表示读、写、执行权限。
    M6JLinux联盟
    如000表示三项权限均无,而100表示只读。这样,我们就有了下面的对应:
    0 [000] 无任何权限
    4 [100] 只读权限
    6 [110] 读写权限
    7 [111] 读写执行权限
    M6JLinux联盟
    现在看上面的几个常用用法就非常清楚了。试着自己来修改权限吧
    M6JLinux联盟
    最后同时附上查询文件(或文件夹)权限的命令
    ls -l 文件名称 (文件夹将-l改为-ld)。

    4)vi 命令学习  , 在输入 i 后 输入内容 ,然后按esc  
    (1):w newfile  是保持修改的文件到新的文件原来的文件保持不变  
        :wq 是强制的写入并退出 ,并更新文件的修改时间  
        :x 是写入并退出 ,但是如果文件没有修改不会更改文件的修改时间  ! 
        :q!是强制退出 并不保存 ! 
    5)查询当前的文件目录 pwd ! 


  • (转)如何提高黑盒测试用例的覆盖度思路

    2011-12-20 10:09:50

     您在做测试设计时是否发现自己写的测试用例超多,但却发现不了几个bug?是否发现经过您的测试之后,还是有较多问题漏测试?本文将大概介绍一下如何避免此类问题的思路

      当您拿接到一个产品/项目拿到需求后,您需要对这个产品的需求进行分析/分解,写出测试方案,然后根据测试方案写测试用例,这就是测试设计的流程。如何避免上面提到的问题,我们就得从需求-->方案-->用例一步一步来分析。

      拿到需求文档后,我们要分析此次的产品/项目 新增、修改、删除那些功能,修改、删除时对原来功能会有什么影响,此时您需要把功能及影响一条一条的列出。

      列出完之后,在方案时就得考虑各种不同的分析方法的应用了,如下:

      1、首先进行等价类划分,包括输入条件和输出条件的等价类划分,合理设置有效等价类和无效等价类,这是减少工作量和提高测试效率最有效的方法。

      2、必须使用边界值分析,经验表明,这种方法设计出的用例能发现很多程序错误。

      3、可以使用错误推测法追加一些测试用例,这需要依靠您的智慧和经验。

      4、对照程序逻辑检查已设计出的测试用例的逻辑覆盖度,如果没有达到覆盖标准应当再补充足够的测试用例。

      5、如果程序的功能说明中含有输入条件的组合情况,一开始就可选因果图和判定表驱动法。

      6、对于参数配置类的软件,要用正交试验法选择较少的组合方式达到最佳效果。

      7、对于业务流清晰的系统,可以利用场景法贯穿整个测试方案过程,在案例中综合使用各种测试方法。

  • (转)Android软件测试的日志文件(Log文件)之多少

    2011-12-06 14:33:00


    分类: Android 2774人阅读 评论(2) 收藏 举报

       很多人经常搞不清楚各种日志文件的作用,什么时候抓这些文件,其实如果你分不清楚的话最好一起抓了,至少你要分清楚有哪些日志文件需要抓。

        log文件分为实时打印的,还有状态信息的两种

        实时打印的主要有:logcat main,logcat radio,logcat events,tcpdump,还有高通平台的还会有QXDM日志

        状态信息的有:adb shell dmesg,adb shell dumpstate,adb shell dumpsys,adb bugreport

     

        讲解一下各自作用:

        通过DDMS抓的其实跟用dos批处理抓的一样都是logcat的日志文件,ddms抓的通常是main缓存中的,就是应用程序打印的日志文件。不过ddms好处在于能够实时看到带有颜色的,如果是用dos批处理只能重定向到文件,到抓完之后才能够看到,不是实时的。

        adb logcat -b main -v time>app.log  打印应用程序的log

        adb logcat -b radio -v time> radio.log 打印射频相关的log,SIM STK也会在里面,modem相关的ATcommand等,当然跟QXDM差的很远了。

        adb logcat -b events -v time  打印系统事件的日志,比如触屏事件。。。

        tcpdump 是很有用的,对于TCP/IP协议相关的都可以使用这个来抓,adb shell tcpdump -s 10000 -w /sdcard/capture.pcap,比如抓mms下载的时候的UA profile,browser上网的时候,使用proxy的APN下载,streaming的相关内容包括UA profile等。

        最后是高通平台的QXDM,不管是不是Android,只要使用高通芯片,都会对它很熟悉,当然了,不是高通的芯片就不用提它了。这个不多讲,内容丰富,射频,电话,上网,...凡是高通提供的解决方案,这个都可以抓。

     

        状态信息:其实一个就够了,那就是bugreport(命令adb bugreport>bugreport.log)。里面包含有dmesg,dumpstate和dumpsys。dmesg(命令adb shell dmesg > ldmesg_kernel.log)是kernel的log,凡是跟kernel相关的,比如driver出了问题(相机,蓝牙,usb,启动,等等吧)。 dumpstate是系统状态信息,里面比较全,包括手机当前的内存信息、cpu信息、logcat缓存,kernel缓存等等。adb shell dumpsys这个是关于系统service的内容都在这个里面,这个命令还有更详尽的用法,比如db shell dumpsys meminfo system是查看system这个process的内存信息。

    还有其他的比如PV的log,一般都是开发人员自己写的,可能让你放到sd卡里面,其他的不足或需要补充的期望您的指导。

  • vbs排序算法2

    2011-11-30 08:56:15

    Dim input, num()
    input = InputBox ("请输入,注意将要排序的字符用空格格开:")
    ReDim num(Len (input))
    Dim a, b:b = 0
    For a = 1ToLen (input)
        flag = 0
        IfMid (input, a, 1) <> " "AndMid (input, a, 1) <> " "Then
          num(b) = num(b) & Mid (input, a, 1)
        Else
           If flag = 0Then b = b+1:flag = 1
             
        EndIf
    Next
    Dim str():ReDim str(b)
    ReDimPreserve num(b)
    dim c, d
    a = 1
    For a = 0To b
        c = 0:d = 0
        For c = 0To b
            IfIsNumeric (num(a)) = TrueAndIsNumeric (num(c)) = TrueThen
               If num(a) - num (c) > 0Then d = d+1
               Else
               If num(a) > num(c) Then d = d+1
            EndIf
        Next
        If str(d) = ""Then
          str(d) = num(a)
        Else
          str(d) = str(d) & " " & num (a)
        EndIf
    Next
    MsgBox str(d)
    Dim vbstr:d = 0
    For d = 0To b
        vbstr = vbstr & " " & str(d)
    Next
    Set ie = WScript.CreateObject("internetexplorer.application")
    With ie
    .Navigate"about:blank"
    .Width = 400
    .Height = 200
    With .Document.parentwindow
    .moveto (.Screen.AvailWidth-400)/2,(.Screen.AvailHeight-200)/2
    .Document.Write"<FONT face=楷体_GB2312 color=#FF9224 size=3><br>排序前:" & input & "<br>排序后:" & right(vbstr, len(vbstr)-1) & "</font></br><body bgcolor='#8020ff'></br>"
    .Document.title = "运算结果如下"
    EndWith
    .document.close
    .MenuBar = 0
    .ToolBar = 0
    .AddressBar = 0
    .StatusBar = 0
    .Visible = true
    .Resizable = 0
    EndWith
    WScript.Sleep10000
    ie.Quit
    Set ie = nothing  
  • 今天做面试题做了一个排序的题!这里学了一下排序的算法!

    2011-11-29 13:42:54

    该算法参考的严蔚敏老师97版 C语言版的快排算法(没有做枢轴的优化),使用了递归调用的方式。

    代码经调试运行无误(控制台程序)。

    1 Dim arr
    2  Dim low
    3 Dim high
    4 arr = Array(1,99,58.32,8,7,3,4.18,2,6,14,65,9,23,43,78,9)
    5
    6 low = Lbound(arr)
    7 high = Ubound(arr)
    8
    9 '===调用快速排序===
    10 QuickSort arr,low,high
    11
    12 For i = 0 to Ubound(arr)
    13 Response.Write(arr(i)&"&nbsp;&nbsp;")
    14 Next
    15
    16 '===========用VBScript实现快速排序======开始============
    17 'Author:falconshh 2011.05.30
    18 'arr:待排数组,下标从0....n-1
    19 'low:数组最低端下标
    20 'high:数组最高端下标
    21 Sub QuickSort(arr,low,high)
    22 Dim pivotPos '枢轴位置
    23 If low < high Then
    24 pivotPos = CInt(Partition(arr,low,high))
    25 QuickSort arr,low,pivotPos-1 '对低端子数组排序
    26 QuickSort arr,pivotPos+1,high '对高端子数组排序
    27 End if
    28 End Sub
    29
    30 '分割数据
    31 Function Partition(arr,low,high)
    32 Dim pivot '定义枢轴
    33 pivot = arr(low) '取第一个记录作为枢轴
    34 i = low
    35 j = high
    36
    37 Do While (i < j)
    38 Do While (i < j and arr(j) >= pivot)
    39 j = j - 1
    40 Loop
    41
    42 arr(i) = arr(j) '将枢轴移到低端
    43
    44 Do While (i < j and arr(i) <= pivot)
    45 i = i + 1
    46 Loop
    47 arr(j) = arr(i) '将枢轴移到高端
    48 Loop
    49
    50 arr(i) = pivot '将枢轴放置到正确的位置(中间点)
    51 Partition = i '返回枢轴的位置
    52 End Function
    53 '===========用VBScript实现快速排序======结束============

    排序结果如下:

    1  2  3  4.18  6  7  8  9  9  14  23  43  58.32  65  78  99  

    这个是网上关于快速排序的一个算法 实例 : 

    Partition(arr,low,high)这个函数的作用是用来确定第一次中间轴的位置 ! 返回一个i值 ! 
    然后

    首先: arr(low)这是固定的值 ,固定了一个轴的位置 ,然后下面就是排序,把小于这个数的排到前面,大于的排到中间,  arr(j)=arr(i) 是把两个数位置调换了 ! 

    我理解成功还是这篇文章的功劳: 

    快速排序是对冒泡排序的一种改进。它的基本思想是:通过一躺排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一不部分的所有数据都要小,然后再按次方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

        假设要排序的数组是A[1]……A[N],首先任意选取一个数据(通常选用第一个数据)作为关键数据,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一躺快速排序。一躺快速排序的算法是:

       1)、设置两个变量I、J,排序开始的时候I:=1,J:=N;

       2)以第一个数组元素作为关键数据,赋值给X,即X:=A[1];

       3)、从J开始向前搜索,即由后开始向前搜索(J:=J-1),找到第一个小于X的值,两者交换;

       4)、从I开始向后搜索,即由前开始向后搜索(I:=I+1),找到第一个大于X的值,两者交换;

       5)、重复第3、4步,直到I=J;

       例如:待排序的数组A的值分别是:(初始关键数据X:=49)

                       A[1]     A[2]     A[3]     A[4]     A[5]      A[6]     A[7]:

                         49        38       65       97       76       13        27

    进行第一次交换后:   27        38       65       97       76       13        49

                       ( 按照算法的第三步从后面开始找

    进行第二次交换后:   27        38       49       97       76       13        65

                      ( 按照算法的第四步从前面开始找>X的值,65>49,两者交换,此时I:=3 )

    进行第三次交换后:   27        38       13       97       76       49        65

    ( 按照算法的第五步将又一次执行算法的第三步从后开始找

    进行第四次交换后:   27        38       13       49       76       97        65

    ( 按照算法的第四步从前面开始找大于X的值,97>49,两者交换,此时J:=4 )

          此时再执行第三不的时候就发现I=J,从而结束一躺快速排序,那么经过一躺快速排序之后的结果是:27        38       13       49       76       97        65,即所以大于49的数全部在49的后面,所以小于49的数全部在49的前面。

          快速排序就是递归调用此过程——在以49为中点分割这个数据序列,分别对前面一部分和后面一部分进行类似的快速排序,从而完成全部数据序列的快速排序,最后把此数据序列变成一个有序的序列,根据这种思想对于上述数组A的快速排序的全过程如图6所示:

    初始状态                        {49     38     65     97     76     13     27}   

    进行一次快速排序之后划分为      {27     38     13}     49   {76     97     65}

    分别对前后两部分进行快速排序    {13}    27    {38}

                                    结束         结束    {49    65}    76    {97}

                                                        49   {65}         结束

                                                            结束

                              图6    快速排序全过程

    1)、设有N(假设N=10)个数,存放在S数组中;

    2)、在S[1。。N]中任取一个元素作为比较基准,例如取T=S[1],起目的就是在定出T应在排序结果中的位置K,这个K的位置在:S[1。。K-1]<=S[K]<=S[K+1..N],即在S[K]以前的数都小于S[K],在S[K]以后的数都大于S[K];

    3)、利用分治思想(即大化小的策略)可进一步对S[1。。K-1]和S[K+1。。N]两组数据再进行快速排序直到分组对象只有一个数据为止。

    如具体数据如下,那么第一躺快速排序的过程是:

    数组下标: 1      2      3      4      5      6      7      8      9      10

               45     36     18     53     72     30     48     93     15      36

          I                                                                   J

    (1)      36     36     18     53     72     30     48     93     15      45

           

    (2)      36     36     18     45     72     30     48     93     15      53

    (3)      36     36     18     15     72     30     48     93     45      53

    (4)      36     36     18     15     45     30     48     93     72      53

    (5)      36     36     18     15     30     45     48     93     72      53

    通过一躺排序将45放到应该放的位置K,这里K=6,那么再对S[1。。5]和S[6。。10]分别进行快速排序。

    一般来说,冒泡法是程序员最先接触的排序方法,它的优点是原理简单,编程实现容易,但它的缺点就是--程序的大忌--速度太慢。下面我介绍一个理解上简单但编程实现上不是太容易的排序方法,我不知道它是不是现有排序方法中最快的,但它是我见过的最快的。排序同样的数组,它所需的时间只有冒泡法的 4% 左右。我暂时称它为“快速排序法”。

         “快速排序法”使用的是递归原理,下面我结合一个例子来说明“快速排序法”的原理。首先给出一个数组{53,12,98,63,18,72,80,46, 32,21},先找到第一个数--53,把它作为中间值,也就是说,要把53放在一个位置,使得它左边的值比它小,右边的值比它大。{21,12,32, 46,18,53,80,72,63,98},这样一个数组的排序就变成了两个小数组的排序--53左边的数组和53右边的数组,而这两个数组继续用同样的方式继续下去,一直到顺序完全正确。

         我这样讲你们是不是很胡涂,不要紧,我下面给出实现的两个函数:

    /*
    n就是需要排序的数组,left和right是你需要排序的左界和右界,
    如果要排序上面那个数组,那么left和right分别是0和9
    */

    void quicksort(int n[], int left,int right)
    {
    int dp;
    if (left<right) {

         /*
         这就是下面要讲到的函数,按照上面所说的,就是把所有小于53的数放
         到它的左边,大的放在右边,然后返回53在整理过的数组中的位置。
         */
         dp=partition(n,left,right);

         quicksort(n,left,dp-1);

         quicksort(n,dp+1,right); //这两个就是递归调用,分别整理53左边的数组和右边的数组
    }
    }

         我们上面提到先定位第一个数,然后整理这个数组,把比这个数小的放到它的左边,大的放右边,然后

    返回这中间值的位置,下面这函数就是做这个的。
    int partition(int n[],int left,int right)
    {
    int lo,hi,pivot,t;

    pivot=n[left];
    lo=left-1;
    hi=right+1;

    while(lo+1!=hi) {
         if(n[lo+1]<=pivot)
           lo++;
         else if(n[hi-1]>pivot)
           hi--;
         else {
           t=n[lo+1];
           n[++lo]=n[hi-1];
           n[--hi]=t;
         }
    }

    n[left]=n[lo];
    n[lo]=pivot;
    return lo;
    }

         这段程序并不难,应该很好看懂,我把过程大致讲一下,首先你的脑子里先浮现一个数组和三个指针,第一个指针称为p指针,在整个过程结束之前它牢牢的指向第一个数,第二个指针和第三个指针分别为lo指针和hi指针,分别指向最左边的值和最右边的值。lo指针和hi指针从两边同时向中间逼近,在逼近的过程中不停的与p指针的值比较,如果lo指针的值比p指针的值小,lo++,还小还++,再小再++,直到碰到一个大于p指针的值,这时视线转移到hi指针,如果 hi指针的值比p指针的值大,hi--,还大还--,再大再--,直到碰到一个小于p指针的值。这时就把lo指针的值和hi指针的值做一个调换。持续这过程直到两个指针碰面,这时把p指针的值和碰面的值做一个调换,然后返回p指针新的位置。




  • qtp面试准备题!

    2011-11-15 21:50:05

    参加面试 ,是一次总结,也是一次挑战 , 是一次重新寻找自己 ! 去经历 , 去感受 , 去总结 , 面对真实的自己 ! 坦然接受结果 ! 

    1.选择网页上所有的复选框 ! 

    checkout=description.create()
    checkout("html tag").value="Input"
    checkout("type").value="checkout"

    checkouts=browser(browser).page(page).childobjets(checkout)

    checkoutsnum=checkouts.count

    for i= 0 to checkoutsnums-1 
     
     checkouts(i).set"on "

    next  

    这个题比较有意思 , 学习了 childobject 不错 ! 

    2.编写在QTP脚本,实现向记事本中输入“0123456789ABCDEFG”后,按ENTER?
    Function  notes(s)

      Set  fso=createobject("scripting.filesystemobject")
         set newnotes=fso.opentextfile("c:\test.txt",8,true )
      noteswrite=newnotes.writeline()
      notes=noteswrite


    EndFunction

    Call notes("0123456789ABCDEFG")

    Set  wsh=createobject(wscript.shell)
    wsh.sendkeys"{enter}"

    3.获取桌面上名字为“vivian”记事本对象  
    set  notes=description.create()
    notes("text").value="vivian" 
    set bjectnotes=desktop.childobjects(notes)  

    4.找到一个图片的文件类型  ! 
    用object spy 找到图片的name ,通过属性取得文件名  

    filename=Browser("Browser").page("page").image("image").gettoproperty("filename") 
    temarray=split(filename,".")
    type=ubound(temarray) 
    msgbox type 

    5.如何删除你要删除的文件夹 ! 
    dim spdrive ,spfolder , sppath
    spdrive="c:/"  
    spfolder="mytest"
    sppath=spdrive&spfolder  

    set fso=createobject("scripting.filesystemobject") 
      fso.deletefolder(sppath)
     
     fso.createfolder("d:/mytest")

    6.如果关掉msgbox  

    set  wsh=createobject(wscript.shell)
    wsh.popup“停留5s,然后关闭”,“5”,“title”  
    title  是magbox的titile  

    7.你是怎么来做qtp流程是什么 ! 
    1.进行功能测试在进行到B版本时候把qtp的对象加到对象库里面 , 
    2.确定进行自动化的模块的用例,和测试数据   (包括要参数化的, 检查点的  )  
    3.开发测试用的函数 和模块脚本   ,调试单独的脚本能够调通 ! 
    4.调试整个脚本 !  
    5.分享报告  ,报bug  !  
    6.进行了td和qtp的链接   ,用一个td和qtp的插件 ,找到相应的脚本就可以了 ! 

    8.如何删除cookie值  ,  
    一种方法是调用webutil里面的方法来删除  

    set  owebutil=createobject(“mecury.gui_webutil”)
    owebutil.deletecookies  
    owebutil=nothing  

    我用得方法是webutil qtp隐藏的方法 ,这个方法可以到qtp的bin的目录下面  ,用exescope来获得 具体的名字是:(wwwspack.dll ) 
    <安装目录>/bin/StdPackage.dll          (标准对象包) 
    <安装目录>/bin/WWWPackage.dll      (WEB对象包) 
    <安装目录>/bin/VbPackage.dll            (VB对象包) 
    <安装目录>/bin/AcxPackage.dll           (ActiveX对象包) 
    <安装目录>/bin/VoPackage.dll            (虚拟对象包) 我们可以分别使用Exescope来打开以上以及DLL来查看其对象的隐藏方法,打开后在TYPELIB里可以查看,里边有许多QTP的隐藏方法  

    第二种方法是:按照vs2008 然后打开qtp debugview 然后把你要看的对象选中 ,然后右键 ,点击add to watch  然后 debug from this step  ,然后你就可以在debugview下面看到你选中的属性和方法了 ! 



    9,用qtp如何来打开一个word  ,并且输入文字 ,然后关闭  

    set  wsh=createobject("word.application") 
           wsh.visiable=true 
     set doc=wsh.document.add  
    set range=doc.paragraphs.add.range 
       range.text="hello   i am  gaomeng " 
    set range2=doc,pagragraphs,add.range
     range,text="hello  i am  vivian  "
    这个具体的word.application 的方法很多 可以到micrsoft的msdn里面查找   具体网址 : http://msdn.microsoft.com/enus/library/ff821215.aspx    

    label :  vbA是应用的一个vb的一个子集 !  




    10录制鼠标右键的方法 ! 

    1.用setting 的方法  replay  方法 ( 1.用浏览器模式 2.为用鼠标模式 )  
    2.click  鼠标的的点击方法有 (micleftbtn  0)表示左击 , micrightbtn 1 表示右点击  , micmiddlebtn 2  是中点击   
    setting.webpackage("replay")=2
    Browser(browser).page.click ,, micrright  
    set wsh=createobject(wscript.sheell) 
    wsh.sendkeys"{down}" 
    wsh.sendkeys"{down}" 
    wsh.sendkeys"{enter}"  

    setting.webpackage("replay")=1   

    第二种方法是用fireevent 方法感觉很好用  
    setting.webpackage("replay")=2  
    browser("browser").page(“page”).link("google大全")fireevent("onclick"),,,micrightbtn  

    这个fireevent 这个方法还可以用到 onmouseover  用到悬浮菜单上面  

    关于悬浮菜单 还可以用  : 

    问题现象:

    系统中有一些菜单是用浮动窗口做的,鼠标移动到某个菜单项上,然后下面会有浮动菜单弹出。本来可以用很简单的Fireevent "Onmouseover" 来解决。不过我遇到的菜单这样处理了没有反应,而另一个同事遇到同样的问题就可以很容易解决。

    解决办法:

    后来据我分析,同事那边估计那个菜单项是Link的,而我遇到的菜单项是WebElement的,据HP专家讲,QTP的这个FireEvent对WebElement支持的不好。于是专家提供了一个引用外部API的方法给我来解决问题。下面拿来分享一下,也许哪天你就会碰到这样的问题,不妨试试。

    Extern.Declare micLong, "SetCursorPos", "user32.dll", "SetCursorPos", micLong, micLong 
    Extern.SetCursorPos X,Y   '鼠标移动到坐标(X,Y) 

    Extern.Declare micVoid, "mouse_event", "user32.dll", "mouse_event", micLong, micLong, micLong, micLong, micLong 
    Extern.mouse_event 2,X,Y,0,0    '鼠标按下 
    Extern.mouse_event 4,X,Y,0,0    '鼠标抬起 

    这里有2个方法,分别是SetCursorPos和mouse_event。首先取得WebElement的绝对坐标,然后分别加一点(因为坐标是控件左上角,避免点不到,把坐标的横纵坐标都加5-10左右),然后使用SetCursorPos方法,鼠标就会正常移动到那个控件上,菜单也就正常弹出来了。mouse_event可能用到的比较少,其实就是Click点击事件,如果用这种方法写就很麻烦,必须把鼠标按下和鼠标抬起都用上才能作为点击的事件。后来在我做的脚本里,经常会用到鼠标移动的方法,点击的方法目前没用到,因为基本上Click都很正常,也许哪天出问题了就可以用这种了。

    扩展一下,其实QTP里可以用这个Extern.Declare引用很多外部的API,只要你知道怎么用,像上面两个方法,我也是通过帮助看懂了一点点,具体这个Extern.Declare怎么用还是去看帮助吧。

    这个extern 的方法来引用外部的dll 库文件中的方法 或者函数  !  

    Extern.Declare micHwnd, "FindWindow", "user32.dll", "FindWindowA", micString, micString 


    michwnd :是qtp的数据类型  
    “findwindow” : 是引用的方法  
    “user32.dll” 是引用的库 (最好写上你存储的路径) 
    “findwindownA”  在dll中程序的名字 , 如果没有就是方法的名字  
    “micstring”: 是方法的参数类型  
    “micstring”:是方法的参数类型  

    这个对于引用  程序中开发的动态库非常的有用 ! 

    通过以上例子我们可以看到又有了一种新的控制对象的方法,其中控制对象有很多种

    我这里就以百度搜索框输入为例,总结一下确定对象的一些方法

     

    1.最普通的方法

    1. Browser("百度一下,你就知道").Page("百度一下,你就知道")
    2. .WebEdit("wd").Set "helloworld"  


    2.描述性编程

    Browser("百度一下,你就知道").Page("百度一下,你就知道").webedit("name:=wd").Set "123"  

     

    3.对象自身接口
    1. Browser("百度一下,你就知道").Page("百度一下,你就知道")
    2. .WebEdit("wd").Object.value="helloworld"  
    4.DOM技术
    Browser("百度一下,你就知道").Page("百度一下,你就知道").Object.getElementById("kw").value="helloworld" 


  • Td导出需求和测试用例到excel 和word中 !

    2011-11-09 17:04:18

    1.导入到word中用tool—document generation  选中需求或者用例  !

    但是导出的时候报用例错误(在xp系统)换了 win2003 就可以了 ! 不知道为什么 

     

    2.然后到execel里面 

    下载一个excelTDAddin.rar 在office 2007里面的 xlsstart 里面压缩并点击  ,然后在加载项中选中 import from qualty center   就可以导出测试用例了

    注意网站的路径要写 http://ip/tdbin 

     

511/3123>
Open Toolbar