在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

教你寫(xiě)出讓同事無(wú)法維護(hù)的代碼

GReq_mcu168 ? 來(lái)源:CSDN知識(shí)庫(kù) ? 作者:CSDN知識(shí)庫(kù) ? 2020-12-09 15:45 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

對(duì),你沒(méi)看錯(cuò)。

本文就是教你怎么寫(xiě)出讓同事無(wú)法維護(hù)的代碼。

01

程序命名

容易輸入的變量名。比如:Fred,asdf

單字母的變量名。比如:a,b,c,x,y,z(如果不夠用,可以考慮 a1,a2,a3,a4,….)

創(chuàng)意地拼寫(xiě)錯(cuò)誤。比如:SetPintleOpening, SetPintalClosing,這樣可以讓人很難搜索代碼。

抽象。比如:ProcessData,DoIt,GetData… 抽象到就跟什么都沒(méi)說(shuō)一樣。

縮寫(xiě)。比如:WTF,RTFSC …… (使用拼音縮寫(xiě)也同樣給力,比如:BT,TMD,TJJTDS)

隨機(jī)大寫(xiě)字母。比如:gEtnuMbER..

重用命名。在內(nèi)嵌的語(yǔ)句塊中使用相同的變量名有奇效。

使用重音字母。比如:int ínt(第二個(gè) ínt 不是 int )

使用下劃線。比如:_,__,___。

使用不同的語(yǔ)言。比如混用英語(yǔ),德語(yǔ),或是中文拼音。

使用字符命名。比如:slash, asterix, comma…

使用無(wú)關(guān)的單詞。比如:god, superman, iloveu….

混淆l和1。字母 l 和數(shù)字 1 有時(shí)候是看不出來(lái)的。

02

偽裝欺騙

把注釋和代碼交織在一起。

b7ff9cf0-33d6-11eb-a64d-12bb97331649.png

代碼和顯示不一致。比如,你的界面顯示叫 postal code,但是代碼里確叫 zipcode。

隱藏全局變量。把使用全局變量以函數(shù)參數(shù)的方式傳遞給函數(shù),這樣可以讓人覺(jué)得那個(gè)變量不是全局變量。

使用相似的變量名。如:?jiǎn)卧~相似,swimmer 和 swimner,字母相似:ilI1| 或 oO08,parselnt 和 parseInt, D0Calc 和 DOCalc,還有這一組:xy_Z, xy__z, _xy_z, _xyz, XY_Z, xY_z, Xy_z。

重載函數(shù)。使用相同的函數(shù)名,但是其功能和具體實(shí)現(xiàn)完全沒(méi)有關(guān)系。

操作符重載。重載操作符可以讓你的代碼變得詭異,感謝 CCTV,感謝 C++,這個(gè)東西是可以把混亂代碼提高到一種藝術(shù)的形式。

比如:重載一個(gè)類的 ! 操作符,但實(shí)際功能并不是取反,讓其返回一個(gè)整數(shù)。

于是,如果你使用 ! ! 操作符,那么,有意思的事就發(fā)生了—— 先是調(diào)用類的重載 ! 操作符,然后把其返回的整數(shù)給 ! 成了 布爾變量,如果是 !!! 呢?呵呵。

03

文檔和注釋

在注釋中撒謊。你不用真的去撒謊,只需在改代碼的時(shí)候不要更新注釋就可以了。

注釋里面寫(xiě)廢話。比如:/* add 1 to i */

只注釋是什么,而不是為什么。

不要注釋秘密。如果你開(kāi)發(fā)一個(gè)航班系統(tǒng),請(qǐng)你一定要保證每有一個(gè)新的航班被加入,就得要修改 25 個(gè)以上的位置的程序。千萬(wàn)別把這個(gè)事寫(xiě)在文檔中。

注重細(xì)節(jié)。當(dāng)你設(shè)計(jì)一個(gè)很復(fù)雜的算法的時(shí)候,你一定要把所有的詳細(xì)細(xì)設(shè)計(jì)都寫(xiě)下來(lái),沒(méi)有 100 頁(yè)不能罷休,段落要有5級(jí)以上,段落編號(hào)要有 500 個(gè)以上。

例如:1.2.4.6.3.13 – Display all impacts for activity where selected mitigations can apply (short pseudocode omitted).。

