当前位置:首页计算机类软件水平考试中级软件评测师->阅读下列Java程序,回答下列问题。[Java程序]publ

阅读下列Java程序,回答下列问题。

[Java 程序]

public int addAppTask(Activity activity, Intent intent,

TaskDescription description, Bitmap thumbnail) {

Point size = getSize1; //1

final int tw = thumbnail.getWidth1;

final int th = thumbnail.getHeight1;

if (tw != size.x || th != size.y) { //2,3

Bitmap bm = Bitmap.createBitmap(size.x, size.y, thumbnail

.getConfig1); //4

float scale;

float dx = 0, dy = 0;

if (tw * size.x > size.y * th) { //5

scale = (float) size.x / (float) th; //6

dx = (size.y - tw * scale) * 0.5f;

} else { //7

scale = (float) size.y / (float) tw;

dy = (size.x - th * scale) * 0.5f;

}

Matrix matrix = new Matrix1;

matrix.setScale(scale, scale);

matrix.postTranslate((int) (dx + 0.5f), 0);

Canvas canvas = new Canvas(bm);

canvas.drawBitmap(thumbnail, matrix, null);

canvas.setBitmap(null);

thumbnail = bm;

}

if (description == null) { //8

description = new TaskDescription1; //9

}

} //10

1、请简述基本路径测试法的概念。

2、请画出上述程序的控制流图,并计算其控制流图的环路复杂度vfG.。

3、请给出问题2中控制流图的线性无关路径。

查看答案 纠错
答案:
本题解析:

1、基本路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例的方法。

2、控制流图

中级软件评测师,章节练习,测试用例设计方法

环路复杂度V(G)=5

3、线性无关路径:

1.1-2-4-5-6-8-9-10

2.1-2-4-5-7-8-9-10(1-2-4-5-7-8-10)

3.1-2-4-5-6-8-10(1-2-4-5-7-8-10)

4.1-2-3-4-5-6-8-9-10(1-2-3-4-5-7-8-9-10,1-2-3-4-5-6-8-10,1-2-3-4-5-7-8-10)

5.1-2-3-8-9-10(1-2-3-8-10)

本题考查白盒测试法的应用。

第一小题考查白盒测试用例设计方法中的基本路径测试法。

基本路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例的方法。

第二小题考查白盒测试用例设计方法:基本路径测试法。涉及到的知识点包括根据代码绘制控制流图、计算环路复杂度。

控制流图是描述程序控制流的一种图示方式,它由节点和定向边构成。控制流图的节点代表一个基本块,定向边代表控制流的方向。其中要特别注意的是,如果判断中的条件表达式是复合条件,即条件表达式是由一个或多个逻辑运算符连接的逻辑表达式,则需要改变复合条件的判断为一系列之单个条件的嵌套的判断。本题程序中,if(tw!=size.x || th!=size.y)这条判断语句中的判定由两个条件组成,因此在画控制流图的时候需要拆开成两条判断语句。需要注意的是,复合条件之间是“&&”的关系还是“||”的关系反应在控制流图的画法是不同的。

程序的环路复杂度等于控制流图中判定节点的个数加1,本题控制流图中判定节点个数为4,所以V(G)=5。

第三小题考查白盒测试用例设计方法:基本路径法。涉及到的知识点包括:根据控制流图和环路复杂度给出线性无关路径。

线性无关路径是指包含一组以前没有处理的语句或条件的路径。从控制流图上来看,一条线性无关路径是至少包含一条在其他线性无关路径中从未有过的边的路径。程序的环路复杂度等于线性无关路径的条数,所以本题中应该有5条线性无关路径。

更新时间:2021-11-23 13:56

你可能感兴趣的试题

单选题

(  )is the process of transforming information so it is unintelligible to anyone but the intended recipient.

  • A.Encryption
  • B.Decryption
  • C.Security
  • D.Protection
查看答案
单选题

As each application module is completed,it undergoes(  )to ensure that it operates correctly and reliably.

  • A.unit testing
  • B.integration testing
  • C.system testing
  • D.acceptance testing
查看答案
单选题

(  )algorithm specifies the way to arrange data in a particular order.

  • A.Search
  • B.Random
  • C.Sorting
  • D.Merge
查看答案
单选题

After analyzing the source code,(  )generates machine instructions that will carry out the meaning of the program at a later time.

  • A.an interpreter
  • B.a linker
  • C.a compiler
  • D.a converter
查看答案
单选题

(  )can help organizations to better understand the information contained within the data and will also help identify the data that is most important to the business and future business decisions.

  • A.Data processing system
  • B.Big Data analytics
  • C.Cloud computing
  • D.Database management
查看答案
单选题

浏览器开启无痕浏览模式后,(  )依然会被保存下来。

  • A.浏览历史
  • B.搜索历史
  • C.已下载文件
  • D.临时文件
查看答案
单选题

下列协议中,不属于TCP/IP协议簇的是(  )。

  • A.CSMA/CD
  • B.IP
  • C.TCP
  • D.UDP
查看答案
单选题

下列传输介质中,带宽最宽、抗干扰能力最强的是(  )。

  • A.双绞线
  • B.红外线
  • C.同轴电缆
  • D.光纤
查看答案
单选题

数控编程常需要用参数来描述需要加工的零件的图形。在平面坐标系内,确定一个点需要2个独立的参数,确定一个正方形需要(  )个独立的参数。

  • A.3
  • B.4
  • C.5
  • D.6
查看答案
单选题

某书的页码为1,2,3,...,共用数字900个(一个多位数页码包含多个数字),据此可以推断,该书最大的页码为(  )。

  • A.237
  • B.336
  • C.711
  • D.900
查看答案