• <tr id="yyy80"></tr>
  • <sup id="yyy80"></sup>
  • <tfoot id="yyy80"><noscript id="yyy80"></noscript></tfoot>
  • 99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

    基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測方法

    2022-09-06 07:31:30東春浩高鴻斌
    計算機研究與發(fā)展 2022年9期
    關(guān)鍵詞:檢測工具測試程序競爭

    張 楊 喬 柳 東春浩 高鴻斌

    (河北科技大學(xué)信息科學(xué)與工程學(xué)院 石家莊 050018)

    (zhangyang@hebust.edu.cn)

    數(shù)據(jù)競爭[1]是指2個或多個線程同時訪問1個內(nèi)存位置并且至少有1個線程執(zhí)行寫操作.數(shù)據(jù)競爭是目前最常見的并發(fā)缺陷之一,它是一種典型的運行時故障,通常在特定的并發(fā)執(zhí)行環(huán)境中發(fā)生,難以被檢測,它的存在會給程序運行帶來潛在的風(fēng)險,嚴(yán)重時會導(dǎo)致程序無法正常運行甚至崩潰,造成無法估量的損失,因此迫切需要對數(shù)據(jù)競爭檢測問題進(jìn)行研究.

    數(shù)據(jù)競爭檢測一直是國內(nèi)外并發(fā)缺陷研究領(lǐng)域的熱點問題之一,很多學(xué)者對數(shù)據(jù)競爭檢測問題進(jìn)行了研究,所采用的方法包括基于動態(tài)程序分析的檢測方法、基于靜態(tài)程序分析的檢測方法、動靜結(jié)合的檢測方法[2-4].基于動態(tài)程序分析的檢測方法在程序運行過程中,通過監(jiān)控程序執(zhí)行路徑和內(nèi)存讀寫訪問等方式檢測數(shù)據(jù)競爭的發(fā)生,這種檢測方式的優(yōu)點在于誤報率較低,缺點是數(shù)據(jù)競爭的漏報率較高,而且檢測過程開銷較大.已有的動態(tài)數(shù)據(jù)競爭檢測工具有Said[5],RVPredict[6],SlimFast[7]等.與動態(tài)數(shù)據(jù)競爭檢測方法不同,靜態(tài)數(shù)據(jù)競爭檢測在源代碼或中間代碼層次展開,通過分析程序中變量的讀寫訪問,輔助以各種靜態(tài)程序分析技術(shù)(如發(fā)生序分析、別名分析、逃逸分析等)進(jìn)行數(shù)據(jù)競爭檢測.這種檢測方式的優(yōu)點在于可以在程序運行之前排除相關(guān)問題,不僅開銷較小,而且檢測較為全面,漏報率較低;缺點在于僅在代碼層面進(jìn)行分析而沒有真正運行程序,可能會導(dǎo)致很多誤報,已有的靜態(tài)檢測工具包括RELAY[8],Elmas[9],SRD[10]等.此外,為了彌補以上2種方式各自的不足,有些研究人員也嘗試將動態(tài)分析和靜態(tài)分析2種檢測方法結(jié)合起來,以此提高檢測的整體效率,常用的動靜結(jié)合的檢測工具有RaceTracker[11]和AsampleLock[12]等.

    近年來,隨著機器學(xué)習(xí)和深度學(xué)習(xí)技術(shù)的發(fā)展和廣泛應(yīng)用,一些研究人員開始將相關(guān)技術(shù)應(yīng)用于數(shù)據(jù)競爭檢測.在國內(nèi),孫家澤等人[13-14]提出一種基于機器學(xué)習(xí)的數(shù)據(jù)競爭檢測方法,該方法使用隨機森林模型,收集指令級別數(shù)據(jù),進(jìn)行數(shù)據(jù)競爭檢測,而且他們還基于Adaboost模型進(jìn)行語句級并發(fā)程序數(shù)據(jù)競爭檢測,該方法的準(zhǔn)確率可達(dá)92%.在國外,Tehrani等人[15]通過提取文件級別的特征來構(gòu)建數(shù)據(jù)競爭訓(xùn)練數(shù)據(jù)集,他們提出一種基于卷積神經(jīng)網(wǎng)絡(luò)(convolutional neural network, CNN)的數(shù)據(jù)競爭檢測方法,實驗表明該方法檢測的準(zhǔn)確率在83%~86%.

    從目前的研究現(xiàn)狀來看,一些研究人員從程序分析的角度開展數(shù)據(jù)競爭檢測研究,另一些研究人員將程序作為語料庫,使用機器學(xué)習(xí)和深度學(xué)習(xí)方法開展研究,雖然已有的檢測方法取得了一定的成效,但仍存在3個方面的問題亟需進(jìn)一步研究完善:

    1) 目前已有工作所使用的學(xué)習(xí)模型主要依賴于深度學(xué)習(xí)中CNN模型和機器學(xué)習(xí)中隨機森林模型,模型還有待于優(yōu)化,準(zhǔn)確率還有提升的空間.

    2) 在構(gòu)建數(shù)據(jù)集時,現(xiàn)有的基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測工具[15]僅應(yīng)用了3個不同的基準(zhǔn)測試程序,所提取的數(shù)據(jù)集樣本個數(shù)較少,在輸入到深度學(xué)習(xí)模型時會導(dǎo)致檢測精度下降.

    3) 在特征抽取時,僅提取指令或文件等級別的某一方面的特征,無法充分反映數(shù)據(jù)競爭的真實情況.

    針對目前研究存在的問題,本文提出一種基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測方法DeleRace(deep-learning-based data race detection).該方法首先使用程序靜態(tài)分析工具WALA[16]從多個實際應(yīng)用程序中提取指令、方法和文件級別中多個代碼特征,對其向量化并構(gòu)造訓(xùn)練樣本數(shù)據(jù);然后通過ConRacer[17]工具對真實數(shù)據(jù)競爭進(jìn)行判定進(jìn)而標(biāo)記樣本數(shù)據(jù),并采用SMOTE[18]增強算法使正負(fù)數(shù)據(jù)樣本分布均衡化;最后構(gòu)建CNN-LSTM[19]的深度神經(jīng)網(wǎng)絡(luò),加以訓(xùn)練構(gòu)建分類器,進(jìn)而實現(xiàn)對數(shù)據(jù)競爭的檢測.在實驗中選取DaCapo[20],JGF[21],IBM Contest[22],PJBench[23]這4個基準(zhǔn)測試程序套件中的26個基準(zhǔn)程序進(jìn)行數(shù)據(jù)競爭檢測,結(jié)果表明DeleRace的準(zhǔn)確率為96.79%,與目前已有的基于深度學(xué)習(xí)的檢測方法DeepRace相比提升了4.65%.與RNN和LSTM相比,DeleRace采用的CNN-LSTM網(wǎng)絡(luò)也具有較高的準(zhǔn)確率.此外,我們將DeleRace與已有的動態(tài)數(shù)據(jù)競爭檢測工具(Said和RVPredict)和靜態(tài)數(shù)據(jù)競爭檢測工具(SRD和ConRacer)進(jìn)行比較,結(jié)果表明DeleRace可以檢測出更多真實有效的數(shù)據(jù)競爭.

    本文的主要貢獻(xiàn)有3個方面:

    1) 從26個不同領(lǐng)域的實際應(yīng)用程序提取指令、方法和文件等多個級別的特征構(gòu)建深度學(xué)習(xí)模型訓(xùn)練數(shù)據(jù)集和測試數(shù)據(jù)集.

    2) 提出一種適合數(shù)據(jù)競爭檢測的深度學(xué)習(xí)模型DeleRace,使用CNN的卷積核提取相關(guān)特征,借助LSTM提取時序特征,通過CNN和LSTM的結(jié)合提升檢測精度.

    3) 將DeleRace與現(xiàn)有的基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測工具進(jìn)行了對比,并與已有的基于程序分析的數(shù)據(jù)競爭檢測工具進(jìn)行比較,驗證了DeleRace的有效性.

    1 基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測方法

    本節(jié)首先給出DeleRace的檢測框架,然后對框架中的每個部分進(jìn)行詳細(xì)介紹.

    1.1 檢測框架

    為了對數(shù)據(jù)競爭進(jìn)行檢測,提出了一個基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測框架DeleRace.首先,為了構(gòu)建深度學(xué)習(xí)模型的訓(xùn)練數(shù)據(jù)集,DeleRace從DaCapo[20],JGF[21],IBM Contest[22],PJBench[23]四個基準(zhǔn)測試程序套件中選取26個含有數(shù)據(jù)競爭的并發(fā)程序,然后使用靜態(tài)程序分析工具提取數(shù)據(jù)競爭發(fā)生位置的上下文特征信息,構(gòu)造訓(xùn)練和測試樣本,并且在樣本數(shù)據(jù)中對真實有效的數(shù)據(jù)競爭進(jìn)行標(biāo)記.為了使提取的文本特征樣本更易于被深度學(xué)習(xí)模型所處理,DeleRace使用Keras[24]的嵌入層對訓(xùn)練樣本中文本特征進(jìn)行向量化.考慮到收集的并發(fā)程序中含有數(shù)據(jù)競爭正樣本數(shù)可能較少,會導(dǎo)致正樣本和負(fù)樣本分布不均衡,我們使用數(shù)據(jù)增強算法增加正樣本的數(shù)量,盡可能地保證正負(fù)樣本均衡分布.最后,構(gòu)建了一個CNN-LSTM深度神經(jīng)網(wǎng)絡(luò)模型,使用訓(xùn)練集對該模型進(jìn)行訓(xùn)練,得到訓(xùn)練好的分類器,使用該分類器進(jìn)行數(shù)據(jù)競爭檢測.基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測框架如圖1所示:

    Fig. 1 The framework of DeleRace圖1 DeleRace方法框架

    1.2 選取實際應(yīng)用程序

    由于目前沒有公開的專門用于數(shù)據(jù)競爭檢測的數(shù)據(jù)集,為了訓(xùn)練深度神經(jīng)網(wǎng)絡(luò)進(jìn)行數(shù)據(jù)競爭檢測,我們首先構(gòu)建數(shù)據(jù)競爭的訓(xùn)練數(shù)據(jù)集.

    1.3 特征提取

    已有的方法在提取數(shù)據(jù)競爭特征時相對單一,無法充分體現(xiàn)數(shù)據(jù)競爭的產(chǎn)生條件,例如文獻(xiàn)[13-14]分別提取指令和語句級別的特征,而文獻(xiàn)[15]僅提取了文件級別的特征.為了充分提取特征,我們在構(gòu)建數(shù)據(jù)集樣本時充分考慮了數(shù)據(jù)競爭產(chǎn)生的條件,依據(jù)這些條件提取多個級別的程序相關(guān)特征.

    數(shù)據(jù)競爭的產(chǎn)生條件包括:1)2個或多個線程對同一個共享內(nèi)存單元進(jìn)行并發(fā)訪問;2)至少有1個為寫操作;3)各個操作之間沒有被使用同一監(jiān)視器對象的鎖保護(hù).基于這3個條件,我們從收集的基準(zhǔn)程序中選取多個級別的特征來構(gòu)建數(shù)據(jù)集樣本,其中包括訪問操作指令相關(guān)信息(如指令的Hash值、是否為寫操作、是否被同步塊包含、是否被同步方法包含)和數(shù)據(jù)競爭發(fā)生位置的相關(guān)信息(如包名、類名、方法名和變量名),其中前4個特征用于表明數(shù)據(jù)競爭的產(chǎn)生條件,后4個特征用于表明數(shù)據(jù)競爭發(fā)生的位置.

    DeleRace借助程序靜態(tài)分析工具WALA[16]進(jìn)行特征提取,主要操作包括:

    1) 通過方法makeNCFABuilder()構(gòu)建程序的控制流圖cg.

    2) 遍歷控制流圖cg,收集所有節(jié)點cgNode下的訪問操作,獲取訪問字段中的指令,判斷該指令是否為寫操作,判斷是否被同步塊或同步方法包含,并通過指令對應(yīng)的內(nèi)存地址來生成Hash值,將其作為變量訪問的唯一標(biāo)識.

    3) 通過以上方法獲得所有變量訪問操作,將每個線程的訪問操作存入集合V中,V定義為

    V=〈isWrite,hashCode,isSyn,isSynBlock〉,

    (1)

    其中isWrite表示是否為寫操作,hashCode表示變量訪問操作指令的Hash值,isSyn表示是否被同步方法包含,isSynBlock表示是否被同步塊包含.遍歷每個線程集合中的所有訪問操作,與不同線程的訪問操作進(jìn)行對比判斷,獲得所有可能存在競爭的訪問操作對.

    4) 通過獲取包名、類名、方法名以及所有靜態(tài)變量和實例變量表明每對訪問操作發(fā)生數(shù)據(jù)競爭的位置,判斷其訪問變量是否相同.

    這里對特征提取后的表現(xiàn)形式進(jìn)行演示,如表1和表2所示.表1展示了IBM Contest[22]基準(zhǔn)測試程序套件中的Account程序中部分?jǐn)?shù)據(jù)的數(shù)值特征信息.其中,“讀寫訪問”列中的“1”代表寫操作,“0”代表讀操作;“標(biāo)簽”列中“1”代表構(gòu)成數(shù)據(jù)競爭,“0”代表不構(gòu)成數(shù)據(jù)競爭;其他列中的“1”代表是,“0”代表否,每一條數(shù)據(jù)樣本包括2個訪問操作,每個訪問操作包含讀寫訪問、Hash值、同步方法、同步塊等4條指令級別的特征.

    Table 1 Numerical Feature表1 數(shù)值特征信息

    Table 2 Text Feature表2 文本特征信息

    表2展示了IBM Contest[22]基準(zhǔn)測試程序套件中的Account程序中部分?jǐn)?shù)據(jù)的文本特征.“標(biāo)簽”列中“1”表示構(gòu)成數(shù)據(jù)競爭,“0”表示不構(gòu)成數(shù)據(jù)競爭,每一條數(shù)據(jù)樣本包括2個訪問操作,每個訪問操作均包含包名、類名、方法名、變量名等文本特征,其中包名和類名為文件級別的特征,方法名和變量名為方法級別的特征.

    Fig. 2 Text feature vectorization圖2 文本特征向量化

    我們借助ConRacer[17]工具對真實數(shù)據(jù)競爭進(jìn)行判定,并對樣本數(shù)據(jù)進(jìn)行標(biāo)記.之所以選擇ConRacer工具,是因為ConRacer在對數(shù)據(jù)競爭的分析過程中考慮了方法調(diào)用的上下文信息,誤報和漏報都相對較少.然而在實際應(yīng)用中ConRacer也不是完美的,仍存在一些誤報和漏報,為了確保數(shù)據(jù)集標(biāo)記的準(zhǔn)確性,我們對標(biāo)記情況進(jìn)行了手動驗證,保證數(shù)據(jù)集的正確性.

    1.4 文本特征向量化

    深度學(xué)習(xí)模型在訓(xùn)練時一般采用數(shù)值向量數(shù)據(jù)作為輸入,通常不會直接采用文本數(shù)據(jù).為了使訓(xùn)練數(shù)據(jù)和測試數(shù)據(jù)易于被深度學(xué)習(xí)模型所使用,需要把提取的文本特征轉(zhuǎn)化為數(shù)值向量.在文本特征向量化的過程中,由于指令級別的特征信息本身為整數(shù)(如表1所示),因此無需將其向量化;而對于方法和文件級別的特征,由于在特征抽取階段獲得的均為文本數(shù)據(jù)(如表2所示),因此需將其轉(zhuǎn)化為數(shù)值向量.

    DeleRace使用Keras[24]的嵌入層進(jìn)行文本特征向量化,該層采用有監(jiān)督的學(xué)習(xí)方式,基于已經(jīng)標(biāo)記好的信息進(jìn)行學(xué)習(xí)并更新權(quán)重,其定義可表示為

    f:Mi→Rn,

    (2)

    其中,Mi表示第i個文本特征的整數(shù)編碼;Rn表示Mi對應(yīng)的n維向量;f是一個參數(shù)化函數(shù)映射,表示將單詞映射到n維向量.

    圖2以Account測試程序中某一文件級別的特征信息為例演示了文本特征向量化的過程,這里設(shè)置詞向量維度n=8.首先將單詞表中的單詞進(jìn)行詞頻統(tǒng)計并進(jìn)行整數(shù)編碼,將單詞轉(zhuǎn)換為數(shù)值向量時不區(qū)分大小寫,因此單詞Account與單詞account的編碼均為18,其他單詞out,num編碼分別為135,100;然后將每個單詞的編碼M經(jīng)過嵌入層處理后映射為一個8維向量,此時得到文本向量化的表示是隨機的,我們對嵌入層進(jìn)行訓(xùn)練并更新權(quán)重;最后得到一個真正可以代表每個單詞的數(shù)值向量,單詞間通過各自對應(yīng)的數(shù)值向量反映單詞間相關(guān)性,通過計算均值使每一個單詞僅用一個數(shù)值來表示.

    1.5 數(shù)據(jù)均衡分布

    DeleRace在樣本數(shù)據(jù)的提取過程中,由于這些并發(fā)程序中數(shù)據(jù)競爭的數(shù)量很少,導(dǎo)致數(shù)據(jù)集中所提取的含有數(shù)據(jù)競爭的樣本數(shù)遠(yuǎn)少于不含有數(shù)據(jù)競爭的樣本數(shù),這導(dǎo)致標(biāo)簽為正樣本和負(fù)樣本的數(shù)量極度不均衡,如果使用該數(shù)據(jù)集進(jìn)行訓(xùn)練會嚴(yán)重影響深度學(xué)習(xí)模型的準(zhǔn)確率.為了解決這個問題,通常采用欠采樣(undersampling)和過采樣(oversampling)2種方法.其中,欠采樣方法會從多數(shù)樣本中減少訓(xùn)練實例,該方法只會減少不含數(shù)據(jù)競爭的樣本,雖可以保證數(shù)據(jù)均衡分布,但減少了樣本數(shù)量;過采樣方法通過分析少數(shù)樣本來增加訓(xùn)練實例,有助于增加數(shù)據(jù)競爭的正樣本數(shù).此外,考慮到欠采樣方法一方面可能會因為減掉的數(shù)據(jù)導(dǎo)致某些關(guān)鍵信息丟失,另一方面減少訓(xùn)練樣本也很有可能導(dǎo)致模型精度下降,因此本文采用過采樣方法來達(dá)到數(shù)據(jù)均衡分布的目的,既可以保證特征信息的完整,又有助于擴充訓(xùn)練樣本從而提高模型精度.

    在過采樣過程中,DeleRace使用SMOTE算法[18]進(jìn)行數(shù)據(jù)增強,它是一種合成少數(shù)類的過采樣技術(shù),其基本思想是對少數(shù)類樣本進(jìn)行分析,并根據(jù)少數(shù)類樣本合成新樣本,然后添加到數(shù)據(jù)集中,如圖3所示.這里先選定一個正樣本,找出這個正樣本的K近鄰(假設(shè)K=4),隨機從K個近鄰中選擇一個樣本,在正樣本和被選出的近鄰樣本的連線上隨機找一個點,這個點就是我們生成的新的正樣本,一直重復(fù)這個過程,直到正樣本和負(fù)樣本數(shù)量均衡.通過SMOTE算法,將原有的12 836條訓(xùn)練樣本擴充到25 438條,從而使正樣本和負(fù)樣本的數(shù)據(jù)樣本數(shù)量達(dá)到了均衡.

    Fig. 3 SMOTE algorithm[18] 圖3 SMOTE算法[18]

    1.6 CNN-LSTM神經(jīng)網(wǎng)絡(luò)

    本文采用CNN-LSTM的神經(jīng)網(wǎng)絡(luò)模型,該模型在Keras中實現(xiàn).CNN并非只能處理圖像,在NLP領(lǐng)域也能夠很精準(zhǔn)地處理分類任務(wù),比如在情感分析[25]和觀點分類[26]中都發(fā)揮了很好的作用.使用CNN進(jìn)行文本分類最顯著的優(yōu)勢是其無需人工手動地提取文本特征,可以自動獲取基礎(chǔ)特征并組合為高級特征,訓(xùn)練模型獲得文本特征與目標(biāo)分類之間的關(guān)系.我們借助CNN模型中卷積層的卷積核提取特征,然后使用最大池化層對上一層卷積層進(jìn)行降維,既降低提取特征的數(shù)據(jù)維度,又保留了具有代表性的特征.

    雖然CNN在處理文本分類問題上存在諸多益處,但由于卷積核的存在,導(dǎo)致CNN在處理時序信號數(shù)據(jù)時存在“長期依賴”問題.針對這一問題,我們選擇了LSTM神經(jīng)網(wǎng)絡(luò)與CNN進(jìn)行結(jié)合.LSTM是長短期記憶神經(jīng)網(wǎng)絡(luò),可以有效解決“長期依賴”問題,不僅如此,LSTM既能解決RNN在訓(xùn)練時反向傳播帶來的“梯度消失”問題,又能夠獲得源代碼中的語義關(guān)系.源程序中的包名、類名、方法名和變量名多以功能命名,因此不同層次中的語義信息與數(shù)據(jù)競爭息息相關(guān).我們選取不同層次的文本特征,通過LSTM層,可以提取其中的語義關(guān)系[27],例如包含關(guān)系和上下文關(guān)系等,這有助于檢測數(shù)據(jù)競爭,提高檢測精度.

    構(gòu)建的CNN-LSTM神經(jīng)網(wǎng)絡(luò)架構(gòu)如圖4所示:

    Fig. 4 CNN-LSTM deep neural network model圖4 CNN-LSTM深度神經(jīng)網(wǎng)絡(luò)模型

    訓(xùn)練網(wǎng)絡(luò)時,首先將每對訪問操作的特征信息輸入到CNN-LSTM神經(jīng)網(wǎng)絡(luò)中,DeleRace的特征輸入定義為

    Input=〈Number_input,Text_input〉,

    (3)

    Number_input=〈numw,numh,numsm,numsb〉,
    Text_input=〈textpa,textc,textm,textv〉,

    其中,Input表示分類器的輸入,Number_input表示數(shù)值信息的輸入,numw,numh,numsm,numsb分別表示是否為寫操作、Hash值、是否被同步方法包含和是否被同步塊包含,Text_input表示文本信息的輸入,此時輸入的文本信息已經(jīng)被向量化,textpa,textc,textm,textv分別為包名、類名、方法名和變量名.由于DeleRace的卷積和池化都采用了2維操作,因此用Reshape函數(shù)將數(shù)值向量的1維矩陣轉(zhuǎn)化為2維,然后再將輸入層的輸出傳入2維卷積層中進(jìn)行自動學(xué)習(xí),每個卷積層后都有一個最大池化層來降低特征維數(shù),避免過擬合.函數(shù)Concatenate把CNN輸出的卷積特征和和LSTM提取的時序特征融合到另一個全連接層進(jìn)行二分類,并通過Dropout方法來防止過擬合,最終輸出測試程序中含有數(shù)據(jù)競爭的個數(shù).

    2 實驗結(jié)果與分析

    本節(jié)首先對實驗配置進(jìn)行介紹;然后對DeleRace進(jìn)行了實驗評估,并對結(jié)果進(jìn)行了分析;最后給出了DeleRace與傳統(tǒng)的數(shù)據(jù)競爭檢測工具的對比.

    2.1 實驗配置

    硬件上,所有的實驗都是在Dell Z820工作站上進(jìn)行的,該工作站配備2個Intel Xeon處理器,主頻為3.2 GHz,內(nèi)存為8 GB.軟件上,操作系統(tǒng)使用Windows 7 Professional,開發(fā)平臺使用Jupyter NoteBook;使用Python3.6和Tensorflow1.9作為深度學(xué)習(xí)的運行支撐環(huán)境;程序分析工具使用WALA1.4.2,使用Eclipse 4.5.1作為WALA的運行平臺,JDK版本為 1.8.0_31.

    2.2 數(shù)據(jù)集描述

    表3列出了構(gòu)建DeleRace訓(xùn)練集的基準(zhǔn)測試程序及其配置信息,這些基準(zhǔn)程序主要來源于DaCapo[20],JGF[21],IBM Contest[22]基準(zhǔn)測試程序套件.從表3中可以看出,DeleRace從16個訓(xùn)練程序中共提取了12 836個數(shù)據(jù)樣本,由于數(shù)據(jù)集中正負(fù)樣本分布不均衡,所以采用SMOTE算法對訓(xùn)練樣本進(jìn)行擴充,擴充后的訓(xùn)練樣本數(shù)增長了近1倍,總數(shù)為25 438個.Lusearch是較大型的基準(zhǔn)測試程序,其提取的訓(xùn)練樣本數(shù)最多,達(dá)到了5 683個,經(jīng)過SMOTE算法擴充后樣本數(shù)增加到11 336個.對于Rax基準(zhǔn)測試程序,最初只提取了23個訓(xùn)練樣本,經(jīng)過SMOTE擴充后訓(xùn)練樣本增加到36個,是16個基準(zhǔn)測試程序中所提訓(xùn)練樣本最少的程序.對于其他基準(zhǔn)測試程序,提取的訓(xùn)練樣本數(shù)經(jīng)過擴充后數(shù)量的范圍在98~4 618.

    Table 3 Training Dataset表3 訓(xùn)練數(shù)據(jù)集

    表4列出了構(gòu)建DeleRace測試集的并發(fā)程序及其配置信息,這些測試程序主要來源于JGF[21],IBM Contest[22],PJBench[23]基準(zhǔn)測試程序套件.在Account,AirlineTickets,Boundedbuffer等10個基準(zhǔn)程序中提取數(shù)據(jù)樣本作為DeleRace的測試集.表4中列出了這些測試程序及抽取的測試樣本數(shù),其中Boundedbuffer描述生產(chǎn)者-消費者算法,是所有測試程序中提取測試樣本最多的程序,共提取599條測試樣本;Critical是模擬雙線程環(huán)境的測試程序,是所有基準(zhǔn)程序中提取測試樣本最少的程序,只有11條測試樣本;其他測試程序的測試樣本數(shù)在25~403.

    Table 4 Test Dataset表4 測試數(shù)據(jù)集

    2.3 研究問題

    在實驗中,我們提出了6個研究問題(research question, RQ),通過回答這些問題對DeleRace方法進(jìn)行評估.

    RQ1:不同特征信息作為DeleRace輸入信息對數(shù)據(jù)競爭檢測結(jié)果有什么影響?如果只考慮幾種特征輸入信息,DeleRace的性能會如何?

    RQ2:DeleRace是否能準(zhǔn)確有效地檢測出數(shù)據(jù)競爭?

    RQ3:DeleRace是否優(yōu)于現(xiàn)有的基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測工具,與其他的深度神經(jīng)網(wǎng)絡(luò)相比,DeleRace的表現(xiàn)會如何?

    RQ4:DeleRace是否優(yōu)于傳統(tǒng)的基于動態(tài)分析的數(shù)據(jù)競爭檢測工具?

    RQ5:DeleRace是否優(yōu)于傳統(tǒng)的基于靜態(tài)分析的數(shù)據(jù)競爭檢測工具?

    RQ6:DeleRace在檢測數(shù)據(jù)競爭時各部分時間性能表現(xiàn)如何?

    RQ1關(guān)注的是不同特征信息對數(shù)據(jù)競爭檢測結(jié)果的影響,通過比較部分特征信息和全部指令特征、方法特征和文件特征相結(jié)合的信息檢測結(jié)果,以此來判斷本文所提取的特征是否有效.

    RQ2關(guān)注的是DeleRace在各個測試程序中準(zhǔn)確率、精確率、召回率和F1值,以此來判斷DeleRace是否可以準(zhǔn)確測試出各個程序中是否含有數(shù)據(jù)競爭以及含有數(shù)據(jù)競爭的個數(shù).

    RQ3關(guān)注的是DeleRace與其他深度學(xué)習(xí)算法在檢測數(shù)據(jù)競爭上的性能對比.我們選擇現(xiàn)有的基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測算法DeepRace[15]進(jìn)行對比實驗,并且與RNN和LSTM神經(jīng)網(wǎng)絡(luò)進(jìn)行對比.

    RQ4關(guān)注的是DeleRace與傳統(tǒng)的基于動態(tài)程序分析工具在檢測數(shù)據(jù)競爭上的性能對比.我們選擇現(xiàn)有的基于動態(tài)分析的數(shù)據(jù)競爭檢測算法Said和RVPredict進(jìn)行對比實驗.

    RQ5關(guān)注的是DeleRace與傳統(tǒng)的基于靜態(tài)程序分析工具在檢測數(shù)據(jù)競爭上的性能對比.我們選擇現(xiàn)有的基于靜態(tài)分析的數(shù)據(jù)競爭檢測算法SRD和ConRacer進(jìn)行對比實驗.

    RQ6關(guān)注的是DeleRace在檢測數(shù)據(jù)競爭上的時間性能,針對測試數(shù)據(jù)集上10個開源程序,記錄了DeleRace在整個檢測數(shù)據(jù)競爭時的平均耗時情況.

    2.4 模型評估指標(biāo)

    使用準(zhǔn)確率、精確率、召回率、F1作為評價指標(biāo)評估DeleRace的有效性.分類問題的混淆矩陣如表5所示,其中TP表示將正樣本預(yù)測為正樣本,F(xiàn)P表示將負(fù)樣本預(yù)測為正樣本,F(xiàn)N表示將正樣本預(yù)測為負(fù)樣本,TN表示將負(fù)樣本預(yù)測為負(fù)樣本.

    Table 5 Confusion Matrix of Binary Classification Problem表5 二分類問題的混淆矩陣

    準(zhǔn)確率(accuracy,ACC),表示預(yù)測正確的樣本占測試集中所有樣本的比例.

    (4)

    精確率(Precision),用于描述模型將正樣本預(yù)測為正樣本占測試集中實際預(yù)測為正樣本的比例.

    (5)

    召回率(Recall),用于描述模型將正樣本預(yù)測為正樣本占測試集中實際預(yù)測正確的比例.

    (6)

    F1(F-Measure),用于描述精確率和召回率的加權(quán)調(diào)和平均.

    (7)

    精確率和召回率是相互影響的,通常情況下,精確率升高,召回率會隨之下降,反之亦然.如果測試集中含有數(shù)據(jù)競爭的樣本數(shù)量為0,則會得到值為1的召回率,但精確率卻會很低,因此,F(xiàn)1用來權(quán)衡精確率和召回率之間的關(guān)系,其取值范圍通常在[0,1]之間,F(xiàn)1值越大表示模型性能越好.

    2.5 模型參數(shù)選擇

    為了回答RQ1,我們選擇5個具有代表性的特征與本文所選擇的8個特征進(jìn)行對比,其對比結(jié)果如表6所示.首先研究特征提取的個數(shù)對于實驗結(jié)果的影響情況,為此我們分別選擇8個特征(見1.3節(jié))和5個特征(包括訪問指令的Hash值、是否含有讀寫操作、發(fā)生數(shù)據(jù)競爭的包名、類名以及方法名)的情況進(jìn)行實驗對比.實驗結(jié)果如表6所示,其中 “DeleRace-5”代表在5個特征下深度學(xué)習(xí)模型的實驗結(jié)果,“DeleRace-8”代表8個特征下深度學(xué)習(xí)模型的實驗結(jié)果.從實驗結(jié)果可以看出,在DeleRace-8情況下,無論是準(zhǔn)確率、精確率、召回率還是F1都比DeleRace-5情況下要高,這表明選取8個特征進(jìn)行實驗比選取5個特征更能提高數(shù)據(jù)競爭的檢測精度.這里我們沒有對更多的特征個數(shù)進(jìn)行實驗,主要是因為這8個特征是依據(jù)數(shù)據(jù)競爭的產(chǎn)生條件提取出來的,已經(jīng)可以充分表示數(shù)據(jù)競爭的相關(guān)特征.基于該實驗結(jié)果,在對DeleRace模型進(jìn)行訓(xùn)練時選擇特征個數(shù)為8.

    Table 6 Performance Comparison of Deep Neural Network Models with Different Feature Numbers表6 不同特征數(shù)量下深度神經(jīng)網(wǎng)絡(luò)模型的性能對比 %

    Fig. 5 The relationship between accuracy and iteration times for DeleRace圖5 DeleRace準(zhǔn)確率與迭代次數(shù)的關(guān)系

    在不同特征數(shù)下DeleRace模型的訓(xùn)練過程中,我們還發(fā)現(xiàn)不僅特征提取的個數(shù)對分類精度有一定的影響,而且模型的迭代次數(shù)也會影響最終測試精度和訓(xùn)練時間開銷.我們研究訓(xùn)練的迭代次數(shù)對于實驗結(jié)果的影響情況,這主要基于2方面考慮:1)迭代次數(shù)過少可能會使檢測精度降低;2)迭代次數(shù)過多雖然可以增加檢測精度但會明顯增加訓(xùn)練的時間開銷.為了在檢測精度和時間開銷之間進(jìn)行折中,我們通過實驗確定相對合適的迭代次數(shù),使其在提高模型檢測精度的同時不會顯著增加訓(xùn)練時間開銷.圖5給出了DeleRace隨迭代次數(shù)的增加時訓(xùn)練和測試準(zhǔn)確率的變化情況.從圖5中可以看出,隨著迭代次數(shù)的增加,準(zhǔn)確率也會不斷提高,當(dāng)?shù)螖?shù)增加到50時,準(zhǔn)確率接近一個穩(wěn)定值,即使迭代次數(shù)再增加準(zhǔn)確率已不再有明顯提升,因此在本實驗中訓(xùn)練DeleRace模型的最佳迭代次數(shù)選擇為50.

    2.6 DeleRace檢測結(jié)果

    為了回答RQ2,我們選用表3中擴充后的25 438個數(shù)據(jù)樣本作為DeleRace的訓(xùn)練集,選用表4中的10個基準(zhǔn)測試程序所提取出的1 686個數(shù)據(jù)樣本作為DeleRace的測試集,其檢測結(jié)果如表7所示:

    Table 7 Detection Results of DeleRace表7 DeleRace檢測結(jié)果 %

    由表7可知,整體上準(zhǔn)確率范圍在90.91%~99.30%,F(xiàn)1值在90.27%~99.34%.Account測試程序的準(zhǔn)確率和F1值分別為99.30%和99.34%,其準(zhǔn)確率、精確率、召回率和F1都是10個測試程序中最高的;而對于Critical基準(zhǔn)測試程序,由于只提取了11個數(shù)據(jù)樣本,其各個指標(biāo)值都是10個基準(zhǔn)測試中最低的,造成其性能較差的原因可能是因為含有的數(shù)據(jù)競爭數(shù)較少,進(jìn)而提取的樣本數(shù)也少,而深度學(xué)習(xí)模型的精度又與數(shù)據(jù)集大小有關(guān),提供的數(shù)據(jù)集樣本越多,效果越好,這可能導(dǎo)致Critical測試程序的檢測精度偏低.

    2.7 與其他深度神經(jīng)網(wǎng)絡(luò)方法對比

    為了回答RQ3,我們將DeleRace與現(xiàn)有的基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測工具DeepRace[15]進(jìn)行對比,并與單獨使用RNN或LSTM的神經(jīng)網(wǎng)絡(luò)性能進(jìn)行比較,其實驗對比結(jié)果如表8所示:

    Table 8 Performance Comparison of Different Deep Neural Network Models表8 不同深度神經(jīng)網(wǎng)絡(luò)模型性能對比 %

    DeepRace[15]是目前已有的基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測工具,由于其數(shù)據(jù)集和模型均未開源,我們無法將其直接與本文方法DeleRace進(jìn)行比較.為了進(jìn)行比較,我們根據(jù)文獻(xiàn)[15]中介紹的方法對其工作進(jìn)行了復(fù)現(xiàn).在比較時,DeleRace,RNN,LSTM,DeepRace都使用相同的訓(xùn)練集和測試集,遵循相同的過程和使用相同的工具來解析源代碼和特征向量化,處理數(shù)據(jù)不平衡問題時也采用了相同的數(shù)據(jù)增強算法,在最大程度上保證了實驗的公平性.與此同時,為了使我們的實驗結(jié)果更為可靠,我們采用10倍交叉驗證的方式來評估DeleRace,即將訓(xùn)練集和數(shù)據(jù)集混合為1份數(shù)據(jù)集,把整個數(shù)據(jù)集隨機分成 10組,用其中9組作為訓(xùn)練集,另外1組作為測試集,重復(fù)這個過程,直到每組數(shù)據(jù)都作過測試集,我們?nèi)?0次結(jié)果的平均值作為我們的最終結(jié)果.實驗結(jié)果如表8所示.

    從表8可以看出,DeleRace檢測的準(zhǔn)確率為96.79%,F(xiàn)1為96.79%,在4種方法中是最高的,準(zhǔn)確率和F1分別比DeepRace高出約4.65%和4.67%,這表明本文方法DeleRace在檢測數(shù)據(jù)競爭方面的性能優(yōu)于DeepRace.此外,我們還將DeleRace與RNN和LSTM網(wǎng)絡(luò)相比,在準(zhǔn)確率方面,DeleRace比其他2種網(wǎng)絡(luò)模型高出7%以上,DeleRace的F1值也比其他2種網(wǎng)絡(luò)模型分別高出7.09%,8.23%.實驗結(jié)果表明,無論是準(zhǔn)確率還是F1,DeleRace均優(yōu)于采用RNN神經(jīng)網(wǎng)絡(luò)、LSTM神經(jīng)網(wǎng)絡(luò)和DeepRace工具檢測數(shù)據(jù)競爭的方法.

    2.8 與動態(tài)數(shù)據(jù)競爭檢測工具對比

    為了回答RQ4,我們將DeleRace與現(xiàn)有的基于動態(tài)程序分析的的數(shù)據(jù)競爭檢測工具Said[5]和RVPredict[6]進(jìn)行對比,其實驗對比結(jié)果如表9所示,其中R-races表示該程序?qū)嶋H的數(shù)據(jù)競爭數(shù)目.

    Table 9 Comparison of DeleRace and Dynamic Data Race Detection Tools表9 DeleRace與動態(tài)數(shù)據(jù)競爭檢測工具的對比

    從表9可以看出, Said檢測到數(shù)據(jù)競爭總數(shù)為46個, RVPredict檢測的總數(shù)為52個,而DeleRace檢測到實際競爭的個數(shù)為57個,明顯多于其他2種檢測工具.對于測試程序AirlineTickets,BoundedBuffer,Bufwriter和Weblech,DeleRace檢測到的實際競爭個數(shù)均多于Said檢測到的數(shù)據(jù)競爭個數(shù);對測試程序PingPong,DeleRace檢測到的數(shù)據(jù)競爭個數(shù)比Said和RVPredict檢測到的數(shù)據(jù)競爭個數(shù)多4個,并且使用DeleRace檢測大部分程序的結(jié)果與實際競爭數(shù)#R-races是相同的, DeleRace最貼近真實競爭的個數(shù).

    在漏報方面,Said和RVPredict工具的漏報總數(shù)分別為11個和5個,而DeleRace的漏報總數(shù)為1個,相比較而言,DeleRace檢測數(shù)據(jù)競爭時存在較少的漏報.在這些測試程序中,只有在檢測Bubblesort測試程序時存在1個漏報,對于Said和RVPredict也同樣存在1個漏報.漏報可能的原因是將某條標(biāo)簽為1的文本特征轉(zhuǎn)化成數(shù)值向量時的單詞相關(guān)性較低,從而導(dǎo)致其發(fā)生漏報.

    盡管DeleRace檢測的真實數(shù)據(jù)競爭個數(shù)較多且漏報較少,但在誤報方面DeleRace與其他2個檢測工具相比還存在一定的差距.總體來說,Said和RVPredict分別只有8個和13個誤報,但是DeleRace的誤報數(shù)卻有22個.在這些程序中,誤報較多的是BoundedBuffer和Bubblesort測試程序,造成誤報的原因可能是在提取數(shù)據(jù)樣本時標(biāo)簽為“0”的數(shù)據(jù)樣本過多而標(biāo)簽為“1”的數(shù)據(jù)樣本過少,造成了數(shù)據(jù)分布不均衡,盡管我們使用了SMOTE數(shù)據(jù)增強算法,使數(shù)據(jù)樣本達(dá)到了平衡,但還是不可避免地造成了一些誤報.DeleRace在誤報方面的不足,將驅(qū)使我們進(jìn)一步完善該方法.

    2.9 與靜態(tài)數(shù)據(jù)競爭檢測工具對比

    為了回答RQ5,我們將DeleRace與現(xiàn)有的基于靜態(tài)程序分析的的數(shù)據(jù)競爭檢測工具SRD[5]和ConRacer[17]進(jìn)行對比,其實驗對比結(jié)果如表10所示.

    從表10可以看出,DeleRace檢測到的數(shù)據(jù)競爭總數(shù)比SRD檢測到的個數(shù)多17個,漏報個數(shù)比SRD少15個,在誤報方面雖然與SRD相等,但總體而言,DeleRace的性能是優(yōu)于靜態(tài)數(shù)據(jù)競爭工具SRD的.

    Table 10 Comparison of DeleRace and Static Data Race Detection Tools表10 DeleRace與靜態(tài)數(shù)據(jù)競爭檢測工具的對比

    我們還將DeleRace與ConRacer進(jìn)行了對比.對于檢測到的實際競爭個數(shù),DeleRace所檢測到的個數(shù)為57個,而ConRacer是53個,本文方法DeleRace比ConRacer所檢測到的個數(shù)多4個.漏報方面,本文方法DeleRace比ConRacer的漏報個數(shù)少4個.盡管DeleRace檢測的真實數(shù)據(jù)競爭個數(shù)較多且漏報較少,但在誤報方面DeleRace與ConRacer相比依舊存在一些差距,ConRacer的誤報個數(shù)僅為6個,但本文方法DeleRace卻為22個,造成誤報較多的原因在2.8節(jié)已經(jīng)進(jìn)行了說明.我們計劃在下一步的工作中進(jìn)行改進(jìn).

    雖然ConRacer工具檢測到的實際競爭個數(shù)比本文方法DeleRace少,且漏報個數(shù)比DeleRace多,但與本文所提到的Said,RVPredict和SRD這3種基于程序分析的數(shù)據(jù)競爭檢測方法相比,ConRacer不僅檢測到的實際競爭個數(shù)最多,而且誤報和漏報均最少,因此ConRacer依舊是較好的檢測工具.針對判定時所出現(xiàn)的誤報和漏報情況,我們對標(biāo)記情況進(jìn)行了手動驗證,以保證數(shù)據(jù)集的正確性.

    2.10 時間性能評估

    對于回答RQ6,我們評估了DeleRace在檢測數(shù)據(jù)競爭時的時間性能.表11記錄了DeleRace檢測數(shù)據(jù)競爭的整體耗時情況,總時長為3 657.14 s,其中耗時最久的步驟是深度神經(jīng)網(wǎng)絡(luò)模型的訓(xùn)練時間,共耗時3 492.42 s,占據(jù)整體檢測時長的95%,主要原因是神經(jīng)網(wǎng)絡(luò)的時間復(fù)雜度和空間復(fù)雜度都會對模型的訓(xùn)練時間產(chǎn)生影響,如果復(fù)雜度過高,很容易導(dǎo)致模型在訓(xùn)練過程中消耗過多的時間,而DeleRace采用了3個卷積層和1個LSTM層處理數(shù)據(jù),獲得了不同的特征并加以合并,層數(shù)深且操作過程較為復(fù)雜,并且迭代次數(shù)過多也會使得訓(xùn)練時間過長,因此在訓(xùn)練模型過程中花費時間較多,耗時比例較高.

    Table 11 The Time of Each Step in DeleRace表11 DeleRace完成各個步驟所花費的時間

    2.11 有效性威脅

    本節(jié)對實驗過程中威脅有效性的4個因素進(jìn)行了討論.

    1) 本文僅選擇來自DaCapo,JGF,IBM Contest,PJBench這4個基準(zhǔn)測試組件中的并發(fā)程序,從這些程序中提取的數(shù)據(jù)競爭數(shù)據(jù)集并不能代表所有程序,因為不同程序可能展現(xiàn)不同的數(shù)據(jù)樣本.為了緩解這個有效性威脅,我們選擇了26個測試程序,這些程序分別來自不同領(lǐng)域,盡可能保證數(shù)據(jù)集來源的多樣性.

    2) 我們在對訓(xùn)練數(shù)據(jù)集進(jìn)行標(biāo)記時采用了ConRacer工具,盡管該工具采用了上下文敏感的程序分析方法,可以有效地報告數(shù)據(jù)競爭,但該工具仍存在誤報和漏報的情況.為了解決這一問題,我們對報告的數(shù)據(jù)競爭采用手動的方式檢查數(shù)據(jù)競爭位置的代碼,盡可能地排除誤報和漏報,最大程度上保證了數(shù)據(jù)集的準(zhǔn)確性.

    3) 將文本特征轉(zhuǎn)化為數(shù)值向量時,轉(zhuǎn)化相似度的高低會影響最終結(jié)果的精度.本文采用Keras中的嵌入層進(jìn)行文本向量化,通過對Keras的嵌入層進(jìn)行訓(xùn)練并對其參數(shù)進(jìn)行調(diào)節(jié)使其轉(zhuǎn)化準(zhǔn)確率可達(dá)98.7%,雖然沒有達(dá)到100%的準(zhǔn)確率,但通過該技術(shù)轉(zhuǎn)化的數(shù)值向量已經(jīng)在很大程度上接近數(shù)據(jù)競爭的文本特征,有效減少了文本向量化對最終結(jié)果的影響.

    4) 在數(shù)據(jù)增強時我們選擇的算法會對訓(xùn)練的最終效果有一定的影響.本文選擇的SMOTE算法是基于隨機過采樣算法的一種改進(jìn)方案,由于隨機過采樣采取簡單復(fù)制樣本的策略來增加少數(shù)類樣本,容易使模型過擬合,而SMOTE算法采用KNN技術(shù)生成新樣本[28-29],通過計算每個少數(shù)類樣本的K個近鄰,并從中隨機挑選N個樣本進(jìn)行隨機線性插值,最終構(gòu)造新的少數(shù)類樣本.因此使用SMOTE算法增加正樣本個數(shù),在擴充訓(xùn)練集時有效減小數(shù)據(jù)增強對模型訓(xùn)練的影響.

    3 相關(guān)工作

    數(shù)據(jù)競爭檢測的相關(guān)研究仍是目前研究的熱點內(nèi)容之一,所采用的方法有很多,目前可分為基于程序分析的數(shù)據(jù)競爭檢測方法以及基于機器學(xué)習(xí)和深度學(xué)習(xí)的數(shù)據(jù)競爭檢測方法.基于程序分析的數(shù)據(jù)競爭檢測方法通常又分為動態(tài)檢測、靜態(tài)檢測和動靜結(jié)合的檢測方法.

    動態(tài)檢測通過運行源程序時插樁等方法獲取并記錄程序運行時狀態(tài).Said等人[5]提出了一種基于SMT解算器的符號分析方法,可以有效地分析線程調(diào)度,準(zhǔn)確定位數(shù)據(jù)競爭.RVPredict[6]將數(shù)據(jù)競爭檢測作為約束求解問題,利用可滿足性模理論(satisfiability modulo theories, SMT)求解器查找數(shù)據(jù)競爭.SlimFast[7]通過減少數(shù)據(jù)冗余、內(nèi)存使用和運行時間來檢測數(shù)據(jù)競爭并提高檢測效率.

    靜態(tài)方法是基于靜態(tài)源代碼分析,通過程序驗證或符號執(zhí)行的方式分析源碼語義或者程序控制流.RELAY[8]是一種基于流敏感和過程間分析的靜態(tài)數(shù)據(jù)競爭檢測工具.Elmas[9]是基于模型檢測理論提出的一種檢測方法,通過對程序中鎖操作路徑進(jìn)行分析并通過發(fā)生序關(guān)系過濾結(jié)果.SRD[10]采用程序切片技術(shù)靜態(tài)判斷訪問事件之間的發(fā)生序關(guān)系并結(jié)合別名分析等靜態(tài)分析技術(shù)檢測數(shù)據(jù)競爭.

    動靜結(jié)合的檢測方法是先靜態(tài)找出所有可能的數(shù)據(jù)競爭,再利用動態(tài)分析檢測程序.RaceTracker[11]采用動靜結(jié)合的檢測方法,首先使用當(dāng)前的靜態(tài)檢測器來產(chǎn)生潛在的競爭,然后潛在競爭的代碼位置進(jìn)行插樁來識別數(shù)據(jù)競爭.AsampleLock[12]是基于優(yōu)化的FastTrack[30]算法和鎖模式的動態(tài)混合數(shù)據(jù)競爭檢測算法,利用采樣技術(shù)監(jiān)控同一時刻同時運行的并發(fā)線程函數(shù)對,再通過預(yù)競爭檢測獲得真正的數(shù)據(jù)競爭的內(nèi)存訪問對.

    有些研究人員開始使用機器學(xué)習(xí)和深度學(xué)習(xí)方法來檢測數(shù)據(jù)競爭.Tehrani等人[15]提出基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測工具DeepRace,首先通過變異分析生成特定的數(shù)據(jù)競爭類型,再通過為每個源文件生成AST構(gòu)造數(shù)據(jù)集,最后將向量化的數(shù)值輸入到CNN中進(jìn)行訓(xùn)練,其檢測準(zhǔn)確率在83%~86%.孫家澤等人提出了AIRaceTest[13]和ADR[14]檢測數(shù)據(jù)競爭工具,AIRaceTest是基于隨機森林的數(shù)據(jù)競爭指令級的檢測工具,首先基于HB關(guān)系和Lockset算法指令級檢測數(shù)據(jù)競爭,并利用其分析結(jié)果訓(xùn)練數(shù)據(jù)競爭隨機森林檢測模型,模型精度為92%.ADR是基于Adaboost模型的數(shù)據(jù)競爭語句級檢測工具,將插樁得到的指令內(nèi)存信息進(jìn)行語句級轉(zhuǎn)化,提取出相關(guān)特征后構(gòu)建Adaboost數(shù)據(jù)競爭檢測模型.與AIRaceTest和DeepRace相比,DeleRace通過提取多個特征,模型性能更好,準(zhǔn)確率也更高.

    4 總 結(jié)

    本文提出一種基于深度學(xué)習(xí)的數(shù)據(jù)競爭檢測方法,該方法首先利用WALA工具從多個實際應(yīng)用程序中提取指令、方法和文件等級別的多個特征,對其向量化并構(gòu)造訓(xùn)練樣本數(shù)據(jù),通過ConRacer工具對真實數(shù)據(jù)競爭進(jìn)行判定進(jìn)而標(biāo)記樣本數(shù)據(jù),采用SMOTE增強算法使數(shù)據(jù)樣本均衡化,最后構(gòu)建并訓(xùn)練CNN-LSTM深度神經(jīng)網(wǎng)絡(luò)實現(xiàn)對數(shù)據(jù)競爭的檢測.在實驗中選取10個基準(zhǔn)測試程序驗證了該方法的有效性,結(jié)果表明DeleRace的數(shù)據(jù)競爭檢測準(zhǔn)確率為96.79%,高于目前已有的基于深度學(xué)習(xí)的檢測方法.此外,我們將DeleRace與已有的動態(tài)數(shù)據(jù)競爭檢測工具(Said和RVPredict)和靜態(tài)數(shù)據(jù)競爭檢測工具(SRD和ConRacer)進(jìn)行比較,驗證了本文方法的有效性.

    進(jìn)一步的研究工作包括:1)針對本文方法誤報較多的問題,將在未來的工作中通過擴大訓(xùn)練數(shù)據(jù)集、增加含有數(shù)據(jù)競爭的標(biāo)簽樣本和采用更多軟件分析等方法減少誤報,并且選取更多的基準(zhǔn)測試程序?qū)δP瓦M(jìn)行訓(xùn)練,提高工具的普適性;2)本文使用CNN-LSTM的神經(jīng)網(wǎng)絡(luò)來對數(shù)據(jù)競爭進(jìn)行檢測,雖然準(zhǔn)確率可達(dá)96.79%,但仍有可提升的空間,我們將繼續(xù)嘗試對深度學(xué)習(xí)模型進(jìn)行優(yōu)化,進(jìn)一步提高檢測精度.

    作者貢獻(xiàn)聲明:張楊負(fù)責(zé)論文想法的提出、方法設(shè)計、實驗指導(dǎo)、數(shù)據(jù)整理與分析、論文的寫作與修改;喬柳負(fù)責(zé)實驗設(shè)計與探究、深度學(xué)習(xí)模型實現(xiàn)、實驗數(shù)據(jù)整理與分析、論文的寫作與修改;東春浩負(fù)責(zé)深度學(xué)習(xí)模型實現(xiàn)、部分實驗數(shù)據(jù)整理、論文的修改;高鴻斌指導(dǎo)實驗和論文的修改.

    猜你喜歡
    檢測工具測試程序競爭
    基于Castle型機械手的三溫量產(chǎn)測試平臺實現(xiàn)
    高溫封隔器膠筒試驗檢測工具的研究
    化工管理(2017年16期)2017-06-23 13:49:36
    感謝競爭
    手機APP交互界面人因適合性測試程序的設(shè)計與實現(xiàn)
    中心主導(dǎo)制訂的《VHF/UHF頻率范圍內(nèi)測向系統(tǒng)測向靈敏度的測試程序》等兩項國際標(biāo)準(zhǔn)在ITU官網(wǎng)正式發(fā)布
    德國Rosen公司發(fā)布新型漏磁檢測工具
    兒時不競爭,長大才勝出
    電氣自動化控制設(shè)備可靠性測試探討
    競爭
    小說月刊(2015年9期)2015-04-23 08:48:17
    中國移動設(shè)計院自主研發(fā)安全檢測工具
    非洲黑人性xxxx精品又粗又长| 每晚都被弄得嗷嗷叫到高潮| 1024手机看黄色片| 亚洲18禁久久av| 少妇丰满av| 国产蜜桃级精品一区二区三区| 亚洲欧美日韩东京热| 午夜精品一区二区三区免费看| 国产精品久久电影中文字幕| 精品99又大又爽又粗少妇毛片 | bbb黄色大片| 午夜精品久久久久久毛片777| 麻豆国产av国片精品| 国产精品 国内视频| cao死你这个sao货| 亚洲五月天丁香| 免费人成视频x8x8入口观看| 亚洲五月天丁香| 一级作爱视频免费观看| 99国产精品99久久久久| 亚洲精品在线观看二区| 我要搜黄色片| 成人亚洲精品av一区二区| 搞女人的毛片| 国产不卡一卡二| 亚洲欧美一区二区三区黑人| 亚洲第一欧美日韩一区二区三区| 国产午夜精品论理片| 99久久久亚洲精品蜜臀av| 宅男免费午夜| 一本久久中文字幕| 免费在线观看日本一区| 神马国产精品三级电影在线观看| 久久这里只有精品中国| 1024香蕉在线观看| 久久精品aⅴ一区二区三区四区| 香蕉av资源在线| 一进一出好大好爽视频| 婷婷六月久久综合丁香| 中文字幕人成人乱码亚洲影| 丰满人妻一区二区三区视频av | 在线视频色国产色| 午夜免费观看网址| a级毛片a级免费在线| 夜夜爽天天搞| 美女 人体艺术 gogo| 99热这里只有精品一区 | 中文亚洲av片在线观看爽| 亚洲一区二区三区色噜噜| 亚洲一区二区三区色噜噜| 老汉色∧v一级毛片| 亚洲中文字幕一区二区三区有码在线看 | 一级毛片女人18水好多| 丰满人妻熟妇乱又伦精品不卡| 亚洲国产精品久久男人天堂| 观看免费一级毛片| 婷婷丁香在线五月| 亚洲第一电影网av| 中文在线观看免费www的网站| 男女那种视频在线观看| 国产精品电影一区二区三区| 亚洲一区二区三区不卡视频| 无遮挡黄片免费观看| 俄罗斯特黄特色一大片| 国产激情久久老熟女| 曰老女人黄片| 此物有八面人人有两片| 亚洲自拍偷在线| 亚洲国产精品合色在线| 老熟妇乱子伦视频在线观看| 国内精品美女久久久久久| 一进一出抽搐gif免费好疼| 亚洲国产欧美网| 黄色成人免费大全| 国产高清videossex| 欧美不卡视频在线免费观看| 每晚都被弄得嗷嗷叫到高潮| 精品国产三级普通话版| 欧美性猛交黑人性爽| 18美女黄网站色大片免费观看| 午夜激情欧美在线| 在线播放国产精品三级| 亚洲一区二区三区不卡视频| 18禁观看日本| 日本精品一区二区三区蜜桃| 啪啪无遮挡十八禁网站| 精品无人区乱码1区二区| 观看免费一级毛片| 亚洲国产精品合色在线| 神马国产精品三级电影在线观看| 国产私拍福利视频在线观看| 69av精品久久久久久| 亚洲五月婷婷丁香| 狂野欧美激情性xxxx| 一级毛片精品| 女同久久另类99精品国产91| 少妇人妻一区二区三区视频| 床上黄色一级片| 中国美女看黄片| 亚洲成a人片在线一区二区| 又爽又黄无遮挡网站| 亚洲成av人片在线播放无| 国产一级毛片七仙女欲春2| 在线永久观看黄色视频| 99国产精品一区二区蜜桃av| 嫩草影院入口| 性色avwww在线观看| 国产久久久一区二区三区| 精品久久久久久久久久免费视频| 波多野结衣巨乳人妻| 亚洲精品一卡2卡三卡4卡5卡| 人人妻,人人澡人人爽秒播| 国产一区二区在线观看日韩 | 久久久久精品国产欧美久久久| 可以在线观看毛片的网站| 好看av亚洲va欧美ⅴa在| 国产精品乱码一区二三区的特点| 婷婷精品国产亚洲av| 一进一出抽搐gif免费好疼| 一级a爱片免费观看的视频| 在线永久观看黄色视频| 亚洲性夜色夜夜综合| 18美女黄网站色大片免费观看| 女人被狂操c到高潮| 亚洲av成人一区二区三| 国产真人三级小视频在线观看| 观看美女的网站| 色av中文字幕| 一区二区三区高清视频在线| 岛国在线免费视频观看| 高清在线国产一区| 男人舔女人的私密视频| 麻豆av在线久日| 久久热在线av| 久久国产乱子伦精品免费另类| cao死你这个sao货| 天堂网av新在线| 亚洲精品在线观看二区| 国产精品久久久久久人妻精品电影| 午夜久久久久精精品| 黄色 视频免费看| a级毛片a级免费在线| 欧美成人免费av一区二区三区| 在线观看免费视频日本深夜| 国产精品女同一区二区软件 | 亚洲18禁久久av| 非洲黑人性xxxx精品又粗又长| 岛国在线观看网站| 欧美黄色片欧美黄色片| 精品久久蜜臀av无| 熟女电影av网| 天天添夜夜摸| 国产精品一区二区免费欧美| 国产精品久久久av美女十八| 麻豆成人午夜福利视频| 亚洲午夜精品一区,二区,三区| 久久中文看片网| 熟女人妻精品中文字幕| 国产精品98久久久久久宅男小说| 国产一区二区三区在线臀色熟女| 国产aⅴ精品一区二区三区波| 18禁观看日本| 性色avwww在线观看| 看片在线看免费视频| 啦啦啦免费观看视频1| 美女cb高潮喷水在线观看 | 亚洲欧美日韩卡通动漫| 成人一区二区视频在线观看| 国产野战对白在线观看| 国产精品九九99| 精品欧美国产一区二区三| 级片在线观看| 欧美日韩精品网址| 精华霜和精华液先用哪个| 女生性感内裤真人,穿戴方法视频| 露出奶头的视频| 亚洲欧美一区二区三区黑人| 久久久色成人| 成人18禁在线播放| 一本综合久久免费| av福利片在线观看| 村上凉子中文字幕在线| 国产高清视频在线观看网站| 99国产精品一区二区蜜桃av| av女优亚洲男人天堂 | 一区福利在线观看| 欧美性猛交黑人性爽| 男人和女人高潮做爰伦理| 最近最新中文字幕大全电影3| 男人舔奶头视频| 老鸭窝网址在线观看| 免费观看精品视频网站| 男女做爰动态图高潮gif福利片| 成人性生交大片免费视频hd| 国产黄片美女视频| 国产精品日韩av在线免费观看| 婷婷丁香在线五月| 久久欧美精品欧美久久欧美| 美女cb高潮喷水在线观看 | 午夜福利在线观看吧| 亚洲av中文字字幕乱码综合| 午夜免费观看网址| 欧美成人免费av一区二区三区| 亚洲一区二区三区色噜噜| 国产伦人伦偷精品视频| 一级毛片精品| 99热只有精品国产| 熟女少妇亚洲综合色aaa.| ponron亚洲| 国产高清有码在线观看视频| 色综合婷婷激情| 久久99热这里只有精品18| 三级毛片av免费| 成年版毛片免费区| 欧美日韩乱码在线| 国产伦精品一区二区三区四那| 国产真人三级小视频在线观看| 麻豆成人午夜福利视频| 久久香蕉精品热| 亚洲性夜色夜夜综合| 最新美女视频免费是黄的| 亚洲自拍偷在线| 给我免费播放毛片高清在线观看| 成年版毛片免费区| 黄频高清免费视频| 在线国产一区二区在线| 亚洲精品美女久久av网站| 成熟少妇高潮喷水视频| 国产男靠女视频免费网站| 性色avwww在线观看| 成人永久免费在线观看视频| 亚洲精品粉嫩美女一区| 久久人妻av系列| 久久久国产欧美日韩av| 国产成人av教育| 国产精品1区2区在线观看.| 成年女人永久免费观看视频| 久久久精品大字幕| 欧美午夜高清在线| 久久精品国产99精品国产亚洲性色| 三级国产精品欧美在线观看 | 日本黄大片高清| 国产成人精品无人区| 1024手机看黄色片| 色老头精品视频在线观看| 免费高清视频大片| 国产aⅴ精品一区二区三区波| 日本与韩国留学比较| 久久久久九九精品影院| 国产精品一区二区三区四区免费观看 | 长腿黑丝高跟| 久久午夜综合久久蜜桃| 九九久久精品国产亚洲av麻豆 | 国产一级毛片七仙女欲春2| 亚洲七黄色美女视频| 99久久精品一区二区三区| 免费av毛片视频| 国产97色在线日韩免费| 伊人久久大香线蕉亚洲五| 成人无遮挡网站| 成人永久免费在线观看视频| 国产一区二区三区在线臀色熟女| 日日摸夜夜添夜夜添小说| 一区福利在线观看| 久久久色成人| 亚洲第一电影网av| tocl精华| 欧美最黄视频在线播放免费| 午夜福利在线观看免费完整高清在 | 亚洲熟妇中文字幕五十中出| 嫁个100分男人电影在线观看| 丁香六月欧美| 男女午夜视频在线观看| 亚洲aⅴ乱码一区二区在线播放| 夜夜夜夜夜久久久久| 国产成+人综合+亚洲专区| 热99在线观看视频| 一边摸一边抽搐一进一小说| 精品久久久久久成人av| 亚洲色图av天堂| 热99在线观看视频| 日日干狠狠操夜夜爽| 亚洲欧美激情综合另类| 国产免费男女视频| 久久人人精品亚洲av| 国产成人精品久久二区二区91| 美女扒开内裤让男人捅视频| 在线十欧美十亚洲十日本专区| 美女免费视频网站| 久久亚洲真实| www.精华液| 久久国产精品影院| 亚洲av美国av| 午夜激情欧美在线| 白带黄色成豆腐渣| 欧美激情在线99| 国产伦在线观看视频一区| 国产一区二区在线av高清观看| 国内久久婷婷六月综合欲色啪| 成人三级黄色视频| 免费看日本二区| 99国产极品粉嫩在线观看| 午夜精品久久久久久毛片777| 久久香蕉精品热| 亚洲国产精品成人综合色| 香蕉久久夜色| 免费大片18禁| 国产伦一二天堂av在线观看| 欧美性猛交╳xxx乱大交人| 国产探花在线观看一区二区| 国产欧美日韩精品亚洲av| 欧美成人免费av一区二区三区| 午夜两性在线视频| 黄色 视频免费看| 久久久久久人人人人人| 麻豆国产97在线/欧美| 久久久国产成人免费| 国产1区2区3区精品| 亚洲色图av天堂| 日韩免费av在线播放| 男女床上黄色一级片免费看| 欧美日韩乱码在线| 午夜成年电影在线免费观看| 欧美精品啪啪一区二区三区| 国产成人系列免费观看| 夜夜爽天天搞| 久久国产精品人妻蜜桃| 每晚都被弄得嗷嗷叫到高潮| 一个人免费在线观看电影 | 美女免费视频网站| 91麻豆av在线| 国产又色又爽无遮挡免费看| 欧美极品一区二区三区四区| 日韩成人在线观看一区二区三区| 成人鲁丝片一二三区免费| 亚洲精品在线观看二区| 国产视频内射| 亚洲乱码一区二区免费版| 国产成人av教育| 国内少妇人妻偷人精品xxx网站 | 久久国产乱子伦精品免费另类| 久久这里只有精品19| 国内少妇人妻偷人精品xxx网站 | 热99在线观看视频| www.熟女人妻精品国产| 免费电影在线观看免费观看| 国产高清videossex| 99久久精品热视频| 亚洲天堂国产精品一区在线| 人人妻,人人澡人人爽秒播| 免费看十八禁软件| 熟妇人妻久久中文字幕3abv| 免费高清视频大片| 亚洲第一电影网av| 五月伊人婷婷丁香| 国产麻豆成人av免费视频| 亚洲最大成人中文| 久久久精品欧美日韩精品| 精品久久久久久久久久久久久| 神马国产精品三级电影在线观看| 亚洲国产欧美一区二区综合| 国产精品亚洲美女久久久| 精品乱码久久久久久99久播| 久久午夜亚洲精品久久| 99热精品在线国产| 国产精品香港三级国产av潘金莲| 欧美激情在线99| 成人欧美大片| av国产免费在线观看| 好男人在线观看高清免费视频| 麻豆一二三区av精品| 国产三级中文精品| 一个人观看的视频www高清免费观看 | 精品久久久久久成人av| 亚洲成人免费电影在线观看| 亚洲无线在线观看| 法律面前人人平等表现在哪些方面| 国产精品99久久99久久久不卡| 亚洲熟妇中文字幕五十中出| 午夜福利成人在线免费观看| av在线蜜桃| 亚洲国产欧美一区二区综合| 欧美日本视频| 亚洲熟妇熟女久久| 一本精品99久久精品77| 美女被艹到高潮喷水动态| 国产一级毛片七仙女欲春2| 国产精品一区二区精品视频观看| 一个人免费在线观看的高清视频| 亚洲第一电影网av| 亚洲av成人不卡在线观看播放网| 午夜免费激情av| 亚洲欧美精品综合一区二区三区| 99国产综合亚洲精品| 欧美大码av| 最新中文字幕久久久久 | 一本精品99久久精品77| 久久久久久人人人人人| 俺也久久电影网| 国产精品乱码一区二三区的特点| 久久久国产精品麻豆| 美女被艹到高潮喷水动态| 亚洲精品色激情综合| 亚洲第一欧美日韩一区二区三区| 国产三级中文精品| 99久久无色码亚洲精品果冻| 亚洲在线观看片| 午夜福利18| 99精品久久久久人妻精品| 国产精品98久久久久久宅男小说| 亚洲无线在线观看| 亚洲国产色片| 老司机在亚洲福利影院| 久久天堂一区二区三区四区| 国产日本99.免费观看| 久久精品91蜜桃| 欧美性猛交黑人性爽| 高清在线国产一区| 2021天堂中文幕一二区在线观| 亚洲精华国产精华精| 美女被艹到高潮喷水动态| 婷婷六月久久综合丁香| 日本撒尿小便嘘嘘汇集6| 国产极品精品免费视频能看的| 观看美女的网站| 少妇的逼水好多| 国产精品av视频在线免费观看| 国产激情久久老熟女| 在线永久观看黄色视频| 一级毛片女人18水好多| 露出奶头的视频| 老司机深夜福利视频在线观看| 亚洲国产精品成人综合色| 小说图片视频综合网站| 精品熟女少妇八av免费久了| 无遮挡黄片免费观看| 欧美另类亚洲清纯唯美| 美女高潮喷水抽搐中文字幕| 国产成人精品久久二区二区免费| 欧美成人性av电影在线观看| 国产视频一区二区在线看| 最近在线观看免费完整版| 日韩人妻高清精品专区| 性欧美人与动物交配| 日本 av在线| 两个人看的免费小视频| 欧美日韩中文字幕国产精品一区二区三区| 搞女人的毛片| 性色avwww在线观看| 国产高清视频在线播放一区| 欧美中文日本在线观看视频| 国产精品久久久人人做人人爽| 高潮久久久久久久久久久不卡| 午夜亚洲福利在线播放| 亚洲在线自拍视频| 天天添夜夜摸| 婷婷亚洲欧美| 亚洲黑人精品在线| 99国产精品一区二区三区| 国产精品一及| 久久精品国产清高在天天线| 免费观看的影片在线观看| 又黄又爽又免费观看的视频| 亚洲性夜色夜夜综合| 国产精品野战在线观看| 国产高清视频在线观看网站| 久久久久精品国产欧美久久久| 天天躁狠狠躁夜夜躁狠狠躁| 很黄的视频免费| 大型黄色视频在线免费观看| 欧美色视频一区免费| 精品国产超薄肉色丝袜足j| 性色avwww在线观看| 国产精品98久久久久久宅男小说| 国产成人精品久久二区二区91| 久久精品亚洲精品国产色婷小说| 久久久国产精品麻豆| 国产伦精品一区二区三区四那| 国产欧美日韩精品亚洲av| 怎么达到女性高潮| 亚洲,欧美精品.| 在线播放国产精品三级| 美女高潮喷水抽搐中文字幕| 欧美乱码精品一区二区三区| 天天躁日日操中文字幕| 国产高潮美女av| www国产在线视频色| 亚洲片人在线观看| 午夜精品一区二区三区免费看| 黄色视频,在线免费观看| 欧美日韩精品网址| 在线观看免费午夜福利视频| 中文字幕人成人乱码亚洲影| 高潮久久久久久久久久久不卡| 偷拍熟女少妇极品色| 黄色成人免费大全| 无人区码免费观看不卡| 国产不卡一卡二| 夜夜躁狠狠躁天天躁| 国内毛片毛片毛片毛片毛片| 在线观看66精品国产| bbb黄色大片| 一a级毛片在线观看| 淫妇啪啪啪对白视频| 精品久久久久久久毛片微露脸| 又黄又爽又免费观看的视频| 久久久国产成人免费| 少妇人妻一区二区三区视频| 观看免费一级毛片| 国产精品女同一区二区软件 | 久久中文字幕人妻熟女| 黑人巨大精品欧美一区二区mp4| 99久久国产精品久久久| 婷婷六月久久综合丁香| 99国产精品99久久久久| 男女视频在线观看网站免费| 久久久久久人人人人人| 美女扒开内裤让男人捅视频| 麻豆国产97在线/欧美| 欧美日韩瑟瑟在线播放| av女优亚洲男人天堂 | 精品久久久久久久久久免费视频| 日韩欧美免费精品| 国产午夜福利久久久久久| av片东京热男人的天堂| 宅男免费午夜| 欧美日本视频| 男人的好看免费观看在线视频| 最好的美女福利视频网| 两个人看的免费小视频| 一个人免费在线观看电影 | 桃色一区二区三区在线观看| 久久久成人免费电影| 一区二区三区国产精品乱码| 亚洲五月天丁香| 此物有八面人人有两片| 国产人伦9x9x在线观看| 亚洲九九香蕉| 国产极品精品免费视频能看的| 欧美中文日本在线观看视频| 亚洲国产欧洲综合997久久,| 757午夜福利合集在线观看| 精品一区二区三区视频在线 | 欧美激情在线99| ponron亚洲| 亚洲国产中文字幕在线视频| 十八禁网站免费在线| 757午夜福利合集在线观看| 一级作爱视频免费观看| 热99在线观看视频| 亚洲国产欧美网| 麻豆av在线久日| 免费看a级黄色片| 男女那种视频在线观看| 亚洲欧美一区二区三区黑人| 成人av一区二区三区在线看| 午夜福利成人在线免费观看| 久久精品综合一区二区三区| 一级黄色大片毛片| e午夜精品久久久久久久| 国产91精品成人一区二区三区| 香蕉久久夜色| 久久午夜亚洲精品久久| 男人舔女人下体高潮全视频| 亚洲中文日韩欧美视频| 十八禁人妻一区二区| 色在线成人网| 亚洲欧美日韩高清在线视频| 欧美在线一区亚洲| 亚洲专区中文字幕在线| 久久久久国内视频| 亚洲精品一区av在线观看| 国产 一区 欧美 日韩| 午夜亚洲福利在线播放| 一进一出抽搐gif免费好疼| 久久伊人香网站| 国产精品精品国产色婷婷| 国产一级毛片七仙女欲春2| 亚洲av电影不卡..在线观看| 90打野战视频偷拍视频| 亚洲熟女毛片儿| 欧美一级毛片孕妇| 欧美日韩中文字幕国产精品一区二区三区| 黑人巨大精品欧美一区二区mp4| 欧美丝袜亚洲另类 | 国内精品久久久久精免费| 欧美成人性av电影在线观看| 久久精品人妻少妇| 亚洲欧洲精品一区二区精品久久久| 在线观看美女被高潮喷水网站 | 国产激情欧美一区二区| 国产精品久久久久久人妻精品电影| 神马国产精品三级电影在线观看| 两个人看的免费小视频| 99国产精品一区二区蜜桃av| 亚洲精品在线观看二区| 淫妇啪啪啪对白视频| 一个人观看的视频www高清免费观看 | 九色成人免费人妻av| 国产精品98久久久久久宅男小说| 国产97色在线日韩免费| 亚洲精品粉嫩美女一区| 欧美日韩综合久久久久久 | 男人舔奶头视频| xxx96com| 免费人成视频x8x8入口观看| 国产男靠女视频免费网站| 免费观看精品视频网站| 18美女黄网站色大片免费观看| 日韩欧美精品v在线| 精品国产乱子伦一区二区三区| 91av网站免费观看| 日本成人三级电影网站| 99久久国产精品久久久| 一区福利在线观看|