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

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

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

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

硬件工程師要知道的10個(gè)C語(yǔ)言技巧

Q4MP_gh_c472c21 ? 來(lái)源:嵌入式ARM ? 作者:嵌入式ARM ? 2022-04-08 09:38 ? 次閱讀

硬件設(shè)計(jì)師最常見(jiàn)的工作內(nèi)容,就是通過(guò)寫(xiě)代碼來(lái)測(cè)試硬件。這10個(gè)C語(yǔ)言技巧(C語(yǔ)言仍然是常見(jiàn)的選擇)可以幫助設(shè)計(jì)師避免因基礎(chǔ)性錯(cuò)誤而導(dǎo)致某些缺陷的產(chǎn)生,并造成維護(hù)方面的困擾。

為了成功的推出一個(gè)產(chǎn)品,軟件開(kāi)發(fā)過(guò)程本身需要經(jīng)歷無(wú)數(shù)的實(shí)踐風(fēng)險(xiǎn)和障礙。任何工程師最不希望的事情就是因所使用語(yǔ)言或工具而帶來(lái)的挑戰(zhàn)。因此,這就需要硬件設(shè)計(jì)師編寫(xiě)代碼來(lái)測(cè)試硬件的工作狀況,在資源受限的情況下,還需要開(kāi)發(fā)硬件和嵌入式軟件。盡管工具和結(jié)構(gòu)化編程已經(jīng)有了很大進(jìn)展,但通常選擇的仍然是C語(yǔ)言,基礎(chǔ)性錯(cuò)誤的不斷發(fā)生,仍會(huì)導(dǎo)致某些缺陷的產(chǎn)生并造成維護(hù)方面的困擾。為竭力避免這些C編程陷阱,這里有10個(gè)C語(yǔ)言技巧供硬件工程師參考。

技巧1:不要使用“GOTO”語(yǔ)句

二十幾年前,當(dāng)計(jì)算機(jī)編程尚處于起步階段時(shí),程序流程是由“GOTO”語(yǔ)句來(lái)控制。該類(lèi)語(yǔ)句允許程序員對(duì)當(dāng)前代碼行斷行,而直接進(jìn)入另一個(gè)不同的代碼段。列表1為簡(jiǎn)單的示例。

列表1 使用GOTO語(yǔ)句

419a2afe-b6ba-11ec-aa7f-dac502259ad0.png

編程語(yǔ)言終究開(kāi)始引入了函數(shù)的概念,即允許程序?qū)Υa進(jìn)行斷行。如果已經(jīng)完成,不再使用goto語(yǔ)句來(lái)表示代碼的斷行。函數(shù)調(diào)用后,函數(shù)將回到下一條指令。列表2為示例。這一做法改善了程序結(jié)構(gòu),提高了可讀性。自此,這被視為編寫(xiě)程序的正確方法。只要看到或想到goto語(yǔ)句,就會(huì)讓軟件工程師退縮,產(chǎn)生本能的厭惡。其中一個(gè)主要的原因是,一個(gè)遍布goto語(yǔ)句的程序會(huì)讓讓人很難抓住重心,不便于對(duì)程序的理解和維護(hù)。

列表2 用函數(shù)控制流程

41b8af24-b6ba-11ec-aa7f-dac502259ad0.png

技巧2:使用FOR(;;)或While(1)

如果goto語(yǔ)句已經(jīng)過(guò)時(shí),那么對(duì)程序創(chuàng)建無(wú)限循環(huán)應(yīng)該如何去做呢,這是一些硬件工程師可能會(huì)疑惑的問(wèn)題。畢竟,之前都是通過(guò)創(chuàng)建一個(gè)goto語(yǔ)句然后再返回到main語(yǔ)句。解決這一問(wèn)題就要利用C語(yǔ)言中已經(jīng)存在的循環(huán)語(yǔ)句for和while(列表3和4)。

列表3 使用一個(gè)無(wú)限的For循環(huán)

41c86b12-b6ba-11ec-aa7f-dac502259ad0.jpg

列表4 使用一個(gè)無(wú)限的While循環(huán)

41dedbd6-b6ba-11ec-aa7f-dac502259ad0.png

