青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-60  評(píng)論-98  文章-0  trackbacks-0
我和充斥臭味代碼的戰(zhàn)爭(zhēng)
by leetaolion 2008-01-12
從去年8月份到現(xiàn)在,我一直在從事一個(gè)261k行代碼的項(xiàng)目(不含空行和注釋)。
其中由我本人編寫(xiě)的代碼10.9k行(不含空行和注釋,我本人所寫(xiě)的注釋大約1/8有效代碼行,屬于比較少的)。
其他模塊注釋非常少,只在接口文件聲明虛接口的時(shí)候會(huì)有一行注釋,實(shí)現(xiàn)文件中幾乎沒(méi)有注釋,大部分文件連文件頭都沒(méi)有。
在我加入小組之前,小組是穩(wěn)定的,每人負(fù)責(zé)幾個(gè)模塊,不采用TDD,依靠的是每日集成。每日的目標(biāo)是:可以Build的代碼。
我加入之后,起初做些邊邊角角的工作。這樣的日子大概持續(xù)了1個(gè)半月的樣子。然后在一個(gè)午睡并沒(méi)有完全醒來(lái)的狀態(tài)下,接手了一個(gè)核心模塊DataMgr_Module,這個(gè)模塊管理所有的計(jì)算的輸出結(jié)果。
一開(kāi)始對(duì)工作的估計(jì)過(guò)于樂(lè)觀,認(rèn)為1個(gè)月就可以搞定。接手之后才發(fā)現(xiàn),原來(lái)的DataMgr_Module其實(shí)是兩個(gè)module,小組的老大和另外一位同事對(duì)于DataMgr是各自為政,每個(gè)人都有一份自己的數(shù)據(jù)結(jié)構(gòu)和管理方法。由于同事同時(shí)負(fù)責(zé)多個(gè)上層模塊的開(kāi)發(fā),所以,DataMgr_Module和上層完全耦合在一起,DataMgr_Module的大部分功能都分布在各個(gè)上層模塊之中,每個(gè)上層模塊重復(fù)實(shí)現(xiàn)的這些功能,如果有一個(gè)功能需要更新,那么就要改動(dòng)所有的上層模塊。所謂的DataMgr_Module只不過(guò)是把自己的所有接口都公布出來(lái)的任人欺負(fù)的家伙,公布的大部分接口都應(yīng)該是私有接口。DataMgr_Module就像是個(gè)受氣包,Manager變成了Clark。
首先要做的是恢復(fù)Manager的地位。統(tǒng)一數(shù)據(jù)結(jié)構(gòu),統(tǒng)一傳輸協(xié)議,從上層模塊收回所有接口實(shí)現(xiàn),規(guī)范業(yè)務(wù)流程,private所有私有接口和成員變量。Manager就該有個(gè)Manager的樣子。
模塊做到最后,我的感受是越到集成測(cè)試的時(shí)候,我就會(huì)越想念TDD。為什么呢?
DataMgr_Module一開(kāi)始就采用了TDD。知道所有的PR會(huì)上確認(rèn)的接口都完成,并通過(guò)了測(cè)試用例。單元測(cè)試做的并不充分,因?yàn)楫?dāng)時(shí)沒(méi)有采用任何的測(cè)試用例方法。只是憑借自己對(duì)模塊可能存在的缺陷進(jìn)行了測(cè)試。整個(gè)單元測(cè)試的過(guò)程與其說(shuō)是在測(cè)試,倒不如說(shuō)是在驗(yàn)證,過(guò)程中對(duì)于錯(cuò)誤的恐懼,使測(cè)試用例漏洞百出,覆蓋效果是比較差勁的。另外一個(gè)原因是,TDD是把測(cè)試用例當(dāng)作用戶手冊(cè)的,但是,同事們根本不在意你的測(cè)試用例。別說(shuō)測(cè)試用例了,有時(shí)候連注釋都懶得看,有問(wèn)題直接溝通,人就是一部用戶手冊(cè)。溝通解決問(wèn)題,是積極高效的,有時(shí)候是重復(fù)的。另外一個(gè)原因就是,注釋的模式不好,常常要更新同樣的3個(gè)不同位置的注釋。之前健健告訴我,應(yīng)該把這看成是必須做好的工作,就好了。但是我人比較懶,需要個(gè)好辦法,變3次為1次。(目前也沒(méi)有找到好辦法,因?yàn)槲覊焊蜎](méi)有怎么好好找過(guò)。)
所以我常常在想,怎么樣才能讓TDD深入我的日常工作呢?
TDD的老爹Kent說(shuō)如果已經(jīng)有可以運(yùn)行的代碼,這時(shí)候是不適合引入TDD的。對(duì)已經(jīng)可以運(yùn)行的261k行代碼重新寫(xiě)測(cè)試用例,怕是要出人命的。我想Kent老爹說(shuō)的是老代碼從新TDD,言之有理,對(duì)于一個(gè)成年人你來(lái)T他的小DD,當(dāng)然就要踢出大事情來(lái)。但是對(duì)于一些新模塊,或者說(shuō)是老模塊需要徹底修改(幾乎全部拋棄)的時(shí)候,年輕人嗎,從小開(kāi)始T他的小DD,慢慢培養(yǎng),說(shuō)不定能T出一個(gè)會(huì)鐵襠功的模塊來(lái),到時(shí)候豈不是天下無(wú)敵了。
正因?yàn)镈ataMgr_Module從小開(kāi)始TDD,集成測(cè)試的時(shí)候,需要增加一個(gè)接口(主要用來(lái)提高模塊的易用性)的時(shí)候,從提出需要到拆入,不過(guò)5分鐘,令用戶滿意的嘴都合不攏了。為什么???因?yàn)門(mén)DD了。
嘴上無(wú)毛,辦事不牢。調(diào)試除了問(wèn)題,幾位用戶首先想到的是DataMgr_Module出了問(wèn)題,肯定要找我。10次有8次是因?yàn)橛脩魶](méi)有按照事先約定的協(xié)議進(jìn)行操作引起的錯(cuò)誤。為什么?。恳?yàn)門(mén)DD了。
當(dāng)然也有T的不好的時(shí)候。一個(gè)哥們把DWORD編碼的模塊,內(nèi)部全部用int代替,因?yàn)樗哉J(rèn)不會(huì)有超過(guò)0x7FFFFFFF個(gè)數(shù)據(jù)要處理。好嘛,新的規(guī)則把編碼的首位置1,0區(qū)分兩類不同數(shù)據(jù),每次操作全是失敗。上層模塊(DataMgr_Module也是相對(duì)的上層模塊)拿著這哥們的DLL調(diào)的天昏地暗,也丈二和尚摸不著頭。沒(méi)辦法,把老兄的的代碼搞過(guò)來(lái)研究一下,原來(lái)老兄偷懶,把所有的字符串全部中轉(zhuǎn)成了int(因?yàn)闆](méi)有現(xiàn)成的字符串到雙字的轉(zhuǎn)換函數(shù)),他T到最后也沒(méi)把這個(gè)臭蟲(chóng)給T出來(lái)。Shit,害死人不抵命的啊。(于是有了上一篇瀏覽量不高的字符串轉(zhuǎn)雙字方法。)
DataMgr_Module出生,使用使得部分Module因此癱瘓,老大不得已,注釋掉了大量的代碼,最上面打上“TODO”的MsgBox,每次運(yùn)行的時(shí)候,大家都會(huì)想起我。
當(dāng)然,最后這些次生修改工作必須由我來(lái)承擔(dān)的。老大不得已,開(kāi)辟了部分原來(lái)限制訪問(wèn)代碼的拆出。不看則以,一看暈菜。老Clark的臭味綿延的如此之遠(yuǎn),上至業(yè)務(wù)模塊,下至基礎(chǔ)模塊,無(wú)一不沾腥帶臭。
有一些代碼甚至到了令人發(fā)指的地步,老大Z寫(xiě)的一個(gè)短短20行的函數(shù),為了使用方便封裝成n個(gè)宏函數(shù),并對(duì)其中的部分函數(shù)再次#define,用戶老大S為了方便,在此基礎(chǔ)上又#define了一次,不知怎么回事,老大S換了個(gè)名字又是一次#define。兩位老大在開(kāi)發(fā)理念上的分歧在這短短的幾行代碼之中體現(xiàn)的淋漓盡致。Sigh,何必呢。(注:老大S是以每日Build通過(guò)為目標(biāo),效率至上。老大Z是一完美主義者,每日Build通過(guò)是他的目標(biāo)之一,更注重Execute的代碼。兩位老大的共同點(diǎn)技術(shù)功力深厚,另外就是從未及時(shí)Meet過(guò)DeadLine。我本人更傾向于老大Z的開(kāi)發(fā)理念,不過(guò)現(xiàn)在是老大S的小弟。)
看來(lái)兩位老大都有問(wèn)題,到底以啥子為目標(biāo)呢?
看看微軟的一天
 每日構(gòu)造: daily build (mid-night)
 開(kāi)發(fā): 解決blocking bugs, 實(shí)現(xiàn)功能, check-out, code review, check-in
 測(cè)試: BVT, 使用測(cè)試用例進(jìn)行測(cè)試
 項(xiàng)目經(jīng)理/組長(zhǎng): 專家會(huì)診