這樣,當(dāng)你寫(xiě)代碼的時(shí)候,你就可以讓你的代碼和文檔一致,如:Act1_2_4_6_3_13() 千萬(wàn)不要注釋度衡單位。

比如時(shí)間用的是秒還是毫秒,尺寸用的是像素還是英寸,大小是 MB 還是 KB 等等。另外,在你的代碼里,你可以混用不同的度衡單位,但也不要注釋。

Gotchas。陷阱,千萬(wàn)不要注釋代碼中的陷阱。

在注釋和文檔中發(fā)泄不滿。

04

程序設(shè)計(jì)

Java Casts。Java 的類型轉(zhuǎn)型是天賜之物,每一次當(dāng)你從 Collectio n里取到一個(gè) object 的時(shí)候,你都需要把其轉(zhuǎn)回原來(lái)的類型。

因些,這些轉(zhuǎn)型操作會(huì)出現(xiàn)在 N 多的地方。

如果你改變了類型,那么你不一定能改變所有的地方。而編譯器可能能檢查到,也可能檢查不到。

利用 Java 的冗余。比如:Bubblegum b = new Bubblegom(); 和 swimmer = swimner + 1; 注意變量間的細(xì)微差別。

從不驗(yàn)證。從不驗(yàn)證輸入的數(shù)據(jù),從不驗(yàn)證函數(shù)的返回值。這樣做可以向大家展示你是多么的信任公司的設(shè)備和其它程序員

不要封裝。調(diào)用者需要知道被調(diào)用的所有的細(xì)節(jié)。

克隆和拷貝。為了效率,你要學(xué)會(huì)使用 copy + past,你幾乎都不用理解別人的代碼,你就可以高效地編程了。

巨大的listener。寫(xiě)一個(gè) listener,然后讓你的所有的 button 類都使用這個(gè) listener,這樣你可以在這個(gè) listener 中整出一大堆 if…else… 語(yǔ)句,相當(dāng)?shù)拇碳ぁ?/p>

使用三維數(shù)組。如果你覺(jué)得三維還不足夠,你可以試試四維。

混用。同時(shí)使用類的 get/set 方法和直接訪問(wèn)那個(gè) public 變量,這樣做的好處是可以極大的挫敗維護(hù)人員。

包裝,包裝,包裝。把你所有的 API 都包裝上 6 到 8 遍,包裝深度多達(dá) 4層以上,然后包裝出相似的功能。

沒(méi)有秘密。把所有的成員都聲明成 public 的,這樣,你以后就很難限制其被人使用,而且這樣可以和別的代碼造成更多的耦合度,可以讓你的代碼存活得更久。

排列和阻礙。把drawRectangle(height, width) 改成 drawRectangle(width, height),等 release 了幾個(gè)版本后,再把其改回去,這樣維護(hù)程序的程序員們很快就不明白哪一個(gè)是對(duì)的。

把變量改在名字上。例如,把 setAlignment(int alignment) 改成,setLeftAlignment,setRightAlignment,setCenterAlignment。

保留你所有的沒(méi)有使用的和陳舊的變量,方法和代碼。

Final 你所有的子結(jié)點(diǎn)的類,這樣,當(dāng)你做完這個(gè)項(xiàng)目后,沒(méi)有人可以通過(guò)繼承來(lái)擴(kuò)展你的類。java.lang.String 不也是這樣嗎?

避免使用 layout。這樣就使得我們只能使用絕對(duì)坐標(biāo),如果你的老大強(qiáng)制你使用 layout,你可以考慮使用 GridBagLayout,然后把 grid 坐標(biāo) hard code。

環(huán)境變量。如果你的代碼需要使用環(huán)境變量,那么,你應(yīng)該把你的類的成員的初始化使用環(huán)境變量,而不是構(gòu)造函數(shù)。

使用全局變量。1)把全局變量的初始化放在不同的函數(shù)中,就算這個(gè)函數(shù)和這個(gè)變量沒(méi)有任何關(guān)系,這樣能夠讓我們的維護(hù)人員就像做偵探工作一樣。

2)使用全局變量可以讓你的函數(shù)的參數(shù)變得少一些。

