<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 消費電子 > 設計應用 > 匯編程序覆蓋測試中不可達指令檢測算法

匯編程序覆蓋測試中不可達指令檢測算法

作者: 時(shí)間:2009-03-24 來(lái)源:網(wǎng)絡(luò ) 收藏

1、引言

本文引用地址:http://dyxdggzs.com/article/167022.htm

一般而言,語(yǔ)言的執行表現為一系列邏輯路徑的動(dòng)態(tài)組合,時(shí)盡量所有可能的路徑是軟件的目標之一,有關(guān)的工作叫做。目前大多數測試工具是針對C/C++等高級語(yǔ)言的,針對語(yǔ)言的測試工具相當少見(jiàn)。由于語(yǔ)言非結構化的特點(diǎn),其實(shí)現往往采用很多條件和無(wú)條件跳轉,使得結構復雜化,按照匯編語(yǔ)言程序執行的一般方法,可以得到語(yǔ)句的執行序列。如果當一段程序中包含有一些無(wú)論在任何情況下都不需要執行或者根本執行不到的時(shí),一般的測試方法就很難將這些甄別出來(lái)并給出適當的提示或進(jìn)行必要的排除。這些指令稱(chēng)為達指令。為此,在研究匯編程序軟件測試的過(guò)程中,本文提出了一種判定匯編源程序達指令的。

2、達指令的判定

2.1 提出的前提條件

程序塊

定義1 程序塊是指程序中一個(gè)含有少量的語(yǔ)句序列,其中只有一個(gè)入口語(yǔ)句和一個(gè)或多個(gè)出口語(yǔ)句,執行時(shí)只能從入口語(yǔ)句進(jìn)入,從出口語(yǔ)句退出。對于一個(gè)給定的程序,可以把它劃分為一系列的程序塊。

定義2 入口語(yǔ)句是指:1) 程序的第一個(gè)語(yǔ)句;2) 或者能夠由條件轉移語(yǔ)句或無(wú)條件轉移語(yǔ)句轉移到的語(yǔ)句;3) 或者緊跟在條件轉移語(yǔ)句后面的語(yǔ)句。

定義3 出口語(yǔ)句是指:1) 下一條入口語(yǔ)句之前的那條語(yǔ)句;2) 或者程序的終止語(yǔ)句。

2.2 不可達指令的判定基本思想

1)首先將已經(jīng)劃分好的某個(gè)源程序塊的所有語(yǔ)句序列號存入一個(gè)預先定義好的數組A中;

2)取程序段執行中可以認可的初始值的上限運行程序,將指令執行的語(yǔ)句序列進(jìn)行記錄,并存入一個(gè)預先定義好的數組A1中;

3)取程序段執行中可以認可的初始值的下限運行程序,同樣將指令執行的語(yǔ)句序列進(jìn)行記錄,并存入一個(gè)預先定義好的數組A2中;

4)取程序段執行中可以認可的初始值的中間值運行程序,同樣將指令執行的語(yǔ)句序列進(jìn)行記錄,并存入一個(gè)預先定義好的數組A3中;

5)將A1,A2,A3三個(gè)數組分別與源程序段的語(yǔ)句序列數組A進(jìn)行逐項比較,并分別把不同項列出并存入數組B1,B2,B3中;

6)最后將分別存有不同項的三個(gè)數組B1,B2,B3進(jìn)行比較,找出其交集,其交集中的元素即為不可達指令語(yǔ)句號。

2.3 不可達指令的判定算法實(shí)現

算法實(shí)現如下:

Void pleonasm( )
{
Int A[n],A1[n],A2[n],A3[n],B1[n],B2[n],B3[n],B[n];
Int I,j,k=0,p=0;
For(i=0;in;i++)
For(j=0;jn;j++)
If(A[i]!=A1[j])
{ B1[k]=A1[j];
k++;}//找出執行上限值時(shí)沒(méi)有執行到的指令序列號
l=len(B1);
k=0;
For(i=0;in;i++)
For(j=0;jn;j++)
If(A[i]!=A2[j])
{ B2[k]=A2[j];
k++;}//找出執行下限值時(shí)沒(méi)有執行到的指令序列號
k=0;
m=len(B2);
For(i=0;in;i++)
For(j=0;jn;j++)
If(A[i]!=A3[j])
{ B3[k]=A3[j];
k++;}//找出執行中間值時(shí)沒(méi)有執行到的指令序列號
n=len(B3);
for(i=0;il;i++)
for(j=0;jm;j++)
for(k=0;kn;k++)
if(B1[i]==B2[j]B2[j]==B3[k])
{B[p]=B1[i];
P++;
Printf(“不可達指令語(yǔ)句號=%d,”,B[p]); }
Pringf(“n”);
}

3、算法驗證

下面以一個(gè)簡(jiǎn)單的匯編源程序來(lái)驗證算法。

1)根據判定算法,首先把源程度塊的所有語(yǔ)句序列號存入數組A
A={1,2,3,4,5,6,7,8,9,10,11,12}

2)把X=12(大于0的數)時(shí)所執行的語(yǔ)句序列號存入數組A1
A1={1,2,3,4,5,6,7,10,11,12}

3)把X=-3(小于0的數)時(shí)所執行的語(yǔ)句序列號存入數組A2
A2={1,2,3,4,9,10,11,12}

4)把X=0(等于0的數)時(shí)所執行的語(yǔ)句序列號存入數組A3
A3={1,2,3,4,5,10,11,12}

5)分別求出A1、A2、A3的補集B1,B2,B3
B1= ={8,9},
B2= ={5,6,7,8},
B3= ={6,7,8,9}

6)求出B1,B2,B3的交集B
B=B1ΛB2ΛB3={8}

因此可以斷定語(yǔ)句8為不可達指令,從源程序塊中刪除后并不影響程序的正確性。

4、算法復雜度分析

此種算法源于程序塊內,程序結構全部為順序結構和簡(jiǎn)單分支結構,因此遍歷過(guò)程算法復雜度均為O(n),判定交集算法復雜度為O(n2)。因為此算法只是進(jìn)行兩種運算,因此算法綜合復雜度為O(n2)。

5、結論

本文討論了一種判定匯編語(yǔ)言程序不可達指令的算法,并通過(guò)一個(gè)示例程序說(shuō)明了算法的實(shí)現并驗證了其正確性。本文的工作為測試更全面、更有效的進(jìn)行做了必要的補充,下一步需要做的是研究高效的覆蓋測試算法,以提高測試的覆蓋率。



評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>