国产剧情视频在线观看-国产剧情麻豆女教师在线观看-国产剧情精品在线观看-国产剧情精品-国产剧情91-国产玖玖在线观看


曙海教育集團(tuán)論壇軟硬件測試專題軟件測試 → 查找嵌入式C語言程序/軟件中的缺陷的多種技術(shù)討論


  共有10641人關(guān)注過本帖樹形打印

主題:查找嵌入式C語言程序/軟件中的缺陷的多種技術(shù)討論

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個性首頁 | 博客 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發(fā)短信
等級:青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊:2010-11-12 11:08:23
查找嵌入式C語言程序/軟件中的缺陷的多種技術(shù)討論  發(fā)帖心情 Post By:2010-12-15 12:32:28

 

基于模式的靜態(tài)代碼分析、運(yùn)行時內(nèi)存監(jiān)測、單元測試以及數(shù)據(jù)流分析等軟件驗(yàn)證技術(shù)是查找嵌入式C語言程序/軟件缺陷行之有效的方法。上述技術(shù)中的每一種都能查找出某一類特定的錯誤。即便如此,如果用戶僅采用上述技術(shù)中的一種或者幾種來進(jìn)行驗(yàn)證,這樣的驗(yàn)證方法很有可能會漏過對程序中的一些缺陷的檢查。解決此類問題的一種安全和有效的策略就是同時使用上述軟件驗(yàn)證中的所有互補(bǔ)技術(shù)。這樣就能建立起一個牢固的框架來幫助用戶檢查出可能會避開某種特定技術(shù)的缺陷。與此同時,用戶也自然地建立起一個能檢測出關(guān)鍵并且難以查找的功能性錯誤的環(huán)境。

本文將詳盡闡述基于模式的靜態(tài)代碼分析、運(yùn)行時內(nèi)存錯誤檢測、單元測試以及數(shù)據(jù)流分析等自動化技術(shù)共同使用時是如何查找出嵌入式C語言程序/軟件中的缺陷的。本文中將以Parasoft C++test為例來演示上述各項(xiàng)技術(shù)。C++teST是一個經(jīng)廣泛的最佳實(shí)踐證明能提升軟件開發(fā)團(tuán)隊(duì)開發(fā)效率以及軟件質(zhì)量的自動化集成解決方案。

當(dāng)讀者在閱讀本文以及任何時候思考查找到的缺陷時,關(guān)注文中的截圖是很重要的。自動化檢測例如內(nèi)存崩潰和死鎖的缺陷,毫無疑問對任何開發(fā)團(tuán)隊(duì)都是一項(xiàng)必不可少的任務(wù)。盡管如此,最致命的缺陷卻是功能性錯誤,這往往是難以自動發(fā)現(xiàn)的。在本文的結(jié)論部分我們將簡要地討論一下查找這些缺陷的技術(shù)。

情景簡介

為了給出一個具體的示例,我們將就一個我們最近遇到的案例來介紹以及演示我們所推薦的缺陷查找策略:一個運(yùn)行在ARM 板上的簡單傳感器應(yīng)用程序。

假設(shè)我們已經(jīng)創(chuàng)建了該應(yīng)用系統(tǒng),但是當(dāng)我們將程序上載到系統(tǒng)目標(biāo)板上并試圖運(yùn)行該程序時,我們沒有在LCD屏上看到所預(yù)期的輸出。

我們尚不明確系統(tǒng)不能正常工作的原因,因此我們設(shè)法對系統(tǒng)進(jìn)行調(diào)試,但是在目標(biāo)板上進(jìn)行調(diào)試是一件耗時而且煩人的事。因?yàn)槲覀儾坏貌皇謩臃治稣{(diào)試器的結(jié)果并試圖人工判斷出問題的真正原因。或者我們使用一些被證實(shí)能自動定位出錯誤的工具或技術(shù)來幫助我們減輕負(fù)擔(dān)。

從這一點(diǎn)而言,我們要么期待使用調(diào)試器來調(diào)試程序能夠帶來好運(yùn),要么我們嘗試使用一種自動化的測試策略來查找代碼中所存在的錯誤。如果自動化技術(shù)仍然沒有幫助我們查找到錯誤,那么我們不得不回到使用調(diào)試器作為最后的辦法。

基于模式的靜態(tài)代碼分析

這里,我們假設(shè)僅在絕對必要的情況下才使用調(diào)試器進(jìn)行調(diào)試,因此我們從運(yùn)行基于模式的靜態(tài)代碼分析開始。它將查找到如下圖所示的問題:

這是違反了 MISRA 的一個規(guī)則,此違規(guī)說明該處的賦值運(yùn)算符存在一些可疑情況。的確,編程者此處的本意是使用比較運(yùn)算符而不是賦值運(yùn)算符。因此我們將此處檢測到的沖突修改掉,并重新運(yùn)行程序。

我們發(fā)現(xiàn)有了一些改善:一些輸出被顯示在了LCD屏上了。但是,由于一次訪問違規(guī),程序崩潰掉了。因此我們需要再次地做出選擇。我們是應(yīng)該使用調(diào)試器還是繼續(xù)使用自動化的錯誤檢測技術(shù)。由于經(jīng)驗(yàn)告訴我們自動化錯誤檢測技術(shù)能非常高效地檢查出我們當(dāng)前程序所遇到的內(nèi)存崩潰這類問題,因此我們決定使用運(yùn)行時內(nèi)存監(jiān)測來查找問題。

整個程序的運(yùn)行時內(nèi)存監(jiān)測

為了進(jìn)行運(yùn)行時內(nèi)存監(jiān)測,我們使用 C++test 來插裝應(yīng)用程序。這樣的插裝是輕量級的,所以經(jīng)過插裝后的程序適合在目標(biāo)板上運(yùn)行。當(dāng)我們把程序上載到目標(biāo)板上并運(yùn)行經(jīng)過插裝的程序后,我們將結(jié)果下載到PC上,如下的錯誤將被報(bào)告出來:

該結(jié)果指出在第48行代碼處產(chǎn)生了一次讀取數(shù)組越界的錯誤。顯然,msgIndex變量的值肯定超過了數(shù)組的范圍。如果我們隨著堆棧追蹤上一級的原因,我們將發(fā)現(xiàn)此處的打印信息所指示的值的確超出了數(shù)組的范圍(因?yàn)樵谡{(diào)用printMessage()函數(shù)前我們給出了一個錯誤的條件)。我們可以刪除掉這個不必要的條件(value <= 20)以修改這個錯誤。

void handleSensorValue(int value)

{

initialize();

int index = -1;

if (value >= 0 && value <= 10) {

index = VALUE_LOW;

} else if ((value > 10) && (value <= 20)) {

index = VALUE_HIGH;

}

printMessage(index, value);

}

然后我們重新運(yùn)行程序,將不會再報(bào)告任何內(nèi)存錯誤。當(dāng)我們把程序上載到目標(biāo)板上時,它似乎如我們預(yù)期那么在工作了。盡管如此,我們?nèi)匀挥幸恍⿹?dān)心。