配置文件。配置文件主要用于一些參數(shù)的初始化,在編程中,我們可以讓配置文件中的參數(shù)名和實(shí)際程序中的名字不一樣。

膨脹你的類。讓你的類盡可能地?fù)碛懈鞣N臃腫和晦澀的方法,比如,你的類只實(shí)現(xiàn)一種可能性,但是你要提供所有可能性的方法。不要定義其它的類,把所有的功能都放在一個(gè)類中。

使用子類。面向?qū)ο笫菍?xiě)出無(wú)法維護(hù)代碼的天賜之物,如果你有一個(gè)類有十個(gè)成為(變量和方法)你可以考慮寫(xiě) 10 個(gè)層次的繼承,然后把這十個(gè)屬性分別放在這十個(gè)層次中。如果可能的話,把這十個(gè)類分別放在十個(gè)不同的文件中。

混亂你的代碼。使用 XML,XML 的強(qiáng)大是無(wú)人能及的,使用 XML 你可以把本來(lái)只要 10 行的代碼變成 100 行。而且,還要逼著別人也有 XML。(參看,信 XML 得永生,信 XML 得自信)

分解條件表達(dá)式。如:把 a==100 分解成,a>99 && a<101

學(xué)會(huì)利用分號(hào)。如:if ( a );else;{ int d; d = c;}

間接轉(zhuǎn)型。如:把 double 轉(zhuǎn) string,寫(xiě)成 new Double(d).toString() 而不是 Double.toString(d)

大量使用嵌套。一個(gè) NB 的程序員可以在一行代碼上使用超過(guò) 10 層的小括號(hào)(),或是在一個(gè)函數(shù)里使用超過(guò) 20 層的語(yǔ)句嵌套{},把嵌套的 if else 轉(zhuǎn)成 [? :] 也是一件很 NB 的事。

長(zhǎng)代碼行。一行的代碼越長(zhǎng)越好,這樣別人閱讀時(shí)就需要來(lái)來(lái)回回的。

不要過(guò)早的return。不要使用 break,這樣,你就需要至少 5 層以上的 if-else 來(lái)處理錯(cuò)誤。

不要使用{}。不要在 if else 使用{},尤其是在你重量地使用 if-else 嵌套時(shí),你甚至可以在其中亂縮進(jìn)代碼,這樣一來(lái),就算是最有經(jīng)驗(yàn)的程序員也會(huì)踩上陷阱。

瑣碎的封裝。比較封裝一個(gè) bool 類,類里面什么都做,就是一個(gè) bool。

循環(huán)。千萬(wàn)不可用 for(int i=0; i

05

測(cè) 試

從不測(cè)試。千萬(wàn)不要測(cè)試任何的出錯(cuò)處理,從來(lái)也不檢測(cè)系統(tǒng)調(diào)用的返回值。

永遠(yuǎn)不做性能測(cè)試。如果不夠快就告訴用戶換一個(gè)更快的機(jī)器。如果你一做測(cè)試,那么就可能會(huì)要改你的算法,甚至重設(shè)計(jì),重新架構(gòu)。

不要寫(xiě)測(cè)試案例。不要做什么代碼覆蓋率測(cè)試,自動(dòng)化測(cè)試。

測(cè)試是懦夫行為。一個(gè)勇敢的程序員是根本不需要這一步的,太多的程序太害怕他們的老板,害怕失去工作,害怕用戶抱怨,甚至被起訴,這種擔(dān)心害怕直接影響了生產(chǎn)力。

如果你對(duì)你的代碼有強(qiáng)大的信心,那還要什么測(cè)試呢?真正的程序員是不需要測(cè)試自己的代碼的。

06

其 他

你的老板什么都知道。無(wú)論你的老板有多 SB,你都要嚴(yán)格地遵照他的旨意辦事,這樣一來(lái),你會(huì)學(xué)到更多的知識(shí)以及如何寫(xiě)出更加無(wú)法維護(hù)的代碼。

顛覆Help Desk。你要確保你那滿是 bug 的程序永遠(yuǎn)不要被維護(hù)團(tuán)隊(duì)知道。當(dāng)用戶打電話和寫(xiě)郵件給你的時(shí)候,你就不要理會(huì),就算要理會(huì),讓用戶重做系統(tǒng)或是告訴用戶其帳號(hào)有問(wèn)題,是標(biāo)準(zhǔn)的回答。

閉嘴。對(duì)于一些像 y2k 這樣的大 bug,你要學(xué)會(huì)守口如瓶,不要告訴任何人,包括你的親人好友以及公司的同事和管理層,這樣當(dāng)?shù)侥且惶斓臅r(shí)候,你就可以用這個(gè) bug 掙錢了。

