久久av综合,激情婷婷欧美,自拍自偷一区二区三区,久久精品免费一区二区三区

首頁 > 新車性能 > 新車性能 > 保持對話繼續:使用ChatGPT修復337個bug中的162個,每個0.42美元

保持對話繼續:使用ChatGPT修復337個bug中的162個,每個0.42美元

發布時間:2024-05-28 16:40:11來源: 15210273549

引用

Xia C S, Zhang L. Keep the Conversation Going: Fixing 162 out of 337 bugs for $0.42 each using ChatGPT[J]. arXiv preprint arXiv:2304.00385, 2023.

論文:
https://arxiv.org/abs/2304.00385

摘要

自動程序修復(APR)旨在自動為有錯誤的程序生成補丁。傳統的 APR 技術缺乏補丁多樣性,因為它們嚴重依賴手工或挖掘的錯誤修復模式,并且不能輕易推廣到其他錯誤/修復類型。為了解決這一限制,最近的 APR 工作重點是利用現代大型語言模型 (LLM) 直接生成 APR 補丁。這種基于 LLM 的 APR 工具的工作原理是,首先構建使用原始錯誤代碼構建的輸入提示,然后查詢 LLM 以在錯誤位置填寫(完型式 APR)正確的代碼,或者生成一個全新的代碼片段作為修補。雖然基于 LLM 的 APR 工具能夠實現最先進的結果,但它仍然遵循經典的生成和驗證 (GV) 修復范例,即首先通過從相同的初始提示中采樣來生成大量補丁,然后驗證每個補丁之后的一個。這不僅會導致許多不正確的重復補丁,而且還會錯過測試失敗以及看似合理的補丁中的關鍵但之前被忽略的信息。為了解決上述限制,我們提出了 ChatRepair,這是第一個完全自動化的對話驅動的 APR 方法,它將補丁生成與即時反饋交織在一起,以對話方式執行 APR。 ChatRepair 首先向 LLM 提供相關測試失敗信息,然后從同一錯誤的早期修補嘗試的失敗和成功中學習,以獲得更強大的 APR。對于未能通過所有測試的早期補丁,我們將不正確的補丁與其相應的相關測試失敗信息結合起來,構建一個新的提示,供LLM生成下一個補丁。這樣,我們就可以避免犯同樣的錯誤。對于通過所有測試的早期補丁(即合理的補?。?,我們進一步要求LLM生成原始合理補丁的替代變體。通過這種方式,我們可以進一步借鑒早期的成功經驗,生成更合理的補丁,從而增加獲得正確補丁的機會。雖然我們的方法是通用的,但我們使用最先進的基于對話的 LLM – ChatGPT 來實現 ChatRepair。我們對廣泛研究的 Defects4j 數據集的評估表明,ChatRepair 能夠在修復性能方面達到最先進的水平,在 Defects4j 1.2 和 2.0 上分別實現 114 和 48 個正確修復。通過計算訪問 ChatGPT 的成本,我們可以修復 337 個錯誤中的 162 個,每個錯誤 0.42 美元!

1 引言

自動程序修復 (APR) 是一種自動生成軟件錯誤補丁的有前途的方法。傳統的 APR 工具通常使用生成和驗證 (GV)范例,首先生成大量候選補丁,然后根據原始測試套件驗證每個補丁,以發現一組合理的補?。ㄍㄟ^所有測試)。然后將這些看似合理的補丁提供給開發人員,以找到正確修復潛在錯誤的正確補丁。傳統的APR技術可以分為基于模板的,基于啟發式的和基于約束的APR工具。在這些傳統技術中,基于模板的 APR 工具,使用手工制作或挖掘的修復模板來匹配和修復有缺陷的代碼模式,被認為是最先進的。然而,基于模板的工具缺乏補丁多樣性,因為它們無法輕松泛化到預定義模板列表之外的錯誤和模式。為了解決傳統 APR 技術的局限性,研究人員提出了利用深度學習進步的基于學習的 APR 方法?;趯W習的方法主要基于神經機器翻譯(NMT)或大型語言模型(LLM)?;?NMT 的 APR 工具將修復視為一項翻譯任務,通過使用歷史錯誤修復數據集訓練 NMT 模型將有錯誤的代碼轉換為正確的代碼。然而,這種基于 NMT 的 APR 工具嚴重依賴于其訓練數據,這些數據是通過抓取開源存儲庫來進行錯誤修復提交而獲得的。這意味著不僅訓練數據集可能有噪音(即包含不相關的提交/更改),而且這些基于 NMT 的方法可能無法推廣到在有限的訓練數據中未見的錯誤修復類型。