我們的差距在哪?
在測(cè)試上。目前團(tuán)隊(duì)大部分成員對(duì)于測(cè)試用例的理解是:由測(cè)試組在系統(tǒng)測(cè)試的時(shí)候,按照需求說(shuō)明書(shū)寫(xiě)出的測(cè)試用例。而單元測(cè)試的測(cè)試用例幾乎就沒(méi)有。咋整?這不就是TDD解決的問(wèn)題嗎。
對(duì)于加入工程組的新模塊,開(kāi)發(fā)初期需要執(zhí)行TDD,測(cè)試用例,測(cè)試用例覆蓋,到什么程度呢,如果是自己寫(xiě),就寫(xiě)到自己不心虛為止吧,如果有人專門(mén)寫(xiě),那就寫(xiě)到此人自己沒(méi)有困惑為止吧。
每次Debug的代價(jià)
每次Debug,需要啟動(dòng)一次HostProgram,加載所有模塊。鼠標(biāo)點(diǎn)點(diǎn),鍵盤(pán)按按,才走到自己想要的斷點(diǎn)。每次這么搞,都感覺(jué)自己傻瓜一樣。自動(dòng)化測(cè)試測(cè)到哪,我現(xiàn)在的能力只能做沒(méi)有界面的單元測(cè)試。界面測(cè)試已經(jīng)提了需求,等著老大們開(kāi)講。
對(duì)隊(duì)友離開(kāi)的恐懼:
我有時(shí)候會(huì)突然冒出這樣的念頭:如果oy,或者xa離開(kāi)了,我們?cè)趺崔k?項(xiàng)目會(huì)不會(huì)因此而停掉。結(jié)論是:項(xiàng)目是不會(huì)停掉的,因?yàn)槲覀冊(cè)谝粋€(gè)大艦隊(duì)中,一個(gè)小舢板部分水手的離開(kāi),老大不會(huì)坐視,新的水手稍后就到。但,進(jìn)一步的進(jìn)展是舉步維艱的。大量沒(méi)有注釋的代碼,足以讓每一個(gè)新成員崩潰。沒(méi)有注釋的代碼,是隊(duì)員變得不可或缺,人是安全的。這只是我以最壞的惡意來(lái)揣測(cè)不注釋代碼的作者?;蛟S是趕時(shí)間吧,之前幾個(gè)版本的發(fā)布都顯得很精彩,不過(guò)軟件的內(nèi)部都是一鍋鹵煮火燒。這種看起來(lái)很美,會(huì)在用戶的手里土崩瓦解。如果是這樣的話,我們因此被團(tuán)隊(duì)拋棄,都不會(huì)再有團(tuán)隊(duì)來(lái)接納。在此之前,還是T自己狠一點(diǎn)吧。