列表中的循環(huán)條件相對(duì)比較簡(jiǎn)單。for循環(huán)無(wú)非是以無(wú)條件情況使用條件語(yǔ)句。而另一方面,while循環(huán)是語(yǔ)句為真即予執(zhí)行,這等同對(duì)任何條件的非零值。

技巧3:使用合適的條件語(yǔ)句

除代碼的可讀性之外,程序的執(zhí)行時(shí)間還主要依賴(lài)于做決定時(shí)所選擇的條件結(jié)構(gòu)類(lèi)型。許多硬件工程師都熟悉簡(jiǎn)單的if語(yǔ)句的使用。然而,有時(shí)工程師可能沒(méi)有意識(shí)到,如果第一個(gè)條件不正確,還可以使用else或else if語(yǔ)句。這可以節(jié)省處理器時(shí)間,而不必評(píng)估另一個(gè)條件語(yǔ)句。在列表5所示的前半部分代碼中,如果Var值為1,則代碼仍會(huì)查看Var是否為0。而在用了else語(yǔ)句的后半部分代碼中,只評(píng)估第一個(gè)語(yǔ)句,之后就繼續(xù)走下面的代碼,這樣就節(jié)省了時(shí)鐘周期,使代碼更加清晰。

列表5 用If/Else替代只用If

41f3846e-b6ba-11ec-aa7f-dac502259ad0.jpg

If/else if/else語(yǔ)句可能并不永遠(yuǎn)適用。如果需要檢查若干個(gè)可能的條件,switch語(yǔ)句可能更合適。這樣,處理器可以評(píng)估語(yǔ)句,然后從一個(gè)答案列表中選擇下一步動(dòng)作,而不用連續(xù)地評(píng)估一堆條件。列表6顯示的例子與列表5示例的類(lèi)型相同。

列表6 使用Switch語(yǔ)句

420550f4-b6ba-11ec-aa7f-dac502259ad0.jpg

以上示例的寓意是,讓條件語(yǔ)句的選擇更開(kāi)放,以選擇出最適合的語(yǔ)句。這種做法使程序結(jié)構(gòu)更簡(jiǎn)單,便于理解程序流程,縮短處理器的額外時(shí)鐘周期。

技巧4:避免使用匯編語(yǔ)言

微處理器的自然語(yǔ)言為匯編語(yǔ)言指令。為低級(jí)別機(jī)器語(yǔ)言編程可能會(huì)為處理器提供更高效的代碼。然而,人類(lèi)并不是天生就會(huì)這種語(yǔ)言,并且經(jīng)驗(yàn)表明,編寫(xiě)匯編語(yǔ)言會(huì)造成誤解。誤解會(huì)導(dǎo)致維護(hù)不當(dāng),更甚者,可能會(huì)使系統(tǒng)到處是bug.一般建議避免使用匯編語(yǔ)言。

實(shí)際上,現(xiàn)在大多數(shù)編譯器都能編譯出非常高效的代碼。采用C語(yǔ)言或C++語(yǔ)言等高級(jí)語(yǔ)言的開(kāi)發(fā),能獲得更有序的結(jié)構(gòu),便于理解和維護(hù),使代碼的整體效果更好。列表7給出了一個(gè)示例,比較了使一個(gè)32位變量遞增所使用的匯編代碼和C語(yǔ)言代碼。

列表7 用匯編和C語(yǔ)言完成一個(gè)變量的遞增

匯編

C代碼

421547b6-b6ba-11ec-aa7f-dac502259ad0.jpg

當(dāng)然,現(xiàn)在仍有一些場(chǎng)合適于使用匯編語(yǔ)言,但這種場(chǎng)合仍比較少。首個(gè)推薦的場(chǎng)合是開(kāi)發(fā)引導(dǎo)裝載程序。這種情況下,可能需要優(yōu)化對(duì)啟動(dòng)過(guò)程中某個(gè)決策(啟動(dòng)應(yīng)用或引導(dǎo)加載器)的速度。此時(shí),分支判定用匯編代碼就可能有意義了。