最近,研究人員開始直接利用高級LLM進行 APR。現代LLM接受了數十億個開源代碼片段的訓練,在許多與代碼相關的任務上展示了令人印象深刻的性能,并且可以學習在給定周圍上下文的情況下直接生成代碼(由于代碼自然性)。 AlphaRepair提出了第一個完形填空式(或填充式)APR 方法,其中有錯誤的代碼被刪除,并且 LLM 在給定前綴和后綴上下文的情況下直接預測正確的代碼。最近的工作還應用基于 LLM 的 APR 來自動完成單個正確行或生成完整的固定函數。一項更廣泛的研究研究了將更大的 LLM 和不同的 LLM 架構(即生成式和填充式)應用于 APR,并證明基于 LLM 的 APR 工具可以在許多 APR 任務上實現新的最先進的性能。同時,現有的基于LLM的APR渠道仍然存在以下局限性:

1)缺少測試失敗信息。當前基于 LLM 的工具沒有考慮原始 bug 暴露測試中的豐富信息。這些信息不僅可以幫助LLM理解被測源代碼的含義,還可以通過具體的代碼片段提供幫助和提示。圖 1 顯示了錯誤修復示例以及原始測試失敗信息。我們看到解決方法是將附加字符串交換為“\\000”。對于基于 LLM 的方法來說,這可能是一個極其困難的修復,因為這個獨特的字符串是這不是預訓練期間常用的字符串,并且當前函數上下文中也沒有其他三重字符串(“\\XXX”)的示例。然而,從測試中的失敗行和相應的錯誤消息中,我們看到測試期望輸出包含三個零,甚至包含直接在補丁中使用的代碼片段(“\\000”)!LLM在處理/利用測試失敗日志等非結構化/復雜信息方面表現出了強大的能力。如果不考慮它們,基于 LLM 的工具可能會浪費大量時間來生成不相關的補丁。

2)重復采樣。當前基于 LLM 的方法首先使用原始有缺陷的代碼構建輸入提示,然后要求 LLM 填寫正確的代碼(即完型填空式 APR)或生成全新的固定函數。使用初始提示,基于 LLM 的技術將對 LLM 進行多次采樣以生成許多補丁,類似于傳統的程序修復 GV 范例。然而,由于每個樣本都是完全獨立的,LLM 不知道任何先前生成的補丁。因此,基于 LLM 的工具可能會生成許多重復或類似的補丁,這些補丁已被確定為不正確,從而浪費 API 訪問的成本或 GPU 執行的時間。此外,這種重復采樣過程也與人類開發人員修復錯誤的方式截然不同,人類開發人員在知識的基礎上迭代構建,并嘗試從之前失敗的嘗試中提出下一個可能的補丁。

3)對有價值的合理補丁的無知。除了無法使用過去的錯誤補丁之外,當前基于 LLM 的 APR 工具也無法有效利用之前生成的合理補丁。合理的補丁已被證明是有價值的,因為它們通常與實際正確的補丁共享相似的位置。此外,我們進一步假設合理的補丁可能還包括通過所有測試的關鍵代碼成分,并且還可以幫助LLM更好地學習如何通過所有測試以生成更合理的補丁(從而增加生成正確補丁的機會)。通過忽略這些有價值的合理補丁信息并在生成合理補丁后從頭開始,現有的基于 LLM 的 APR 可能會錯過正確修復更多錯誤的機會。