評(píng)論:
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-12 13:57 | <a href=http://minidx.com>minidxer</a>
這樣的項(xiàng)目,做起來(lái)要累死人了……  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-12 16:26 | LOGOS
這樣的情形,可以試試《修改代碼的藝術(shù)》(《Working Effectively with Legacy Code》)里面介紹的東西,應(yīng)該會(huì)有幫助。
祝你好運(yùn)  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-12 21:35 | K120
一個(gè)模塊10.9k行的代碼,這個(gè)模塊劃分的也夠大了。
“大量沒(méi)有注釋的代碼,足以讓每一個(gè)新成員崩潰”??鋸埩税?。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-12 21:45 | K120
不好意思,說(shuō)錯(cuò)話了,我自己一個(gè)模塊的代碼也有11個(gè)CPP文件,平均每個(gè)文件超過(guò)600行,大致也在6.5K行代碼,還沒(méi)完成呢  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-13 08:33 | 小笨象
這時(shí)候,注釋是很重要的了。
我自己寫(xiě)的程序,怎么也有10萬(wàn)行了。不敢忘了寫(xiě)注釋,怕自己轉(zhuǎn)頭就忘了。
還好,我公司寫(xiě)的程序,注釋還多,接手的人基本上不問(wèn)我怎么做的,看注釋就行了。嗯。。。??赡苁且?yàn)槿思衣斆靼?。。。。?nbsp; 回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-13 14:04 | 西門(mén)有悔
暈哦.我一同事寫(xiě)了一個(gè)模塊,6K多代碼,沒(méi)有一行注釋,而且通篇是:
testID, devicenumber,Int? Long? Unsigned Long?....