另一種場(chǎng)合是開(kāi)發(fā)一種在DSP上運(yùn)行有嚴(yán)格時(shí)序要求的控制循環(huán)。為了從設(shè)備中的得到每個(gè)時(shí)鐘周期,用匯編語(yǔ)言做控制循環(huán)的編碼是有意義的。如果目前任務(wù)適合用匯編,應(yīng)確保將其妥善存檔便于有據(jù)可查,這樣,未來(lái)的開(kāi)發(fā)者(或未來(lái)的版本)會(huì)明白該代碼的用途。

技巧5:充分利用模塊化

筆者最常見(jiàn)的經(jīng)歷是著手由硬件工程師開(kāi)啟的一個(gè)新項(xiàng)目往往是雜亂無(wú)章的代碼組織。通常我們會(huì)發(fā)現(xiàn),代碼由一個(gè)單一的主模塊組成,其中有2.5萬(wàn)多行代碼。在這些應(yīng)用中,一切都是全局性的,函數(shù)寥寥無(wú)幾,goto語(yǔ)句貫穿整個(gè)代碼結(jié)構(gòu)。15年前這算正常,但如今已不再適用了!

C語(yǔ)言編程使工程師能夠?qū)⒋a分成獨(dú)立的功能模塊,這簡(jiǎn)化了代碼導(dǎo)航,同時(shí)還能夠使工程師使用封裝等面向?qū)ο蠹夹g(shù)。代碼可以被組織成邏輯模塊,這很有意義。雖然可能要先花點(diǎn)時(shí)間(幾分鐘),但從長(zhǎng)遠(yuǎn)來(lái)看,這將能省掉很多漫長(zhǎng)之夜,和很多調(diào)試之苦!

技巧6:寫(xiě)千層餅式代碼而非面條式代碼

Beningo是一個(gè)意大利名字,和許多意大利人一樣,我對(duì)意大利面食也是毫無(wú)保留地?zé)釔?ài)。當(dāng)拿意大利面食與軟件相比時(shí),我就會(huì)想到兩種面食,即意大利面條和千層餅。意大利面條比較混亂,面條相互交織,縱橫交錯(cuò),結(jié)果完全沒(méi)有任何類(lèi)型的結(jié)構(gòu)。編寫(xiě)非結(jié)構(gòu)化代碼就非常像意大利面條:咬一口,完全不知道吃的是哪部分。

另一種就是意大利千層餅!這種面食是分層的,是有結(jié)構(gòu)的。分層開(kāi)發(fā)的代碼不僅更容易理解,還可以移走一層并添加一個(gè)新層,基本上能夠?qū)崿F(xiàn)重復(fù)使用和維護(hù)的簡(jiǎn)易性。圖1為用千層餅式代碼模型的一個(gè)簡(jiǎn)單軟件模塊示例。

422adcde-b6ba-11ec-aa7f-dac502259ad0.jpg

圖1 千層餅軟件模型

驅(qū)動(dòng)程序配置

應(yīng)用程序配置

應(yīng)用程序

驅(qū)動(dòng)程序庫(kù)

硬件

技巧7:使用描述式變量名稱(chēng)

編寫(xiě)易于理解和維護(hù)的較大軟件有許多障礙,其中之一就是變量的命名習(xí)慣。為了盡力縮短變量名,開(kāi)發(fā)者通常會(huì)自創(chuàng)一些較短的、令人費(fèi)解的助記符,往往只有他們自己才能明白的符號(hào)。現(xiàn)代語(yǔ)言使一個(gè)變量名可以包含數(shù)百個(gè)字符。為了讓事情清晰明確,“直截了當(dāng)”地方法要好于其它方式。因此,變量名一目了然不僅有利于開(kāi)發(fā)人員,也有利于未來(lái)的維護(hù)團(tuán)隊(duì)。列表8給出一個(gè)示例。

列表8 變量的命名

42447dba-b6ba-11ec-aa7f-dac502259ad0.png

技巧8:少用#pragma語(yǔ)句

C語(yǔ)言中有一種特殊的#pragma語(yǔ)句。這些語(yǔ)句通常處理非標(biāo)準(zhǔn)的句法和特性,應(yīng)盡可能避免使用這種語(yǔ)句,因?yàn)樗鼈兪欠菢?biāo)準(zhǔn)的,不能從一個(gè)處理器移植到另一個(gè)處理器。有些編譯器可能要求用這類(lèi)語(yǔ)句完成某項(xiàng)任務(wù),例如定義一個(gè)中斷服務(wù)程序。