我們的工作。我們推出 ChatRepair – 一種完全自動化的對話驅動的 APR 方法,它將補丁生成與即時反饋交織在一起,以對話方式執行補丁生成。雖然我們的想法很籠統,但為了構建 ChatRepair,我們使用最近開發的、當前最先進的基于對話的 LLM – ChatGPT,它不僅經過數十億代碼片段的訓練,而且還經過設計以對話方式使用,以更好地理解說明。 ChatRepair 首先提取相關測試失敗信息作為初始提示,為 ChatGPT 提供更多 APR 上下文信息。此外,ChatRepair 進一步從早期修補的失敗和成功中學習嘗試相同的錯誤以獲得更強大的 APR。對于未能通過所有測試的早期補丁,我們將不正確的補丁與其相應的測試失敗信息結合起來,構建一個新的提示,供 LLM 生成下一個補丁。這樣,我們就可以避免犯同樣的錯誤。對于通過所有測試的早期補?。春侠淼难a?。?,我們進一步要求LLM生成原始合理補丁的替代變體。通過這種方式,我們可以進一步借鑒早期的成功經驗,生成更合理的補丁,從而增加獲得正確補丁的機會。由于我們的方法使用 ChatGPT 模型,因此我們還計算用于修復錯誤的 ChatGPT API 查詢的美元成本。令人驚訝的是,我們發現通過使用 ChatRepair,我們可以修復 337 個錯誤中的 162 個,每個錯誤 0.42 美元。

本文做出以下貢獻:

維度。我們為全自動程序修復開辟了對話驅動范例的新維度。我們的工作首次證明,我們可以有效地利用以前被忽略的測試失敗信息,以及以對話方式進行的早期補丁嘗試,以提示LLM生成更正確的補丁。此外,我們展示了利用基于對話的LLM進行 APR 的廣闊前景。
技術。我們使用最新的ChatGPT 模型開發了ChatRepair,這是一種完全自動化的對話驅動的APR 工具。更具體地說,我們自動提取有關初始測試失敗以及早期補丁嘗試的簡潔相關信息,以提示 ChatGPT 進行有效的 APR。
評估。我們在廣泛研究的 Defects4j 1.2、2.0和 QuixBugs數據集上針對當前最先進的基于學習的傳統 APR 工具評估 ChatRepair。 ChatRepair 在 Defects4j 1.2 和 2.0 上分別獲得了 114 個和 48 個正確錯誤修復(比之前的最佳基線多 15 個和 17 個)的新的最先進修復結果。此外,我們進行了廣泛的消融研究,以證明利用豐富的語義測試失敗信息和 ChatRepair 的對話范例進行修復所獲得的改進。
2 技術介紹

我們提出了 ChatRepair,一種完全自動化的對話驅動的 APR 技術,它結合了多個維度的反饋信息來迭代查詢模型以生成補丁。 ChatRepair 不像現有基于 LLM 的 APR 技術那樣直接根據有缺陷的代碼生成補丁,而是另外提供有價值的測試失敗信息,以進一步幫助 LLM 生成補丁。此外,ChatRepair 并沒有像之前基于 LLM 的 APR 技術那樣從相同的提示中連續采樣,而是跟蹤對話歷史記錄,并通過提示從先前失敗和成功的同一錯誤修補嘗試中進一步學習。通過這種方式,ChatRepair 既可以避免以前的失敗,又可以在早期的成功(例如合理的補?。┑幕A上構建更有效的 APR。因此,ChatRepair 最大限度地提高了獲得正確修復潛在錯誤的真正正確補丁的能力。雖然我們的方法是通用的,可以使用不同的 LLM 并應用于各種不同的修復場景,但在這項工作中,我們使用專為對話交互設計的最先進的 ChatGPT 模型,如圖1所示。


圖1:ChatRepair整體工作流程

2.1 初始輸入

首先,我們使用原始的bug項目和bug來構建ChatGPT的初始提示,以啟動修復過程。我們遵循先前基于學習的APR工具,并主要關注線級修復(特別是填充或封閉型APR,因為它已被證明是最先進的[58])。同時,ChatRepair通常也可以用于各種不同的修復場景,我們將在后面的部分中更詳細地對其進行評估。

ChatRepair使用來自失敗測試的各種信息,包括1)它的名稱,2)觸發測試失敗的相關代碼行,以及3)產生的錯誤消息。失敗測試的名稱可以作為被測函數的簡短摘要。在圖2的例子中,失敗的測試是
testGreatestSubtypeUnionTypes5(),它告訴我們,我們正在測試一個與從聯合類型中確定最大子類型相關的功能。相關的測試代碼和錯誤消息給出了關于測試失敗原因的具體信息。在示例中,相關的測試代碼和錯誤消息告訴模型,我們正在比較No_OBJECT_TYPE,但源代碼函數錯誤地返回了一個None對象。這樣失敗的測試信息不僅在源代碼的功能方面為模型提供了更多的解釋,而且在預期輸出和函數使用方面提供了具體的信息,以幫助模型生成正確的修復。注意,如果有多個失敗的測試,ChatRepair只提供其中一個的信息,以保持簡潔的初始提示。最后,我們通過給model生成正確的行來替換填充位置的有bug的代碼來結束我們的初始提示。設C為輸出生成序列概率的ChatGPT,preandsufas為刪除錯誤行后的錯誤代碼的前綴和后綴,Ifillas為替換錯誤行的填充令牌,f0為構造的失敗測試信息,Ifillas為填充指令提示符。補丁pgenerated可以形式化的條件概率:C(p|pre,infill,suf,f0,Ifill)