我直接暈倒了.這樣下去真的會(huì)死人的  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-13 15:14 | eXile
http://www.javaeye.com/topic/6294
關(guān)于文檔和注釋的討論  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-13 15:17 | eXile
http://www.javaeye.com/topic/5876
關(guān)于文檔和注釋的討論  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-14 08:31 | 創(chuàng)建更好的解決方案
@LOGOS
書(shū)中講的大都是以有測(cè)試的系統(tǒng)為前提,但是以前老前輩們寫(xiě)的程序,連注釋都少的可憐,基本上不考慮封裝,改起來(lái)真是痛苦啊!

  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-14 08:33 | 創(chuàng)建更好的解決方案
@小笨象
我剛工作半年多點(diǎn),代碼寫(xiě)的少了一些。到了10萬(wàn)行的時(shí)候,或許會(huì)提高一下層次。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-14 12:17 | 創(chuàng)建更好的解決方案
@&lt;a href=http://minidx.com&gt;minidxer&lt;/a&gt;
你可是我見(jiàn)過(guò)的最細(xì)心的管理員啊,呵呵
  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-14 16:18 | LOGOS
@創(chuàng)建更好的解決方案
書(shū)里面講的是以無(wú)測(cè)試的系統(tǒng)為前提的,和你理解的不太一樣  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-14 19:15 | 小笨象
寫(xiě)代碼,經(jīng)驗(yàn)是很重要的。
多寫(xiě),多看,注釋不要忘。這就足夠了。
慢慢的你就知道了。
如果有人教你,那才能提高得快。但不能事事問(wèn)人,問(wèn)就問(wèn)最強(qiáng)的。。。。。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-14 23:54 | 菌子
### 我負(fù)責(zé)的模塊,10幾年了,10k行,我都怕動(dòng)。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-15 08:01 | 創(chuàng)建更好的解決方案
@菌子
好的模塊你動(dòng)它干嘛?
有臭味的模塊,不動(dòng),留它干嘛?  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-15 14:04 | 菌子
額。。 如果這個(gè)代碼已經(jīng)在十年間添加和修改了無(wú)數(shù)次,充滿了臭味,但是仍然良好的工作。 其中很多定義,用法你根本不知道原因, 你如何修改它?   回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-15 22:01 | 創(chuàng)建更好的解決方案
@菌子
那要看你對(duì)代碼的要求了。
代碼能工作,沒(méi)錯(cuò)。
但是這是基本的要求,可擴(kuò)展性、可移植性、可測(cè)試性也要考慮啊。
這些指標(biāo)在團(tuán)隊(duì)中尤為重要。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-17 11:49 | 小四
個(gè)人感覺(jué)10K行的代碼,下決心花力氣還是可以讀通的。再多了,就很是觸霉頭。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-21 22:51 | abettor
早就發(fā)現(xiàn),注釋是一種美德。
所幸,自己天良未泯,好歹有1/10的注釋。