我們僅查找到我們所執(zhí)行的代碼路徑中的一個內(nèi)存寫溢出實(shí)例,我們憑什么能夠斷定我們尚未執(zhí)行到的代碼就不會有內(nèi)存寫溢出錯誤了呢?如果我們檢查覆蓋率分析,我們就會發(fā)現(xiàn)reportSensorFailure()這個函數(shù)從未被執(zhí)行到。我們有必要對這個函數(shù)進(jìn)行測試,但是具體如何進(jìn)行呢?建立一個調(diào)用該函數(shù)的單元測試用例就是一個不錯的辦法。

在單元測試中使用運(yùn)行時內(nèi)存監(jiān)測:我們使用C++test的測試用例向?qū)韯?chuàng)建一個測試用例的框架,并向其中添加一些測試代碼。然后運(yùn)行該測試用例——以檢查上面提到的未經(jīng)測試的函數(shù),同時打開運(yùn)行時內(nèi)存監(jiān)測功能。使用C++teST,全過程大約只需要數(shù)秒鐘。

結(jié)果標(biāo)明該函數(shù)已經(jīng)被覆蓋到了,但同時也查找到了新的錯誤:

我們的測試用例查找到了更多的內(nèi)存相關(guān)錯誤。很顯然,當(dāng)失敗處理函數(shù)被調(diào)用時,我們的內(nèi)存初始化存在問題(空指針)。通過更進(jìn)一步的分析,我們發(fā)現(xiàn)在reportSensorValue()函數(shù)中存在函數(shù)調(diào)用順序錯誤。finalize()函數(shù)先于printMessage()函數(shù)被調(diào)用,但是finalize()函數(shù)中釋放了printMessage()函數(shù)需要使用的內(nèi)存。

void finalize()

{

if (messages) {

free(messages[0]);

free(messages[1]);

free(messages[2]);

}

free(messages);

}

將函數(shù)調(diào)用順序進(jìn)行修改后,我們重新運(yùn)行程序。

這樣我們就解決了上面報(bào)告中的第一個錯誤。現(xiàn)在我們再來分析報(bào)告中的第二個錯誤:即打印信息中的AccessViolatiONException。產(chǎn)生這個錯誤的原因是相應(yīng)的消息列表未經(jīng)初始化。為了解決該問題,我們在打印該信息前調(diào)用一次initialize()函數(shù)來對其進(jìn)行初始化。經(jīng)修改后的函數(shù)如下所示:

void reportSensorFailure()

{

initialize();

printMessage(ERROR, 0);

finalize();

}

當(dāng)我們再次運(yùn)行該測試用例時,僅有一個任務(wù)被報(bào)告出來:未經(jīng)驗(yàn)證的單元測試用例(an unvalidated unit test case),這其實(shí)并不算一條錯誤。我們只需對輸出進(jìn)行一下驗(yàn)證,以將該測試用例轉(zhuǎn)換為回歸測試。通過創(chuàng)建合適的斷言,C++test會自動為我們完成這些步驟。

接下來我們再次運(yùn)行整個程序。覆蓋率分析告訴我們幾乎整個程序都已經(jīng)被覆蓋到了,并且沒有發(fā)現(xiàn)任何內(nèi)存錯誤。

這樣就結(jié)束了嗎?其實(shí)不然。雖然我們運(yùn)行了整個程序并為未覆蓋到的函數(shù)創(chuàng)建了單元測試用例,但還是有一些路徑是沒有被覆蓋到的。我們?nèi)匀豢梢岳^續(xù)創(chuàng)建單元測試用例,但是若指望通過這樣的方法來覆蓋程序中的所有路徑將耗費(fèi)相當(dāng)長的時間。或者我們使用另外的方法,使用數(shù)據(jù)流分析來對這些路徑進(jìn)行模擬。

數(shù)據(jù)流分析

我們使用C++test的BugDetective來進(jìn)行數(shù)據(jù)流分析,BugDetective能模擬系統(tǒng)中的不同路徑并檢查這些路徑中是否存在潛在的問題。進(jìn)行數(shù)據(jù)流分析后,我們得到如下結(jié)果:

仔細(xì)分析報(bào)告的結(jié)果,我們發(fā)現(xiàn)程序中存在一條未被覆蓋到的潛在路徑可能會造成在finalize()函數(shù)中出現(xiàn)兩次free的操作。在程序中,reportSensorValue()函數(shù)調(diào)用了finalize()函數(shù),然后finalize()函數(shù)調(diào)用了free()。同時,finalize()函數(shù)還會被mainLoop()函數(shù)調(diào)用。我們可以修改finalize()函數(shù)以使其更加智能化,從而修復(fù)這個問題,修改后的代碼如下:

void finalize()

{

if (messages) {

free(messages[0]);

free(messages[1]);

free(messages[2]);

free(messages);

messages = 0;

}

}

現(xiàn)在我們再次運(yùn)行數(shù)據(jù)流分析,得到的結(jié)果將只有兩個問題:

這里我們可能使用了-1作為索引來訪問了數(shù)組。這是由于整型變量index被設(shè)置的初始值為-1,并且存在一條可能通過if語句的路徑在未將該整型變量正確的進(jìn)行初始化之前便調(diào)用了printMessage()函數(shù)。運(yùn)行時分析未檢查到這樣的一條路徑,并且該路徑很有可能在真實(shí)世界中永遠(yuǎn)不可能被執(zhí)行到。這就是靜態(tài)數(shù)據(jù)流分析相對于運(yùn)真實(shí)運(yùn)行時內(nèi)存監(jiān)測最主要的不足:數(shù)據(jù)流分析能檢查出潛在的路徑,這些路徑可能包含在程序?qū)嶋H執(zhí)行過程中不會執(zhí)行到或不存在的路徑。盡管如此,為了做到有備無患,我們刪除了上述的不必要的條件(value>=0)以修改這個潛在的錯誤。

void handleSensorValue(int value)

{

initialize();

int index = -1;

if (value <= 10) {

index = VALUE_LOW;

} else {

index = VALUE_HIGH;

}

printMessage(index, value);

}

相同地,我們也對最后一個報(bào)告的錯誤進(jìn)行相應(yīng)的處理。現(xiàn)在我們再次運(yùn)行數(shù)據(jù)流分析,將不會再有錯誤被報(bào)告出來。

為了確保程序運(yùn)行一切正常,我們重新運(yùn)行整個分析過程。首先,我們開啟運(yùn)行時內(nèi)存監(jiān)測并運(yùn)行應(yīng)用程序,一切表現(xiàn)正常。然后我們開啟內(nèi)存監(jiān)測并運(yùn)行單元測試,一個任務(wù)被報(bào)告出來:

我們的單元測試檢測到reportSensorFailure()函數(shù)的行為已經(jīng)發(fā)生了改變。這是由于我們已經(jīng)對finalize()函數(shù)進(jìn)行了修改——為了糾正之前報(bào)告的一個問題所做的修改。此處報(bào)告的任務(wù)是為了讓我們注意此修改,并提示我們應(yīng)該對測試用例進(jìn)行相應(yīng)的審查,并且確定是否應(yīng)該對代碼或者測試用例進(jìn)行相應(yīng)的修改,以表示這種新的行為實(shí)際上是我們所預(yù)期的行為。在檢查完代碼之后,我們發(fā)現(xiàn)后者(修改)是正確的并且應(yīng)該更新斷言的正確條件。

/* CPPtest_TEST_CASE_BEGIN test_reportSensorFailure */

/* CPPTEST_TEST_CASE_CONTEXT void reportSensorFailure(void) */

void sensor_tests_test_reportSensorFailure()

{

/* Pre-condition initialization */

/* Initializing global variable messages */

{

messages  = 0 ;

}

{

/* Tested function call */

reportSensorFailure();

/* Post-condition check */

CPPTEST_ASSERT(0 == ( messages ));

}

}

/* CPPTEST_TEST_CASE_END test_reportSensorFailure */

作為最終的確認(rèn),我們需要獨(dú)立地運(yùn)行整個程序——在IDE中關(guān)閉掉運(yùn)行時內(nèi)存監(jiān)測來對程序進(jìn)行構(gòu)建。結(jié)果顯示一切如我們所預(yù)期一樣運(yùn)行。

總結(jié)

作為全文的結(jié)尾,讓我們一起對上述各個步驟進(jìn)行一個鳥瞰式的總結(jié)。

首先,我們開發(fā)的程序并未如我么所預(yù)期那樣運(yùn)行,我們不得不在兩種解決方法中選擇一種來查找程序中的錯誤:通過運(yùn)行調(diào)試器或者使用自動錯誤檢測技術(shù)。

如果我們使用調(diào)試器運(yùn)行代碼來查找錯誤,我們將會看到一些很奇怪的現(xiàn)象:程序中的一些變量總是被賦予了相同的值。基于這種現(xiàn)象我們不得不通過排除法來查找問題的原因——即在應(yīng)該使用比較運(yùn)算符的地方我們錯誤地使用了賦值運(yùn)算符。而靜態(tài)代碼分析則能為我們自動地檢查出該邏輯錯誤。運(yùn)行時內(nèi)存分析是不可能檢查出這種錯誤的,因?yàn)檫@種錯誤與內(nèi)存無關(guān)。數(shù)據(jù)流分析也很有可能找不到這類錯誤因?yàn)閿?shù)據(jù)流分析僅僅是通過這些路徑而不會驗(yàn)證這些條件的正確性。

當(dāng)我們解決了這個問題后,程序可以運(yùn)行了,但是仍然還有內(nèi)存相關(guān)的問題。內(nèi)存相關(guān)的問題是很難被調(diào)試器發(fā)現(xiàn)的;當(dāng)用戶使用調(diào)試器調(diào)試程序時,用戶并不知道內(nèi)存的實(shí)際大小。但是自動錯誤檢查工具能夠做到這點(diǎn)。因此,為了查找這些內(nèi)存問題,我們將整個程序進(jìn)行插裝,并使用運(yùn)行時內(nèi)存分析工具來運(yùn)行程序。這樣我們就能知道到底是那一片內(nèi)存發(fā)生了寫溢出錯誤。