據我們所知,ChatRepair是第一個通過結合故障信息的自然語言描述(例如,代碼在此測試中失敗:{failure_test})作為輸入到強大的ChatGPT模型中,以純提示方法應用這些測試失敗和錯誤消息的工作。與之前使用的修復測試執行信息不同[61],它依賴于自定義編碼或手工制作的啟發式,通過使用ChatGPT通過提示進行ChatRepair不僅是跨越不同編程語言但也不受測試信息類型的限制。

2.2 會話修補

我們首先使用創建的初始提示來查詢ChatGPT以獲得模型輸出并提取候選補丁。然后,我們轉移到方法的對話部分,我們將patch生成與測試驗證反饋交織在一起,以對話的方式提示未來的生成。每個由模型生成的補丁之后,都立即有一個補丁驗證步驟,以在測試套件上編譯和運行補丁。如果補丁未能通過測試,我們將使用不正確的補丁和失敗的測試構建詳細的反饋信息,作為下一個補丁生成提示的一部分。與初始提示類似,測試失敗信息可以幫助模型了解失敗原因,并為生成正確修復提供指導。在對話步驟中,我們進一步將測試失敗信息與之前不正確的補丁結合起來,不僅可以避免生成更多類似的不正確補丁,還可以從前幾代的錯誤中學習。我們重復這個過程,直到生成一個通過整個測試套件的可信補丁。

2.3 貌似合理的補丁生成

在前一步之后,ChatRepair應該獲得一個可以通過整個測試套件的貌似合理的補丁。然而,一個似是而非的補丁可能并不總是能夠正確地修復底層bug,因為測試套件可能是不完整的,因此無法覆蓋底層代碼的所有可能的預期用法。因此,開發人員必須手動檢查合理的補丁以確定正確的補丁。合理的補丁和最終正確的補丁都有一個相似的特點:它們都可以通過整個測試套件。因此,ChatRepair不是從頭開始),而是直接利用現有的可信補丁來創建更可信的補丁。簡而言之,為了增加我們能夠生成正確補丁的概率,ChatRepair采用之前生成的可信補丁,并要求模型生成替代變體并產生額外的候選補丁。

首先,我們采用最初使用的提示符,其中包含原始的有bug的代碼功能以及有用的測試失敗信息。然后,我們在提示符后面添加生成的合理補丁列表。在開始時,該列表將只包含上一步中單個合理的補丁,但是隨著我們繼續生成額外的合理補丁,它會增長。接下來,我們在提示符中指出我們想要解決的任務-請生成一個替代修復行。然后,我們使用這個提示符作為ChatGPT的輸入,并獲得一個候選補丁,我們將再次編譯并運行測試套件,以檢查它是否確實是另一個合理的補丁。我們不斷地查詢ChatGPT并更新提示符,以包含生成的新的可信補丁,以避免再次重復生成相同的可信補丁,并進一步構建早期的可信補丁。再次設C為輸出生成序列概率的ChatGPT模型,Ibe為初始提示符,Iplas為任務指令,PL<n={pl1,…,pln−1}是之前生成的可信補丁。生成的下一個似是而非的補丁可以形式化為條件概率:C(pli|I,PL<i,IPL)。

最后,我們得到一個似是而非的補丁列表,這些補丁可以交給開發人員進行人工檢查。與之前的APR工具(僅對原始錯誤代碼進行操作以生成補丁)不同,ChatRepair利用每個可能的補丁中額外的有用信息來獲得更多可能的補丁。一個合理的補丁通常包含有用的成分/模式,允許它通過原始測試套件;因此,ChatGPT不是從頭開始(即再次修復錯誤),而是在現有的可信補丁的基礎上構建,通過其強大的理解指令的能力,可以獲得額外的可信補丁,以增加我們的最終補丁列表中包含修復錯誤的正確補丁的可能性。