我的Team里其他一些兄弟相比之下就殘忍了一些。有為老兄,一個(gè)函數(shù)寫(xiě)了1798行,沒(méi)有任何注釋,局部變量沒(méi)有任何語(yǔ)義,都是“h”、“f”之類。后來(lái),他走了,留下的幾個(gè)人哭了。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-22 13:53 | 歲月流冰
我現(xiàn)在工作的模塊有35個(gè)cpp文件,n個(gè)h文件,cpp文件幾乎每個(gè)都在8k行以上,而且注釋極少。很郁悶。  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-22 17:29 | 創(chuàng)建更好的解決方案
@歲月流冰
呵呵,8k行是不是太重量了些。
我看到2k行以上的代碼都會(huì)心有戚戚焉。
所以都控制在2k以內(nèi)吧(或許我們的項(xiàng)目規(guī)模就不夠大吧)。
  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2008-01-22 17:33 | 創(chuàng)建更好的解決方案
@abettor
割了吧,都燒焦了。
  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng)[未登錄](méi) 2008-01-25 15:31 | 汪江濤
臭味?吐啊吐的就習(xí)慣了  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2009-05-26 17:46 | zsggsz
團(tuán)隊(duì)規(guī)則:沒(méi)有注釋代碼的人就主動(dòng)離開(kāi)!  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2010-08-06 13:32 | stepinto
@K120
我現(xiàn)在維護(hù)的代碼,300多k,至少4,5個(gè)cpp都是在15000行左右的,基本沒(méi)有注釋,大量的Duplicated code,Long method,Large class  回復(fù)  更多評(píng)論
  
