首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】 逻辑覆盖法是设计白盒测试用例的主要方法之一,它是通过对程序逻辑结构的遍历实现程序的覆盖。针对以下由C语言编写的程序,按要求回答问题。 struct_ProtobufC
阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】 逻辑覆盖法是设计白盒测试用例的主要方法之一,它是通过对程序逻辑结构的遍历实现程序的覆盖。针对以下由C语言编写的程序,按要求回答问题。 struct_ProtobufC
admin
2013-01-19
50
问题
阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
逻辑覆盖法是设计白盒测试用例的主要方法之一,它是通过对程序逻辑结构的遍历实现程序的覆盖。针对以下由C语言编写的程序,按要求回答问题。
struct_ProtobufCIntRange {
int start_value;
unsigned orig_index;
},
typedef struct _ProtobufCIntRange ProtobufCIntRange;
int int_range_lookup(unsigned n_ranges,const ProtobufCIntRange*range8,int value){
unsigned start,n; //1
start=0;
n=n_ranges;
while(n>1){ //2
unsigned mid=start+n/2;
if(value
n=mid—start; //4
}
else if(value>=ranges[mid].start_value+
(int)(ranges[mid+1].orig_index-ranges[mid].orig_index)) {//5
unsigned new_start=mid+1; //6
n=start+n-new_start;
start=new_start;
}
else //7
return(value-ranges[mid].start_value)+ranges[mid].orig_index;
}
if(n>0){ //18
unsigned start_orig_index=ranges[start].orig_index;
unsigned range_size=ranges[start+1].orig_index-start_orig_index;
if(ranges[start].start_value<=value
&&value<(int)(ranges[start].start_value+range_size)) //9,10
return(value-ranges[start].start_value)+start_orig_index; //11
}
return-1; //12
} //13
请画出上述程序的控制流图,并计算其控制流图的环路复杂度V(G)。
选项
答案
控制流图 [*] 环路复杂度V(G)=7
解析
本题考查白盒测试方法中的基本路径法。涉及到的知识点包括:根据代码绘制控制流图、计算环路复杂度。
控制流图是描述程序控制流的一种图示方法。其基本符号有圆圈和箭线:圆圈为控制流图中的一个结点,表示一个或多个无分支的语句;带箭头的线段称为边或连接,表示控制流。基本结构如下所示:
根据题中程序绘制的控制流图如下所示。其中要特别注意的是,如果判断中的条件表达式是复合条件,即条件表达式是由一个或多个逻辑运算符连接的逻辑表达式,则需要改变复合条件的判断为一系列之单个条件的嵌套的判断。本题程序中,if(ranges[start].start_value<=value&&value<(int)(ranges[start].start_value+range_size))这条判断语句中的判定由两个条件组成,因此在画控制流图的时候需要拆开成两条判断语句。控制流图详见参考答案。
环路复杂度用来衡量一个程序模块所包含的判定结构的复杂程度,数量上表现为独立路径的条数,即合理地预防错误所需测试的最少路径条数。环路复杂度等于图中判定节点的个数加l,图中判定节点个数为6,所以V(G)=7。
转载请注明原文地址:https://kaotiyun.com/show/87WZ777K
本试题收录于:
软件评测师下午应用技术考试题库软考中级分类
0
软件评测师下午应用技术考试
软考中级
相关试题推荐
()不属于网络基础平台的组成部分。
局域网中,()具有良好的扩展性和较高的信息转发速度,能适应不断增长的网络应用需要。
移动终端被用户随身携带,具有唯一号码等特性使移动应用可以满足衣食住行娱乐等需求,这属于移动互联网的()的特色。
关于索赔程序的描述,不正确的是()。
类库、构件、模板和框架是软件开发过程中常用的几种提高软件质量、降低开发工作量的软件复用技术。()是面向对象的类库的扩展,并由一个应用相关联构件家族构成,这些构件协同工作形成了它的基本结构骨架。
软件配置管理必须保证软件配置管理项的正确性、完备性、_____________。
软件工程中,(35)不属于用户文档的内容。
电缆传输信道测试不包括(14)检测。
从监理的角度来分类,以下不属于监理总控类文档的是______。
关于监理工作程序,按照工作顺序划分,不正确的是()。
随机试题
设备监理工程师在对设备设计进行相关管理时,还会进行设计过程的( )和( )。
在金融创新过程中,商业银行的贷款有逐渐“表外化”的倾向,具体业务包括贷款额度、周转性贷款承诺、循环贷款协议和()。
“扭曲的体像”是()患者的表现。
美国著名的智囊公司——兰德公司花费了20年的时间跟踪世界500家大公司,发现百年长盛不衰的企业具有一个共同的特征,就是树立了超越利润的社会目标,不以利润为唯一追求目标。从这段文字可以推出:
以下哪一个不是维新派兴办的学堂()
根据我国刑法的规定,对犯罪分子所犯的数罪均被判处有期徒刑、拘役或者管制刑的,应当采取()。
很强的电流会通过伴随电流产生的电磁场而使在其附近生活和工作的人更容易患癌症吗?电话线工人每天都工作在这样的电流旁边,他们可以作为例子。实验结果表明,他们患脑癌的概率更大。因此,电磁场引发癌症的假设是成立的。以下哪项最为恰当地指出了上述论证所存在的
法律权利就是权利主体依法要求义务主体作出某种行为或者不作出某种行为的资格。对于法律权利的特征,表述正确的有
下列关于栈的叙述正确的是()。
下列关于C++函数的叙述中,正确的是()。
最新回复
(
0
)