新車性能更多>>

深藍汽車已經通過用戶服務月的“五大主動”,開啟了從規模擴張到價值經營的轉身 動如疾“風” 靜臥“云”端 風云T9L九大越級僅12.99萬元起 不做選擇題的年輕人,能讓15萬級SUV市場卷出新高度嗎? 本田Prelude,矛盾重重但又棄之可惜的雙門小跑 售價區間12.99-18.69萬元 搭載鯤鵬超能電混CDM6.0 奇瑞風云T9L正式上市 廣汽以星源插混、星源超級雙擎(HEV+)為核心,疊加星源增程構建全域動力矩陣,重構混動行業新標桿 13.38萬,歐拉5限定版憑什么讓99臺車1分28秒賣光? 30分鐘沒廢話 東風日產這次把發布會開成了“爽文” 馮長軍:汽車設計是品牌靈魂的直觀體現 嵐圖汽車為上海交大和西安交大校慶提供出行保障 深度試駕沃爾沃XC90 T8:是不是新能源不重要,重要的是腔調 濟南展看麗馳:四大展區全系車型深度解析,三大核心技術引爆全場 3月份出口量“炸場”,中國汽車出海按下加速鍵 20萬級家用MPV破局者:江淮瑞風RF8悅享系列 重新定義全家舒適出行 尚界新車挑戰小米SU7, “全系滿配”能否后來居上? 比亞迪如何用12年啃下新加坡這塊“硬骨頭”? 純電SUV埃安N60即將迎來上市,新車定于4月16日開啟預售 3月交付同比漲136%,是時候重估蔚來價值了 30萬的「9系旗艦」,上汽大眾闖進新勢力腹地 新一代SU7交付即上量,領克07GT定名:“7系”之戰誰能贏? 奇瑞集團3月銷量240,678輛 同比增長12.1% 一季度出口近40萬輛 上汽集團年銷450.7萬輛凈利翻倍 新年一季度銷量持續走強 “飽和式”進擊、“確定感”托底,一汽-大眾“含金量”還在上升 60 萬銷量背后的 “奇瑞樣本”:從規模增長到高質量躍遷 油價漲到心慌?一汽-大眾新車型、新政策,給車主吃下定心丸 15萬元左右大五座SUV首選!廣汽昊鉑HT豪華滿配超值 從泰國年度汽車大獎到月銷3萬,深藍探索全球化與本土化雙線發展路徑 紀念40年榮耀,本田賽車公司打造謳歌Integra超級復刻定制賽車 做新能源時代“三好學生” 奇瑞風云T9L重構家用SUV價值 長城炮迎來強敵 全新江鈴大道換裝2.5T動力 售價11.28萬元起
久久av综合,激情婷婷欧美,自拍自偷一区二区三区,久久精品免费一区二区三区
国产精品nxnn| 在线看片不卡| 国产aⅴ精品一区二区三区久久| 99日韩精品| av一区二区高清| 国产福利片在线观看| 国产精品一区2区3区| 人人爱人人干婷婷丁香亚洲| 在线观看亚洲精品福利片| 国产一区91| 在线亚洲观看| 综合激情一区| 亚洲精品动态| 欧美日韩调教| 最新国产精品久久久| 亚洲一区二区日韩| 日韩一区二区三区精品| 欧美欧美黄在线二区| 国产精品xxx| 国产一区不卡| 国产一级一区二区| 国产午夜精品一区在线观看| 美腿丝袜在线亚洲一区| 久久久久久婷| 久久久久国产| 久久电影一区| 日本不卡一二三区黄网| 日韩av电影一区| 国产高清日韩| 91成人精品在线| 国产欧美三级| 久久不卡日韩美女| 国产一区精品福利| 鲁大师精品99久久久| 午夜日韩在线| 亚洲精品乱码日韩| 久久精品日韩欧美| 在线精品小视频| 欧美精品99| 91精品蜜臀一区二区三区在线| 91成人网在线观看| 亚洲欧美日韩专区| 国产欧美在线| 中文字幕人成乱码在线观看| 水蜜桃精品av一区二区| 久久精品青草| 7m精品国产导航在线| 久久免费高清| 欧美偷窥清纯综合图区| av高清不卡| 伊人国产精品| 欧美黄色网页| 国产精品片aa在线观看| 国产99久久| 97久久超碰| 中文字幕亚洲影视| 日韩精品一区二区三区免费观影| 亚洲一区二区三区中文字幕在线观看 | 亚洲精品888| 国产精品视频一区二区三区四蜜臂| 久久一区二区三区喷水| 麻豆高清免费国产一区| 四虎精品一区二区免费| 欧美日一区二区| 国产精品激情| 男女性色大片免费观看一区二区 | 香蕉成人av| 国产剧情一区二区在线观看| 欧美精品一区二区久久| 精品国产一区二区三区2021| 日日夜夜免费精品视频| 欧美日韩激情| 欧美韩日一区| 成人av三级| 久久99青青| 欧美日韩一区二区三区四区在线观看| 黄色亚洲精品| 国产精品普通话对白| 黄色在线观看www| 国产精品欧美一区二区三区不卡| 丝袜美腿成人在线| 97在线精品| 成人台湾亚洲精品一区二区| 美女久久久久久 | 一区二区三区午夜视频| 久久国产直播| 人人精品亚洲| 精品在线99| 99视频精品全国免费| 成人片免费看| 久久久影院免费| 午夜国产一区二区| 国产一区导航| 日本精品久久| 国产欧美高清视频在线| 91亚洲国产成人久久精品| 欧美精选视频一区二区| 久久精品国产68国产精品亚洲| 国产在线成人| 香蕉国产精品| 国产欧美一区二区色老头| 久久亚洲道色| 免费成人在线影院| 国产丝袜一区| 欧美一区久久久| 久久蜜桃精品| 日韩区欧美区| 国产精品成人一区二区不卡| 午夜国产欧美理论在线播放 | 中文字幕日韩高清在线| 久久久久黄色| 香蕉久久国产| 国产亚洲字幕| 亚洲主播在线| 高清在线一区| 亚洲精品美女91| 欧洲一级精品| 日韩免费精品| 日韩啪啪电影网| 欧美经典一区| 色8久久久久| 激情欧美丁香| 久久99蜜桃| 国产毛片久久| 亚洲精品乱码日韩| 中文在线免费视频| 日韩不卡一二三区| 尤物网精品视频| 国产精品99一区二区三区| 视频一区在线视频| 久久久久久美女精品| 国产精品一国产精品k频道56| 99成人在线视频| 精品视频免费| 欧美视频一区| 最新亚洲国产| 亚洲欧美日韩国产| 中国字幕a在线看韩国电影| 在线亚洲免费| 精品欧美久久| 激情欧美一区二区三区| 日韩免费看片| 国产精品一在线观看| 亚洲精品少妇| 亚洲一级大片| 免费高清在线一区| 美国欧美日韩国产在线播放| 日韩中文字幕高清在线观看| 国产一区2区| 久久中文精品| 日本亚洲视频在线| 亚洲精品成a人ⅴ香蕉片| 午夜亚洲精品| 久久精品国内一区二区三区水蜜桃| 精品伊人久久| 国产盗摄——sm在线视频| 麻豆精品在线播放| 久久精品二区亚洲w码 | 新版的欧美在线视频| 美日韩精品视频| 久久精品伊人| 亚洲午夜av| 久久午夜精品一区二区| 国产精品久久乐| 久久久蜜桃一区二区人| 亚洲女同av| 国产另类在线| 日韩欧美综合| 日韩三区四区| 亚洲欧美不卡| 久久精品高清| 日韩va亚洲va欧美va久久| 欧美日韩在线二区| 欧美日韩a区| 久久精品国产99国产精品| 激情欧美一区| 国产精品久久久久久久久久久久久久久| 日韩中文视频| 亚洲欧美日本国产| 国产模特精品视频久久久久| 欧美天堂视频| 97人人精品| 老司机精品久久| av中文资源在线资源免费观看| 亚洲深深色噜噜狠狠爱网站 | 国产伦久视频在线观看| 国产精品嫩草99av在线| 精品中文字幕一区二区三区四区| 日本亚洲欧洲无免费码在线| 韩国女主播一区二区三区| 国产日韩中文在线中文字幕| 伊人久久大香伊蕉在人线观看热v| 日韩一级不卡| 日韩精品dvd| 亚洲天堂久久| 免费精品视频| 亚洲精品少妇| 国产精品久久国产愉拍| 欧美黑人做爰爽爽爽| 欧美激情麻豆|