在這種情況下,可能除了使用#pragma語(yǔ)句以外別無(wú)它法。如果可能,將所有的#pragma語(yǔ)句放在一個(gè)模塊或幾個(gè)模塊里。這有助于確保在代碼移植時(shí),只需要更新幾處代碼,而非整個(gè)代碼庫(kù)。此外,這也將有助于防止移植代碼的首次編譯所帶來(lái)的困擾。

技巧9:錯(cuò)誤往往并不是看上去那樣簡(jiǎn)單

在調(diào)試一個(gè)C程序時(shí),有一個(gè)讓人當(dāng)心的陷阱就是編譯器錯(cuò)誤。由于編譯器的復(fù)雜性,當(dāng)檢測(cè)到一個(gè)錯(cuò)誤時(shí),通常錯(cuò)誤位于程序中的其它地方,而非編譯器所指示的位置。這主要與編譯器生成程序的步驟有關(guān)。錯(cuò)誤類(lèi)型通常是一致的,工程師可以發(fā)現(xiàn)的一些錯(cuò)誤中,90%都是根源:

*當(dāng)心漏掉#include文件。這可能會(huì)使程序開(kāi)發(fā)人員看到完美的代碼行,但由于未包含必要的頭文件,編譯器便會(huì)將其標(biāo)志為一個(gè)錯(cuò)誤,表示有些東西未定義。

*當(dāng)心漏掉分號(hào)。編寫(xiě)C代碼時(shí)最常見(jiàn)的錯(cuò)誤是忘記在句末加分號(hào)。

*當(dāng)心漏掉括號(hào)。漏寫(xiě)括號(hào)是代碼編寫(xiě)過(guò)程中又一常犯的錯(cuò)誤,或是粗心漏掉,或是由于鍵入錯(cuò)誤而產(chǎn)生一個(gè)錯(cuò)誤字符。

*當(dāng)心漏掉逗號(hào)。在復(fù)雜的定義中很容易忘記逗號(hào)!

一般情況下,當(dāng)彈出一個(gè)奇怪的編譯錯(cuò)誤對(duì)話(huà)框時(shí),要查看該行前已被編譯的內(nèi)容。很有可能就是錯(cuò)誤所在!它可能是出現(xiàn)在一行上面,或中間部分,或在完全不同的文件里。

不要放棄!只要具備一定的經(jīng)驗(yàn),解決這些疑難問(wèn)題就會(huì)成為一種第二天性。

技巧10:優(yōu)秀的程序員編寫(xiě)的代碼行數(shù)不一定少

人們常有這種誤解,即認(rèn)為較一般的程序員而言,一個(gè)優(yōu)秀的程序員往往寫(xiě)較少的代碼行就能解決問(wèn)題。不要卷入這一錯(cuò)誤的想法!一個(gè)優(yōu)秀的程序員通常具備思維縝密、結(jié)構(gòu)清晰的編碼基礎(chǔ)。變量命名和封裝都恰如其分,系統(tǒng)中幾乎不用全局變量。函數(shù)應(yīng)保持簡(jiǎn)短有效。如果代碼看起來(lái)很混亂,需要多寫(xiě)幾行才能使其看上去更清晰,那就不妨多寫(xiě)幾行!可以上網(wǎng)查看獲得C代碼編寫(xiě)最混亂殊榮獎(jiǎng)項(xiàng)的代碼用作前車(chē)之鑒。優(yōu)秀程序員寫(xiě)的代碼簡(jiǎn)潔、易于理解和維護(hù),代碼行數(shù)并非最少(圖2)!

4257d0cc-b6ba-11ec-aa7f-dac502259ad0.jpg

圖2 簡(jiǎn)短程序

END

審核編輯 :李倩

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

    關(guān)注

    180

    文章

    7610

    瀏覽量

    137231
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3631

    瀏覽量

    93841

原文標(biāo)題:硬件工程師必知的10個(gè)C語(yǔ)言技巧