盡管如此,在審查覆蓋率分析結(jié)果的時候,我們注意到在目標(biāo)板上測試的時候,并不是全部代碼都被覆蓋到了。通過自動化的工具得到這樣的覆蓋率信息是簡單的,因?yàn)楣ぞ邥詣拥?/p>

跟蹤覆蓋率,但是,如果我們是通過調(diào)試器,就不得不判斷哪一部分程序經(jīng)過了驗(yàn)證。而這通常只能依靠我們?nèi)斯び涗浀姆绞絹韺?shí)現(xiàn)。

當(dāng)工具提醒我們一些代碼未被覆蓋到時,我們決定改變單元測試來額外地增加我們測試執(zhí)行的覆蓋率。這就揭示了程序中另外一些問題。在目標(biāo)系統(tǒng)的正常測試中,覆蓋所有函數(shù)也許是不可能完成的任務(wù),因?yàn)槠渲幸恍┖瘮?shù)可能是硬件的失敗處理函數(shù)或僅在某些小概率的特定情況下才會被調(diào)用的函數(shù)。而對這些函數(shù)的測試對于一些注重安全性的程序而言又是至關(guān)重要的。試想在飛機(jī)上用來處理速度傳感器問題的程序中存在著代碼錯誤:我們會有系統(tǒng)崩潰的危險(xiǎn),而不是導(dǎo)致某個設(shè)備為非工作狀態(tài)。因此,通過創(chuàng)建單元測試用例來覆蓋這類型的執(zhí)行路徑往往是對其進(jìn)行有效測試的唯一方法。

接下來,我們修復(fù)了工具檢查到的所有問題,同時通過驗(yàn)證相應(yīng)的結(jié)果創(chuàng)建了一個回歸測試用例(作為報(bào)告的任務(wù)之一引導(dǎo)我們完成)。然后我們運(yùn)行數(shù)據(jù)流分析來覆蓋在目標(biāo)系統(tǒng)上即便使用單元測試也未執(zhí)行到的路徑。在此之前,我們幾乎已經(jīng)達(dá)到了100%的代碼行覆蓋率,但是我們的路徑覆蓋率卻未達(dá)到這個水平。BugDetective幫我們發(fā)現(xiàn)了這些方面的一些潛在問題。這些問題可能并沒有實(shí)際發(fā)生或者有可能永遠(yuǎn)不會發(fā)生。也許在實(shí)際運(yùn)行時,這些問題僅僅會在當(dāng)其條件滿足的情況下才會出現(xiàn),并且在現(xiàn)實(shí)生活中,這些條件可能永遠(yuǎn)不可能滿足。盡管如此,我們不能保證隨著代碼的升級,應(yīng)用程序不會執(zhí)行到這些路徑。

安全起見,我們?nèi)匀恍薷牧怂鶊?bào)告的問題以排除任何可能影響它的實(shí)際應(yīng)用執(zhí)行的風(fēng)險(xiǎn)。在修改代碼的同時,我們同時也引入了回歸測試,當(dāng)我們再次運(yùn)行單元測試時立即被檢測到。在所有的自動化錯誤檢測方法中,回歸測試是唯一能夠幫助我們檢查到代碼是否發(fā)生了功能性的改變的方法,并且能驗(yàn)證出對代碼進(jìn)行的修改是否引入了功能性的錯誤以及不可預(yù)知的副作用。最后,我們修改了回歸測試套件,并重新測試代碼,發(fā)現(xiàn)一切運(yùn)行正常。

正如讀者所見,我們使用的一切測試方法——基于模式的靜態(tài)代碼分析、內(nèi)存分析、單元測試、數(shù)據(jù)流分析以及回歸測試——并不是相互競爭的關(guān)系,恰好相反,它們是一種互補(bǔ)的關(guān)系。將上述工具結(jié)合使用,它們就是一套具有強(qiáng)大作用的工具集,并為嵌入式C語言程序/軟件提供一個無可比擬的自動化錯誤檢測解決方案。

總而言之,通過自動地查找很多關(guān)于內(nèi)存和其它編碼的缺陷,我們成功地讓程序運(yùn)行起來了。盡管如此,值得注意的是,最危險(xiǎn)的缺陷卻是實(shí)際的功能性錯誤:例如程序并未如所指定的要求運(yùn)行。而不幸的是,這些錯誤往往是非常難以被發(fā)現(xiàn)的。

查找這類缺陷的最好的一個方式就是通過同行代碼審查來實(shí)現(xiàn)。即另指派至少一人來檢查代碼并且審查代碼與需求內(nèi)容的一致性,這樣用戶就能對實(shí)際程序是否會如預(yù)期那樣運(yùn)行有一個很好的*估。

另外一個十分有用的策略是圍繞代碼創(chuàng)建一個回歸測試套件,這能幫助用戶快捷地驗(yàn)證代碼與規(guī)范的一致性。在本文所描述的示例情景中,單元測試被用來強(qiáng)制執(zhí)行應(yīng)用程序級的運(yùn)行時內(nèi)存監(jiān)測所未覆蓋到的代碼:它能覆蓋到當(dāng)前程序的功能性,在此之后,我們對代碼做了一些修改,它能提醒我們代碼出現(xiàn)的相應(yīng)的功能性問題。事實(shí)上,這種單元測試用例應(yīng)該被更早地創(chuàng)建起來:理想情況下,當(dāng)用戶在實(shí)現(xiàn)程序的功能時就應(yīng)該被創(chuàng)建起來。這樣,用戶就能得到更高的覆蓋率并同時構(gòu)建起一個更強(qiáng)壯的“安全網(wǎng)”來捕捉關(guān)鍵的功能性改變。