# re: 我和充斥臭味代碼的戰(zhàn)爭(zhēng) 2010-08-06 13:33 | stepinto
這絕對(duì)是項(xiàng)目管理問(wèn)題@abettor
  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美极品一区二区三区| 久久综合福利| 国产美女精品免费电影| 欧美激情日韩| 欧美日韩在线综合| 欧美日一区二区三区在线观看国产免| 欧美激情一区二区三级高清视频| 欧美成人日本| 欧美视频在线一区二区三区| 国产精品大片wwwwww| 国产精品女人毛片| 亚洲第一网站免费视频| 亚洲精品偷拍| 午夜精品一区二区三区四区| 欧美在线视频a| 欧美丰满少妇xxxbbb| 亚洲精品久久久久| 中文网丁香综合网| 久久爱www久久做| 欧美黄色一区二区| 国产伦精品一区二区三区视频孕妇 | 99精品欧美一区二区蜜桃免费| 亚洲一级黄色av| 久久婷婷久久一区二区三区| 欧美日产一区二区三区在线观看| 国产一区二区成人久久免费影院| 亚洲精品孕妇| 蜜月aⅴ免费一区二区三区| 亚洲高清视频在线| 亚洲欧美精品中文字幕在线| 久久久久亚洲综合| 欧美性片在线观看| 亚洲国产精品一区二区第四页av| 亚洲欧美成人网| 91久久久久久久久| 久久久人人人| 国产欧美一区二区三区沐欲 | 牛牛影视久久网| 一区二区三区视频在线看| 欧美国产视频一区二区| 欧美日本韩国| 18成人免费观看视频| 亚洲免费综合| 亚洲第一综合天堂另类专| 亚洲午夜国产成人av电影男同| 久久久久久9999| 国产精品亚洲美女av网站| 亚洲人成人一区二区三区| 久久精品国产免费观看| 夜夜爽www精品| 欧美精品激情在线| 亚洲国产乱码最新视频| 久久久久久网址| 欧美一区二视频| 国产伦精品一区二区三区视频孕妇 | 一本久道久久久| 免播放器亚洲| 久久久久久91香蕉国产| 国产亚洲精品7777| 欧美一级二区| 亚洲资源在线观看| 国产精品每日更新在线播放网址| 一区二区三区成人| 亚洲免费成人av| 欧美日韩在线精品| 亚洲一区二区三区视频播放| 日韩一级黄色av| 国产精品国内视频| 欧美综合77777色婷婷| 亚洲专区在线视频| 国产日韩欧美综合在线| 久久精品日韩欧美| 久久青草福利网站| 亚洲国产综合在线| 亚洲国产高清在线| 欧美视频成人| 欧美一区二区三区在线观看视频 | 国产精品99久久久久久白浆小说| 欧美日韩免费观看一区=区三区| 亚洲美女91| 亚洲视频网站在线观看| 国产精品欧美日韩久久| 久久国产高清| 老巨人导航500精品| 亚洲精品美女在线| 一本一道久久综合狠狠老精东影业| 久久久久久综合| 亚洲国产精品久久人人爱蜜臀 | 免费观看日韩av| 欧美freesex8一10精品| 99国产精品国产精品久久| 亚洲一二三区视频在线观看| 国产亚洲午夜| 91久久精品一区| 国产精品美女久久福利网站| 久久久99免费视频| 欧美韩国日本一区| 欧美怡红院视频一区二区三区| 久久久久国产精品一区二区| 日韩午夜三级在线| 欧美一区二区播放| 亚洲乱码国产乱码精品精可以看| 亚洲午夜免费视频| 亚洲国产精品久久久久婷婷884| 在线视频欧美精品| 亚洲激情在线激情| 亚洲午夜在线视频| 亚洲人成网站精品片在线观看| 亚洲午夜精品一区二区三区他趣 | 国产精品夫妻自拍| 欧美91大片| 国产欧美日韩专区发布| 亚洲成在人线av| 国产手机视频一区二区| 91久久精品久久国产性色也91 | 一区二区精品| 久久久久九九九九| 欧美在线视频播放| 欧美手机在线| 亚洲国产天堂久久综合| 国产在线观看一区| 亚洲一区精品在线| 99精品视频一区| 另类图片国产| 久久综合精品国产一区二区三区| 国产精品毛片| 夜夜嗨av一区二区三区网页| 亚洲人成欧美中文字幕| 久久九九99视频| 久久久999精品| 国产亚洲二区| 午夜精品久久久久久99热软件| 一区二区三区日韩欧美| 欧美电影免费观看高清完整版| 久久米奇亚洲| 国产亚洲亚洲| 久久经典综合| 久久久久www| 国产在线视频欧美| 性久久久久久| 美女国内精品自产拍在线播放| 国产色产综合产在线视频| 亚洲小说春色综合另类电影| 午夜精品久久久久久久蜜桃app| 欧美午夜精品久久久久久久| 日韩西西人体444www| 亚洲免费人成在线视频观看| 亚洲第一主播视频| 欧美在线视频日韩| 久久久91精品国产一区二区三区| 国产日韩精品视频一区| 亚洲夜间福利| 久久久91精品国产| 在线国产亚洲欧美| 欧美成人免费小视频| 亚洲日本aⅴ片在线观看香蕉| 中文日韩欧美| 国产欧美日韩一区二区三区在线观看 | 一区二区三区不卡视频在线观看| 欧美精品久久久久a| 亚洲精品日韩激情在线电影 | 国产精品自拍网站| 久久www成人_看片免费不卡| 久久免费视频在线观看| 1204国产成人精品视频| 欧美人妖另类| 亚洲在线视频免费观看| 久久全球大尺度高清视频| 亚洲国产精品久久久久秋霞影院| 欧美精品www在线观看| 亚洲婷婷综合久久一本伊一区| 久久久av网站| 日韩五码在线| 国产日韩欧美在线| 欧美aaa级| 欧美一级久久久久久久大片| 欧美**人妖| 欧美亚洲综合网| 亚洲另类在线视频| 国外成人在线| 国产精品久久二区二区| 久久精品视频免费观看| 亚洲精品一线二线三线无人区| 欧美一区观看| 日韩亚洲一区二区| 国产婷婷色综合av蜜臀av | 国产亚洲精品aa| 欧美日韩精品久久久| 久久精品视频一| 亚洲性夜色噜噜噜7777| 亚洲国产老妈| 久久夜色精品国产噜噜av| 亚洲视频免费观看| 亚洲激情成人| 黑人极品videos精品欧美裸| 欧美日韩在线精品| 欧美经典一区二区三区| 久久综合九色九九| 欧美一区二区三区男人的天堂| 99ri日韩精品视频|