忽悠。你會(huì)學(xué)會(huì)忽悠,就算你的代碼寫(xiě)得很爛,你也要為其掛上 GoF 設(shè)計(jì)模式的標(biāo)簽,就算你的項(xiàng)目做得再爛,你也要為其掛上敏捷的標(biāo)簽,讓整個(gè)團(tuán)隊(duì)和公司,甚至整個(gè)業(yè)界都開(kāi)始躁動(dòng),這樣才能真正為難維護(hù)的代碼鋪平道路。

總之,我們的口號(hào)是——Write Everywhere, Read Nowhere。

責(zé)任編輯:lq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4893

    瀏覽量

    70445
  • 變量
    +關(guān)注

    關(guān)注

    0

    文章

    614

    瀏覽量

    28885

原文標(biāo)題:如何寫(xiě)出讓同事無(wú)法維護(hù)的代碼?

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    【經(jīng)驗(yàn)分享】玩轉(zhuǎn)FPGA串口通信:從“幻覺(jué)調(diào)試”到代碼解析

    FPGA開(kāi)發(fā),思路先行!玩FPGA板子,讀代碼是基本功!尤其對(duì)從C語(yǔ)言轉(zhuǎn)戰(zhàn)FPGA的“寶貝們”來(lái)說(shuō),適應(yīng)流水線(pipeline)編程可能需要點(diǎn)時(shí)間。上篇點(diǎn)燈代碼解讀了基礎(chǔ),而如果能親手寫(xiě)出串口通訊
    的頭像 發(fā)表于 06-05 08:05 ?222次閱讀
    【經(jīng)驗(yàn)分享】玩轉(zhuǎn)FPGA串口通信:從“幻覺(jué)調(diào)試”到<b class='flag-5'>代碼</b>解析

    手把手教你如何調(diào)優(yōu)Linux網(wǎng)絡(luò)參數(shù)

    在高并發(fā)網(wǎng)絡(luò)服務(wù)場(chǎng)景中,Linux內(nèi)核的默認(rèn)網(wǎng)絡(luò)參數(shù)往往無(wú)法滿足需求,導(dǎo)致性能瓶頸、連接超時(shí)甚至服務(wù)崩潰。本文基于真實(shí)案例分析,從參數(shù)解讀、問(wèn)題診斷到優(yōu)化實(shí)踐,手把手教你如何調(diào)優(yōu)Linux網(wǎng)絡(luò)參數(shù),支撐百萬(wàn)級(jí)并發(fā)連接。
    的頭像 發(fā)表于 05-29 09:21 ?162次閱讀

    富士伺服驅(qū)動(dòng)器的常用故障代碼及其檢查與維護(hù)

    富士伺服驅(qū)動(dòng)器的常用故障代碼及其檢查與維護(hù)方法如下: 一、常用故障代碼及其檢查 1. 過(guò)電流故障(OC 1、OC 2) ? ?● 顯示:驅(qū)動(dòng)器顯示過(guò)電流故障。 ? ?● 檢出內(nèi)容:主回路晶體的輸出
    的頭像 發(fā)表于 04-23 17:37 ?787次閱讀
    富士伺服驅(qū)動(dòng)器的常用故障<b class='flag-5'>代碼</b>及其檢查與<b class='flag-5'>維護(hù)</b>

    為什么無(wú)法從源代碼推斷OpenVINO?構(gòu)建中的VPU?

    為什么無(wú)法從源代碼推斷OpenVINO?構(gòu)建中的 VPU
    發(fā)表于 03-06 07:12

    設(shè)備遠(yuǎn)程維護(hù)如何實(shí)現(xiàn)?遠(yuǎn)程維護(hù)平臺(tái)的功能特點(diǎn)

    隨著工業(yè)智能化和數(shù)字化轉(zhuǎn)型的快速推進(jìn),設(shè)備遠(yuǎn)程維護(hù)已成為企業(yè)提升運(yùn)營(yíng)效率、降低維護(hù)成本的重要手段。通過(guò)遠(yuǎn)程維護(hù)平臺(tái),企業(yè)能夠?qū)崟r(shí)監(jiān)控設(shè)備狀態(tài),快速響應(yīng)故障,實(shí)現(xiàn)設(shè)備的高效管理和維護(hù)。本
    的頭像 發(fā)表于 02-21 15:50 ?381次閱讀
    設(shè)備遠(yuǎn)程<b class='flag-5'>維護(hù)</b>如何實(shí)現(xiàn)?遠(yuǎn)程<b class='flag-5'>維護(hù)</b>平臺(tái)的功能特點(diǎn)

    探討篇(三):代碼復(fù)用的智慧 - 提升架構(gòu)的效率與可維護(hù)

    作者:京東物流 馮志文 前兩篇從服務(wù)粒度和服務(wù)內(nèi)的分層架構(gòu)角度探討,本文繼續(xù)從服務(wù)間代碼復(fù)用角度探討。 背景 在分布式架構(gòu)中,代碼復(fù)用是個(gè)難題。那么如何處理代碼功能共享的問(wèn)題呢?本文結(jié)合日常實(shí)踐中
    的頭像 發(fā)表于 12-27 15:58 ?587次閱讀
    探討篇(三):<b class='flag-5'>代碼</b>復(fù)用的智慧 - 提升架構(gòu)的效率與可<b class='flag-5'>維護(hù)</b>性

    怎么集齊7個(gè)云平臺(tái)?本文教你!

    每家云平臺(tái)都有自己的協(xié)議,工程師要移植不同的SDK代碼或基于各家的手冊(cè)文檔對(duì)接不同的協(xié)議,看著都頭大,該如何集齊7個(gè)云平臺(tái)?本文教你!本文將以Air780E+LuatOS作為示例,教你使用IoT_CLOUD連接Tlink云平臺(tái)。
    的頭像 發(fā)表于 12-02 14:41 ?1016次閱讀
    怎么集齊7個(gè)云平臺(tái)?本文<b class='flag-5'>教你</b>!

    如何安全有效的刪代碼

    作者:京東科技 王丹迪 刪除代碼是軟件開(kāi)發(fā)過(guò)程中常見(jiàn)的一部分,但必須謹(jǐn)慎操作以確保不會(huì)引入錯(cuò)誤或破壞現(xiàn)有功能。有效的做系統(tǒng)瘦身會(huì)降低維護(hù)成本,減少冗余代碼,減少開(kāi)發(fā)同事踩坑的機(jī)會(huì)。以下
    的頭像 發(fā)表于 11-20 10:39 ?576次閱讀

    DAC61416無(wú)法正常SPI通信,無(wú)法寫(xiě)入代碼,為什么?

    這是我的原理圖,在實(shí)際使用時(shí),發(fā)現(xiàn)spi寫(xiě)入有問(wèn)題,無(wú)法寫(xiě)入代碼
    發(fā)表于 11-19 07:22

    讓單片機(jī)代碼性能起飛的七大技巧

    單片機(jī)的程序比軟開(kāi)少一些,真正想編寫(xiě)出高效的代碼,還是要積累很多年的。? ? ? ? ?? 在做研發(fā)工程師的10年里,我經(jīng)歷過(guò)幾個(gè)公司,看過(guò)很多工程師寫(xiě)的代碼,但真正能讓我跪著看完的,極少。哪怕是
    的頭像 發(fā)表于 11-16 10:21 ?1110次閱讀
    讓單片機(jī)<b class='flag-5'>代碼</b>性能起飛的七大技巧

    如何寫(xiě)出穩(wěn)定的單片機(jī)代碼

    這篇文章分享怎么寫(xiě)出穩(wěn)定的單片機(jī)代碼。? ?? 我對(duì)優(yōu)秀代碼的理解,大體分為兩個(gè)部分:高效和穩(wěn)定。 ? 兩者都能做到很好的,如果靠自己摸索,沒(méi)有刻意去練習(xí),可能需要花10年,甚至更久
    的頭像 發(fā)表于 11-15 16:40 ?781次閱讀
    如何<b class='flag-5'>寫(xiě)出</b>穩(wěn)定的單片機(jī)<b class='flag-5'>代碼</b>

    如同TPA6011芯片,耳機(jī)輸出端可以直接設(shè)計(jì)成兩組并聯(lián)輸出讓客戶可選擇插一個(gè)耳機(jī)或兩個(gè)耳機(jī)嗎?

    請(qǐng)問(wèn)如同TPA6011芯片,耳機(jī)輸出端可以直接設(shè)計(jì)成兩組并聯(lián)輸出讓客戶可選擇插一個(gè)耳機(jī)或兩個(gè)耳機(jī)嗎?(不考慮SE/BTL、HP/LINE功能設(shè)定)
    發(fā)表于 10-22 07:07

    代碼整潔之道-大師眼中的整潔代碼是什么樣

    幾個(gè)月前寫(xiě)了一篇文章“如何寫(xiě)出難以維護(hù)代碼”,從中能大概了解到不好維護(hù)代碼是什么樣,有哪些壞味道,那肯定有人會(huì)反問(wèn),難以
    的頭像 發(fā)表于 09-09 16:30 ?621次閱讀
    <b class='flag-5'>代碼</b>整潔之道-大師眼中的整潔<b class='flag-5'>代碼</b>是什么樣

    VG814通過(guò)DM平臺(tái)遠(yuǎn)程維護(hù)LAN口鏈接的攝像頭,經(jīng)常無(wú)法訪問(wèn),請(qǐng)問(wèn)什么原因?

    設(shè)備:VG814 通過(guò)DM平臺(tái) 遠(yuǎn)程維護(hù)LAN口鏈接的攝像頭,經(jīng)常無(wú)法訪問(wèn),請(qǐng)問(wèn)什么原因?應(yīng)該如何排查?經(jīng)常出現(xiàn):.ngrok.iot.inhand.com.cn:83 not found請(qǐng)問(wèn)這個(gè)和瀏覽器、連接方式、有關(guān)系嗎?請(qǐng)幫忙給出建議。
    發(fā)表于 07-24 06:17

    軟件設(shè)計(jì)哲學(xué):新“代碼整潔之道”

    工作三年以來(lái)一直對(duì)寫(xiě)出設(shè)計(jì)優(yōu)雅且可讀性較好的代碼抱有執(zhí)念,最初接觸到的關(guān)于代碼整潔和軟件設(shè)計(jì)的書(shū)是《代碼整潔之道》,這本書(shū)大概在我入職半年時(shí)讀完,并在很長(zhǎng)的一段時(shí)間內(nèi)將其中談到的“每個(gè)
    的頭像 發(fā)表于 07-22 12:18 ?465次閱讀
    軟件設(shè)計(jì)哲學(xué):新“<b class='flag-5'>代碼</b>整潔之道”
    主站蜘蛛池模板: 成人夜色香网站在线观看 | 明日花绮罗在线观看 | 国模张文静啪啪私拍337p | 中文字字幕码一二区 | 99久久综合给久久精品 | 国产伦精品一区二区三区在线观看 | 欧美高清激情毛片 | 亚洲天堂第一页 | 免费高清一级欧美片在线观看 | 美女好紧好大好爽12p | 欧美视频不卡一区二区三区 | 人人做人人爽久久久精品 | 超薄肉色丝袜精品足j福利 超黄视频在线观看 | 岛国毛片 | 一卡二卡卡四卡无人区中文 | 加勒比日本道 | 亚洲精品成人a在线观看 | baoyu168成人免费视频 | 天天干夜夜爽天天操夜夜爽视频 | 成人欧美另类人妖 | 91网站在线看 | 在线天堂中文新版www | 日本高清视频网站www | 国产不卡毛片 | 高清毛片一区二区三区 | 五月天婷婷综合网 | 久操色| 五月激情啪啪网 | 波多野结衣在线一区 | 久操视频免费看 | 欧美美女一区二区三区 | 精品福利在线观看 | 小雪被老外黑人撑破了 | 亚洲国产精品乱码一区二区三区 | 视频在线二区 | www.毛片网站 | 日本国产高清色www视频在线 | 萌白酱白丝护士服喷水铁牛tv | 91综合在线 | 国产chinesetube | 欧美一区二区不卡视频 |