Parasoft的C++test能幫助用戶完成這兩個任務(wù):從自動化到管理同行代碼審查流程,以及幫助團(tuán)隊(duì)創(chuàng)建,持續(xù)地運(yùn)行并維護(hù)一個高效的回歸測試套件。

關(guān)于Parasoft C++test

Parasoft C++test是一個經(jīng)廣泛的最佳實(shí)踐證明能提升軟件開發(fā)團(tuán)隊(duì)開發(fā)效率以及軟件質(zhì)量的自動化集成解決方案。C++test能進(jìn)行諸如編碼策略增強(qiáng)、靜態(tài)代碼分析、運(yùn)行時內(nèi)存監(jiān)測、自動同行代碼審查以及單元和組件測試,從而為軟件開發(fā)團(tuán)隊(duì)提供一種更加實(shí)用的方法來確保其C以及C++程序能如所預(yù)期那樣工作。C++test可以用于在通用開發(fā)IDE下的桌面平臺中,以及在回歸測試時通過命令行以批處理模式的方式運(yùn)行。同時,C++test還集成了Parasoft的報(bào)告系統(tǒng),該系統(tǒng)能提供具有細(xì)分能力的基于Web 的儀表板,這使得開發(fā)團(tuán)隊(duì)根據(jù)C++test的測試結(jié)果和其他的一些關(guān)鍵進(jìn)程指標(biāo)來更加方便地跟蹤項(xiàng)目的狀態(tài)和趨勢。

通過在宿主機(jī)上進(jìn)行大量的測試以及在目標(biāo)系統(tǒng)中進(jìn)行的平滑的驗(yàn)證,C++test能夠幫助軟件開發(fā)團(tuán)隊(duì)減少花在嵌入式系統(tǒng)開發(fā)中的時間、精力以及成本。隨著代碼在宿主機(jī)上的構(gòu)建,C++test的自動化框架使得開發(fā)者能在目標(biāo)硬件系統(tǒng)尚未準(zhǔn)備好的情況下就開始測試以提升代碼質(zhì)量。這大大地縮短了花在目標(biāo)系統(tǒng)上測試的時間。早期在宿主機(jī)上構(gòu)建的測試套件可以被重用來在仿真器或真實(shí)的目標(biāo)板上驗(yàn)證程序的功能性。