文章出處:【微信號(hào):gh_c472c2199c88,微信公眾號(hào):嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    電子工程師最關(guān)心的10個(gè)問(wèn)題

    ;從硬件轉(zhuǎn)為軟件,從軟件轉(zhuǎn)為測(cè)試;電子工程師根據(jù)實(shí)際的情況和個(gè)人的興趣愛(ài)好,看中時(shí)機(jī)轉(zhuǎn)行說(shuō)不定發(fā)現(xiàn)另一個(gè)天空。10 放棄技術(shù)轉(zhuǎn)行的途徑是什么試著想想電子產(chǎn)業(yè)生態(tài)系統(tǒng)的每一
    發(fā)表于 05-18 11:49

    硬件工程師要知道的8個(gè)設(shè)計(jì)技巧

    個(gè)軟件設(shè)計(jì)技巧。 1.設(shè)計(jì)控制流程圖 工程師進(jìn)行到開(kāi)發(fā)軟件這一步時(shí)會(huì)情不自禁地開(kāi)始書(shū)寫(xiě)代碼。這種思維定勢(shì)就像在原理圖還未完成之前就開(kāi)始嘗試畫(huà)PCB。當(dāng)著手開(kāi)發(fā)軟件時(shí),克制寫(xiě)代碼的沖動(dòng),取而代之
    發(fā)表于 05-30 17:30

    [轉(zhuǎn)帖]硬件工程師10個(gè)C語(yǔ)言技巧

    。盡管工具和結(jié)構(gòu)化編程已經(jīng)有了很大進(jìn)展,但通常選擇的仍然是C語(yǔ)言,基礎(chǔ)性錯(cuò)誤的不斷發(fā)生,仍會(huì)導(dǎo)致某些缺陷的產(chǎn)生并造成維護(hù)方面的困擾。為竭力避免這些C編程陷阱,這里有10
    發(fā)表于 06-09 14:44

    關(guān)于硬件工程師的真相:這行真的不行嗎,敢問(wèn)路在何方?

    、完善,因?yàn)?b class='flag-5'>硬件工程師需要的只是紛繁復(fù)雜。三、實(shí)例講解1.技術(shù)上學(xué)習(xí)以做藍(lán)牙為例: 你需要知道天線(xiàn)的設(shè)計(jì),你需要知道饋線(xiàn)的設(shè)計(jì),最后到阻抗匹配、矢量分析儀的使用。所有的每一
    發(fā)表于 12-16 11:13

    硬件工程師要知道的DFM可制造性設(shè)計(jì)

    的設(shè)計(jì)隱患流入到生產(chǎn)端,最終導(dǎo)致生產(chǎn)制造困難。說(shuō)說(shuō)我與可制造性設(shè)計(jì)的三個(gè)小故事吧!故事一 · 大公司的經(jīng)歷剛畢業(yè)的時(shí)候進(jìn)入了大公司,成為一名硬件工程師。公司有Layout工程師
    發(fā)表于 05-31 13:15

    【重磅】一個(gè)高薪硬件工程師應(yīng)具備的能力

    最大?比如醫(yī)療電子,汽車(chē)電子,芯片原廠(chǎng)類(lèi),消費(fèi)類(lèi)電子,電源,射頻等行業(yè)。2.電子硬件工程師,是否需要掌握一點(diǎn)基礎(chǔ)的軟件知識(shí),例如C語(yǔ)言,java等等。3.做
    發(fā)表于 03-05 10:51

    硬件工程師要知道的DFM可制造性設(shè)計(jì)

    最近,有硬件工程師朋友找我討論DFM,也就是可制造性設(shè)計(jì)。Design for Manufacturability。什么是可制造性設(shè)計(jì),看一張圖很容易明白:過(guò)大的PCB,無(wú)法上產(chǎn)線(xiàn)批量生產(chǎn),極大
    發(fā)表于 04-17 11:09

    硬件工程師10個(gè)C語(yǔ)言技巧

    硬件工程師10個(gè)C語(yǔ)言技巧,感興趣的小伙伴們可以看看。
    發(fā)表于 07-26 10:43 ?102次下載

    硬件工程師應(yīng)該知道的音頻功放電路

    作為硬件工程師,特別是做純粹模擬電路、應(yīng)用于音頻功放的工程師,對(duì)于A類(lèi),B類(lèi),AB類(lèi),D類(lèi),G類(lèi),H類(lèi),T類(lèi)功放應(yīng)該特別熟悉。大多數(shù)工程師或許只知道
    發(fā)表于 11-27 14:58 ?51次下載

    10個(gè)C語(yǔ)言技巧供硬件工程師參考

    除代碼的可讀性之外,程序的執(zhí)行時(shí)間還主要依賴(lài)于做決定時(shí)所選擇的條件結(jié)構(gòu)類(lèi)型。許多硬件工程師都熟悉簡(jiǎn)單的if語(yǔ)句的使用。然而,有時(shí)工程師可能沒(méi)有意識(shí)到,如果第一個(gè)條件不正確,還可以使用e
    的頭像 發(fā)表于 06-03 09:21 ?6184次閱讀
    <b class='flag-5'>10</b><b class='flag-5'>個(gè)</b><b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>技巧供<b class='flag-5'>硬件</b><b class='flag-5'>工程師</b>參考

    工程師要知道的軟件+通用硬件優(yōu)勢(shì)

    工程師要知道的軟件+通用硬件優(yōu)勢(shì) 1. 費(fèi)用:相對(duì)于專(zhuān)用ASIC動(dòng)輒幾百萬(wàn)上千萬(wàn)美元的開(kāi)發(fā)費(fèi)用,一個(gè)軟件 + 通用硬件平臺(tái)的前期開(kāi)發(fā)費(fèi)用也
    的頭像 發(fā)表于 04-27 11:50 ?3655次閱讀

    工程師該避免的10個(gè)C語(yǔ)言陷阱資料下載

    電子發(fā)燒友網(wǎng)為你提供工程師該避免的10個(gè)C語(yǔ)言陷阱資料下載的電子資料下載,更有其他相關(guān)的電路圖、源代碼、課件教程、中文資料、英文資料、參考設(shè)
    發(fā)表于 04-19 08:41 ?2次下載
    <b class='flag-5'>工程師</b>該避免的<b class='flag-5'>10</b><b class='flag-5'>個(gè)</b><b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>陷阱資料下載

    硬件工程師必知的10個(gè)C語(yǔ)言技巧

    硬件設(shè)計(jì)最常見(jiàn)的工作內(nèi)容,就是通過(guò)寫(xiě)代碼來(lái)測(cè)試硬件。這10個(gè)C
    的頭像 發(fā)表于 02-23 15:35 ?1970次閱讀
    <b class='flag-5'>硬件</b><b class='flag-5'>工程師</b>必知的<b class='flag-5'>10</b><b class='flag-5'>個(gè)</b><b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>技巧

    關(guān)于C語(yǔ)言10個(gè)技巧

    硬件工程師最常見(jiàn)的工作內(nèi)容是通過(guò)寫(xiě)代碼來(lái)測(cè)試硬件。這10個(gè)C
    發(fā)表于 10-18 09:10 ?719次閱讀
    主站蜘蛛池模板: 狠狠操精品视频| 超级毛片| 亚洲第一综合| 五月天婷婷精品视频| 天天操天天干天天摸| 色淫阁色九九| 操操干干| 在线观看日本亚洲一区| 情趣店上班h系列小说| 一级特黄色片| 婷婷色婷婷| 欧美很很干| 国产福利网站| 天天舔天天射天天操| 国产在线观看福利| 亚洲一区二区三区免费在线观看 | 黄网站免费大全| 国产裸体美女视频全黄| 亚洲午夜免费| 免费永久视频| 激情综合色五月丁香六月亚洲| 美女免费视频一区二区三区| 午夜欧美成人久久久久久| 欧美色欧美亚洲高清在线视频| 国产亚洲美女| 不卡免费在线视频| 亚洲色图2| 在线免费成人网| 特级黄| 久久亚洲精品成人综合| 在线观看天堂| 国产午夜视频在线观看第四页| 亚洲综合国产一区二区三区| 亚洲国产成人久久精品图片| 男人边吃奶边做视频免费网站| 爱我免费视频观看在线www| 理论在线看| 日本aaaaa级毛片片| 色在线观看视频| 成人免费看黄页网址大全| 久久国产影视|