支持(0中立(0反對(0單帖管理 | 引用 | 回復(fù) 回到頂部

返回版面帖子列表

查找嵌入式C語言程序/軟件中的缺陷的多種技術(shù)討論








簽名
国产剧情视频在线观看-国产剧情麻豆女教师在线观看-国产剧情精品在线观看-国产剧情精品-国产剧情91-国产玖玖在线观看
<dfn id="is4kg"></dfn>
  • <ul id="is4kg"></ul>
  • <abbr id="is4kg"></abbr>
  • <ul id="is4kg"></ul>
    <bdo id="is4kg"></bdo>
    97avcom| 欧美日韩一区综合| 国产伦精品一区二区| 四虎永久国产精品| 国产精品xxx视频| 精品视频一区二区| 久久久午夜视频| 91日本在线视频| 亚洲一区二区三区四区中文| 国产欧美一区二区| 亚洲欧美日产图| 91九色国产视频| 亚洲成人第一| 成人免费视频网| 亚洲欧洲一区二区在线观看| 成人免费激情视频| 午夜欧美一区二区三区免费观看| 国产精品久久久久久久9999 | 国产欧美一区二区三区久久人妖| 久久亚洲综合网| 国产精品91久久| 视频一区三区| 1卡2卡3卡精品视频| 97精品视频在线播放| 国产一区免费在线观看| 91精品国产免费久久久久久 | 国产精品美女主播| 午夜精品区一区二区三| 国产一区私人高清影院| 中文字幕一区二区三区有限公司| av蓝导航精品导航| 日本一欧美一欧美一亚洲视频| 精品一区二区国产| 国产精品男人爽免费视频1| 亚洲精品第一区二区三区| 亚洲一区二区久久久久久| 久久免费福利视频| 九九九九九精品| 国产主播欧美精品| 97在线观看视频国产| 蜜桃av噜噜一区二区三区| 日韩av电影手机在线| 色播五月综合| 国产福利久久精品| 国产剧情久久久久久| 欧美高清视频在线| 人禽交欧美网站免费| 1区1区3区4区产品乱码芒果精品| 国产成人高清激情视频在线观看 | 夜夜春亚洲嫩草影视日日摸夜夜添夜 | 清纯唯美一区二区三区| 亚洲999一在线观看www| 日韩美女毛茸茸| 色综合久久久888| 久久综合福利| 国产精品对白一区二区三区| 国产精选久久久久久| 亚洲97在线观看| 欧美丰满片xxx777| 欧美日韩视频在线一区二区观看视频| 国产精品二区二区三区| 91成人免费在线观看| 国产色视频一区| 国产精品jvid在线观看蜜臀| 91av国产在线| 韩剧1988免费观看全集| 欧美大片免费观看在线观看网站推荐| 午夜精品一区二区三区四区| 日本不卡一区| 青青影院一区二区三区四区| 欧美在线视频二区| 欧美精品一区二区视频| 欧美日韩综合另类| 日本精品一区二区三区不卡无字幕| 狠狠色噜噜狠狠狠狠色吗综合| 丁香婷婷久久久综合精品国产| 亚洲最大福利视频网站| 91视频在线免费观看| 91人成网站www| 国产色视频一区| 91精品美女在线| 国产日本欧美一区二区三区在线| 国产精品大片wwwwww| 国产99久久精品一区二区 夜夜躁日日躁| 国模叶桐国产精品一区| 一区二区三区我不卡| 亚洲图片在线观看| 中文字幕日韩精品一区二区| 亚洲激情一区二区| 色综合91久久精品中文字幕| 在线观看一区二区三区三州| 欧美国产第一页| 久久久久国产精品免费| 97人人爽人人喊人人模波多| 欧美在线一区二区视频| 欧亚精品中文字幕| 国产成人一区二区在线| 国产精品久久一| 成人羞羞国产免费| 国产精品久久九九| 欧美日韩一区综合| 中文字幕中文字幕在线中一区高清 | 91精品国产成人| 性日韩欧美在线视频| 欧美尤物巨大精品爽| 国产成人精品一区| 成人免费观看a| 国产精品一区二区欧美黑人喷潮水| 久久综合福利| 中文字幕一区二区三区四区五区| 国产91精品久久久久久久| 国产精品美女www爽爽爽视频| 亚洲一区中文字幕在线观看| 国精产品99永久一区一区| 欧美一区视久久| 欧美极品少妇xxxxⅹ裸体艺术| 欧美与黑人午夜性猛交久久久| 国产精品免费网站| 国产在线播放一区二区| 91免费在线观看网站| 99热在线播放| 欧美三日本三级少妇三99| 亚洲一区三区视频在线观看| 91精品国产91久久久久久| 国产精品视频一区国模私拍| 91福利视频导航| 欧美国产综合视频| 久久久免费高清电视剧观看| 国产精品美女久久久免费| 痴汉一区二区三区| 亚洲国产欧美日韩| 日本精品视频在线播放| av成人在线电影| 台湾成人av| 国产99久久精品一区二区 夜夜躁日日躁| 亚洲free性xxxx护士hd| 色99中文字幕| 国产精品伦子伦免费视频| 精品无码久久久久国产| 国产综合在线看| 成人免费在线网址| 亚洲日本一区二区三区在线不卡| 国产精品国产三级国产aⅴ浪潮| 国产精品二区在线| 国内精品久久久久久中文字幕 | 国产精品久久久久aaaa九色| 国产精品二区在线| 欧美精品18videos性欧美| 成人免费大片黄在线播放| 日韩国产在线一区| 国产精品美女www| 美女主播视频一区| 日本精品久久久| 久久涩涩网站| 国产精品美女久久久久久免费| 欧美午夜欧美| 国产精品美女呻吟| 色婷婷精品国产一区二区三区| 国产精品黄色影片导航在线观看| 欧美福利一区二区三区| 国产精品18久久久久久首页狼| 国产无套精品一区二区| 国产日韩欧美中文在线播放| 在线综合视频网站| 成人久久一区二区| 欧美夫妻性生活xx| 3d精品h动漫啪啪一区二区| 夜夜春亚洲嫩草影视日日摸夜夜添夜| 国产一区二区丝袜高跟鞋图片| 色女孩综合网| 51蜜桃传媒精品一区二区| 一区高清视频| 国产精品一区二区你懂得| 奇米4444一区二区三区| 欧美欧美一区二区| 成人精品一区二区三区电影免费| 欧美国产精品va在线观看| 99热在线国产| 日本高清久久天堂| 日韩欧美三级电影| 99久久99| 国产精品久久久久久久电影| 亚洲一区二区三区在线观看视频| 产国精品偷在线| 日本韩国欧美精品大片卡二| 亚洲精品tv久久久久久久久| 99九九视频| 日本高清不卡在线| 亚洲综合五月天| 国产亚洲精品自在久久| 国产精品视频最多的网站| 亚洲精品成人a8198a| 国产成人免费电影| 国产精品永久在线| 91国语精品自产拍在线观看性色| 欧美连裤袜在线视频| 91麻豆国产精品| 欧美专区在线视频| 亚洲精品一品区二品区三品区 | av成人在线电影| 国产成人一区二| 欧美激情精品久久久久久| 久久综合中文色婷婷| 亚洲自拍偷拍福利| 国产成人综合精品| 性欧美亚洲xxxx乳在线观看| 四虎影院一区二区三区| 黑人中文字幕一区二区三区| 成人情趣片在线观看免费| 日本亚洲欧洲色| 久久久久久久色| 五月天丁香综合久久国产| 国产日韩欧美二区| 亚洲自拍av在线| 国产精品一区二区三| 日产精品99久久久久久| 91成人精品网站| 欧美精品第一页在线播放| 欧美日本国产精品| 久久精品美女| 极品尤物一区二区三区| 99影视tv| av电影成人| 91日本视频在线| 国产日韩欧美影视| 国产精品自产拍在线观| 国产精品av电影| 国语自产精品视频在线看| 中文字幕一区二区三区5566| 日韩电影大全在线观看| 精品国产免费久久久久久尖叫| 91丨九色丨国产| 欧美激情中文字幕乱码免费| 一区二区三视频| 日韩欧美在线观看强乱免费| 欧洲精品一区色| 日本不卡二区| 日本午夜精品电影| 无码免费一区二区三区免费播放| 日韩一本精品| 亚洲一区二区三区欧美| 中文字幕一区二区中文字幕| 中文字幕精品—区二区日日骚| 亚洲在线欧美| 欧美激情乱人伦| 久久久久这里只有精品| 韩日欧美一区二区| 欧美中文字幕在线播放| 日韩av免费在线看| 国产精品黄页免费高清在线观看| 国产精品777| 国产精品视频yy9099| 国产精品香蕉国产| 成人久久久久久久| 91精品国产一区二区三区动漫 | 欧美专区第一页| 欧美亚洲午夜视频在线观看| 日本精品视频在线播放| 国产成人精品日本亚洲专区61| 热99精品里视频精品| 国产精品成人播放| 91精品久久久久久久久久另类| 成人黄色免费在线观看| 91网免费观看| 久久精品第九区免费观看| 欧美日韩一区二区三区免费| 亚洲一区二区三区午夜| 久久久综合免费视频| 911国产网站尤物在线观看| 国产成人精品在线视频| 成人黄色网免费| 国产精品.com| 日韩精品一区二区三区色偷偷 | 97超视频免费观看| 国产成人精品午夜| 91久久精品国产| 久久精品二区| 欧美国产乱视频| 国产成人精品一区二区| 91免费看国产| 久久久国产精品一区二区三区| 亚洲国产另类久久久精品极度| 91av国产在线| 91久久精品www人人做人人爽| 蜜桃传媒视频麻豆第一区免费观看 | 国产成人精品视频在线观看| 国产日韩欧美电影在线观看| 国语精品中文字幕| 欧美丰满少妇xxxxx| 国产精品99导航| 国产伦精品一区二区三区免| 亚洲综合欧美日韩| 国产精品极品在线| 精品一区二区三区日本| 韩国欧美亚洲国产| 3d动漫啪啪精品一区二区免费| 日韩国产高清一区| 日韩美女av在线免费观看| 成人资源av| 综合一区中文字幕| 久精品国产欧美| 97国产精品久久| 亚洲一区二区三区香蕉| 欧美在线视频二区| 欧美专区中文字幕| 国产一级特黄a大片99| 欧美国产在线电影| 91久久国产精品91久久性色| 鲁鲁视频www一区二区| 97超视频免费观看| 国产98在线|日韩| 中国人体摄影一区二区三区| 91精品国产综合久久久久久久久| 麻豆亚洲一区| 国产成人黄色av| 久久精品日韩| 日本一本a高清免费不卡| 国产成人精品福利一区二区三区 | av噜噜色噜噜久久| 欧美黄色www| 99久热re在线精品996热视频| 欧美疯狂性受xxxxx另类| 成人激情视频在线观看| 一本一道久久a久久综合精品| 国产精品一区久久久| 日韩区国产区| 成人网在线视频| 欧美激情精品久久久久久黑人 | 国产乱码精品一区二区三区日韩精品| 中文字幕久久综合| 97久久精品午夜一区二区| 一区二区三区四区五区视频 | 国产伦精品一区二区三区免| 国内精品在线一区| 精品久久sese| 国产精品电影久久久久电影网| 欧美一区亚洲二区| 成人av番号网| 中文字幕日韩精品久久| yellow视频在线观看一区二区 | 国产成人成网站在线播放青青| 久久全国免费视频| 精品一区二区不卡| 国产精品香蕉av| 欧美激情视频一区二区| 精品久久久久久亚洲| 国产精品免费一区二区三区都可以| 图片区小说区区亚洲五月| 91国产在线播放| 国产99久久精品一区二区永久免费 | 国产精品二区三区四区| 日韩美女毛茸茸| 亚洲亚洲精品三区日韩精品在线视频| 成人片在线免费看| 国产精品入口福利| 国内伊人久久久久久网站视频 | 国产成人精品福利一区二区三区 | 国模精品系列视频| 欧美日韩在线观看一区二区三区 | 国语自产精品视频在线看| 精品一区二区三区视频日产| 国产日韩精品在线观看| 97在线视频精品| 日韩中文一区| 国产一区福利视频| 亚洲999一在线观看www| 国产成人高潮免费观看精品| 欧美激情中文字幕乱码免费| 日本一区二区免费看| 国产高清精品一区| 成人信息集中地欧美| 国产91色在线播放| 91精品国产91久久久久久久久 | 精品亚洲一区二区三区四区五区高| 91av视频在线免费观看| 91精品国产高清自在线| 亚洲二区自拍| 欧美精品一区二区视频 | 欧美一区二区三区图| 一区二区欧美日韩| 欧美日韩国产精品一区二区| 国产美女精品久久久| 444亚洲人体| 国产欧亚日韩视频| 日韩av片免费在线观看| 韩国19禁主播vip福利视频| 亚洲欧美影院| 色播亚洲婷婷| 日本一区二区精品| 欧美高清性xxxxhd| 蜜桃日韩视频| 免费影院在线观看一区| 精品无码久久久久国产| 国产欧美韩日| 国产精品亚洲综合| 国产精品10p综合二区| 91福利视频导航| 亚洲精品日产aⅴ| 亚洲xxxxx电影| 成人中文字幕在线观看| 国产精品视频最多的网站| 国产成人高清激情视频在线观看| 清纯唯美亚洲激情| 国产福利精品在线| 国产福利精品视频| 国产精品色视频| 国产精品亚洲片夜色在线| 国产精品黄页免费高清在线观看| 国产精品久久视频| 成人黄色大片在线免费观看| 91啪国产在线| 国产91aaa| 久久99精品久久久久久秒播放器 | 色噜噜一区二区| 天堂av一区二区| 亚洲一二区在线| 欧美大片网站在线观看| 97精品伊人久久久大香线蕉| 欧美孕妇性xx| 国产精品久久网| 成人性生交xxxxx网站| 91亚洲精品在线观看| 高清日韩一区| 久久久久久久久久久一区 | 一区二区在线观| 欧美极品美女电影一区| 91黑丝在线观看| 国产精品久久久久久亚洲调教| 成人免费在线视频网站| 国产精品久久国产三级国电话系列| 极品尤物一区二区三区| 日韩资源av在线| 久久久久久久久久av| 欧美一级片在线播放| 国产精品色午夜在线观看| 亚洲精品日产aⅴ| 精品一区久久久久久| 亚洲精品久久久久久一区二区| 国模精品系列视频| 国产精品日韩av| 鬼打鬼之黄金道士1992林正英| 久久一区免费| 欧美精品18videos性欧美| 国产精品96久久久久久| 91久久精品国产91久久性色tv| 精品视频在线观看| 中文字幕一区二区三区精彩视频| 国产69精品久久久久久| 成人中文字幕+乱码+中文字幕| 国严精品久久久久久亚洲影视| 性欧美videosex高清少妇| 欧美性受xxxx白人性爽| 91亚洲永久免费精品| 九色91视频| 欧美激情啊啊啊| 国产精品青青在线观看爽香蕉 | | 国产精品最新在线观看| 国产欧美日韩综合精品二区| 亚洲一卡二卡三卡四卡无卡网站在线看| 2019中文在线观看| 91色p视频在线| 日本视频一区在线观看| 清纯唯美亚洲激情| 99精品国产一区二区| 亚洲电影免费| 国产精品久久久久久久9999| 精品久久久久亚洲| 97在线观看免费| 国产欧美一区二区三区久久人妖| 美女精品国产| 91精品国产沙发| 岛国视频一区免费观看| 欧美黄色片视频| 91免费国产网站| 日韩在线电影一区| 国产精品久久一区主播| 欧美久久久久久一卡四| 欧美中文字幕视频在线观看| 国产伦精品一区二区三区免| 国内精品美女av在线播放| 91传媒视频在线观看| 欧美黑人极品猛少妇色xxxxx| 国产一区二区丝袜| 色婷婷精品国产一区二区三区| 国产精品久久久久福利| 欧美 日韩 国产在线| 国产成人精品免费视频| 精品乱色一区二区中文字幕| 欧美在线视频一区| 九色91视频| 国产精品第10页| 亚洲精品国产一区| 亚洲xxxx18| 欧美激情综合亚洲一二区| 97夜夜澡人人双人人人喊| 久久人91精品久久久久久不卡| 国产传媒一区| 欧美最猛性xxxx| 欧美日韩在线观看一区| 国产欧美精品日韩| 欧美丰满老妇厨房牲生活| 都市激情久久久久久久久久久| 97av在线影院| 日本不卡二区| 69堂成人精品视频免费| 8x拔播拔播x8国产精品| 欧美不卡在线一区二区三区| 国产女同一区二区| 久久久久久久激情视频| 久99久视频| 国产一区私人高清影院| 欧美黄色性视频| 久久久国产精品一区二区三区| 国产精品天天狠天天看| 在线一区高清| 精品综合久久| 成人免费看吃奶视频网站| 97国产suv精品一区二区62| 久久免费视频1| 国产日韩欧美中文在线播放| 久久久久久久色| 久久久久久久久久码影片| 成人精品福利视频| 51午夜精品视频| 日韩av图片| 成人在线免费网站| 国产精品视频色| 91国产精品电影| 色狠狠久久av五月综合| 国产精品免费看一区二区三区| 国产脚交av在线一区二区| 欧美夫妻性生活xx| 欧美乱偷一区二区三区在线| 91精品久久香蕉国产线看观看| 亲子乱一区二区三区电影| 一本一道久久久a久久久精品91| 精品欧美一区二区在线观看视频| 91精品久久久久久久久久久| 97超级碰碰碰| 欧美国产视频日韩| 色播亚洲视频在线观看| 国产欧美日韩视频一区二区三区| 成人日韩在线电影| 国产精品99久久久久久人| 午夜精品三级视频福利| 视频一区二区三区免费观看| 蜜桃久久影院| 产国精品偷在线| 7777精品伊久久久大香线蕉语言| 国产精品久久久久久久一区探花| 欧美野外猛男的大粗鳮| 欧美精品久久久久久久| 亚洲精品在线观看免费| 欧美日韩成人一区二区三区| 国产区一区二区三区| 99r国产精品视频| 成人精品在线视频| 国产日韩精品综合网站| 国产成人精品国内自产拍免费看| 91tv亚洲精品香蕉国产一区7ujn| 一本色道久久综合亚洲二区三区| 日产精品久久久一区二区| 精品国产免费一区二区三区| 99re国产视频| 91九色露脸| 成人免费91在线看| 99久久久精品免费观看国产| 91久久极品少妇xxxxⅹ软件| 成人综合国产精品| 成人免费视频网址| 国产日韩综合一区二区性色av| 国产一区私人高清影院| 国产免费一区二区三区在线观看| 国产精品黄页免费高清在线观看| 日本欧美爱爱爱| 国产精品r级在线| 国产精品九九久久久久久久| 国产精品爱久久久久久久| 日韩女优在线播放| 国产精品国产福利国产秒拍| 国产精品爱久久久久久久| 国产精品日韩在线观看| 国产精品免费一区豆花| 国产在线精品播放| 亚洲国产高清国产精品| 亚洲欧美国产不卡| 欧美丰满老妇厨房牲生活| 欧美极品少妇全裸体| 国语对白做受69| 欧洲成人免费视频| 国产精品美女无圣光视频| 国产美女久久精品香蕉69| 日韩免费精品视频| 欧美日韩一区在线视频| 欧美一区二区三区精美影视 | 亚洲高清视频在线观看| 一道精品一区二区三区 | 91九色在线观看| 国产伦精品一区二区三|