91网首页-91网页版-91网在线观看-91网站免费观看-91网站永久视频-91网站在线播放

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

C#程序優(yōu)化的一些建議

admin
2023年5月15日 22:1 本文熱度 1215

用屬性代替可訪問的字段

1、.NET數(shù)據(jù)綁定只支持?jǐn)?shù)據(jù)綁定,使用屬性可以獲得數(shù)據(jù)綁定的好處;
2、在屬性的get和set訪問器重可使用lock添加多線程的支持。  

readonly(運(yùn)行時(shí)常量)和const(編譯時(shí)常量)

1、const只可用于基元類型、枚舉、字符串,而readonly則可以是任何的類型;
2、const在編譯時(shí)將替換成具體的常量,這樣如果在引用中同時(shí)使用了const和readonly兩種值,則對readonly的再次改變將會(huì)改變設(shè)計(jì)的初衷,這是需要重新編譯所更改的程序集,以重新引用新的常量值。
3、const比readonly效率高,但失去了應(yīng)用的靈活性。  

is與as

1、兩者都是在運(yùn)行時(shí)進(jìn)行類型的轉(zhuǎn)換,as操作符只能使用在引用類型,而is可以使用值和引用類型;
2、通常的做法是用is判斷類型,然后選擇使用as或強(qiáng)類型轉(zhuǎn)換操作符(用operater定義的轉(zhuǎn)換)有選擇地進(jìn)行。  

ConditionalAttribute代替#if #endif條件編譯

1、ConditionalAttribute只用于方法級,對其他的如類型、屬性等的添加都是無效的;而#if #endif則不受此限制;
2、ConditionalAttribute可以添加多個(gè)編譯條件的或(OR)操作,而#if #endif則可以添加與(AND)[這里可以完全定義為另一個(gè)單獨(dú)的符號];
3、ConditioanlAttribute定義可以放在一個(gè)單獨(dú)的方法中,使得程序更為靈活。  

提供ToString()方法

1、可以更友好的方式提供用戶詳細(xì)的信息;
2、使用IFormatter.ToString()方法提供更靈活的定制,如果添加IFormatProvider 和ICustomFormatter接口則更有意義的定制消息輸出。  

值和引用類型的區(qū)別

1、值類型不支持多態(tài),適合存儲(chǔ)應(yīng)用程序操作的數(shù)據(jù),而引用則支持多態(tài),適用于定義應(yīng)用程序的行為;
2、對于數(shù)組定義為值類型可以顯著提高程序的性能;
3、值類型具有較少的堆內(nèi)存碎片、內(nèi)存垃圾和間接訪問時(shí)間,其在方法中的返回是以復(fù)制的方式進(jìn)行,避免暴露內(nèi)部結(jié)構(gòu)到外界;
4、值類型應(yīng)用在如下的場景中:類型的職責(zé)主要是用于數(shù)據(jù)存儲(chǔ);公共接口完全由一些數(shù)據(jù)成員存取屬性定義;永遠(yuǎn)沒有子類;永遠(yuǎn)沒有多態(tài)行為。  

值類型盡可能實(shí)現(xiàn)為常量性和原子性的類型

1、使我們的代碼更易于編寫和維護(hù);
2、初始化常量的三種策略:在構(gòu)造中;工廠方法;構(gòu)造一個(gè)可變的輔助類(如StringBuilder)。  

確保0為值得有效狀態(tài)

1、值類型的默認(rèn)狀態(tài)應(yīng)為0;
2、枚舉類型的0不應(yīng)為無效的狀態(tài);在FlagsAttribute是應(yīng)確保0值為有效地狀態(tài);
3、在字符串為為空時(shí)可以返回一個(gè)string.Empty的空字符串。  

相等判斷的多種表示關(guān)系

1、ReferenceEquals()判斷引用相等,需要兩個(gè)是引用同一個(gè)對象時(shí)方可返回true;
2、靜態(tài)的Equals()方法先進(jìn)行引用判斷,再進(jìn)行值類型判斷的;
3、對于引用類型的判斷可以在使用值語義時(shí)使用重寫Equals()方法;
4、重寫Equals()方法時(shí)也應(yīng)當(dāng)重寫GetHashCode()方法,同時(shí)提供operater==()操作。  

理解GetHashCode()方法的缺陷

1、GetHashCode()僅應(yīng)用在基于散列的**定義鍵的散列值,如HashTable或Dictionary;
2、GetHashCode()應(yīng)當(dāng)遵循相應(yīng)的三條規(guī)則:兩個(gè)相等對象應(yīng)當(dāng)返回相同的散列碼;應(yīng)當(dāng)是一個(gè)實(shí)例不變式;散列函數(shù)應(yīng)該在所有的整數(shù)中產(chǎn)生一個(gè)隨機(jī)的分布。  

優(yōu)先使用foreach循環(huán)語句

1、foreach可以消除編譯器對for循環(huán)對數(shù)組邊界的檢查;
2、foreach的循環(huán)變量是只讀的,且存在一個(gè)顯式的轉(zhuǎn)換,在對象的對象類型不正確時(shí)拋出異常;3、foreach使用的需要有:具備公有的GetEnumberator()方法;顯式實(shí)現(xiàn)了IEnumberable接口;實(shí)現(xiàn)了IEnumerator接口;
4、foreach可以帶來資源管理的好處,因?yàn)槿绻幾g器可以確定IDisposable接口時(shí),可以使用優(yōu)化的try…finally塊;  

默認(rèn)字段的初始化優(yōu)于賦值語句

1、字段生命默認(rèn)會(huì)將值類型初始化為0,引用類型初始化為null;
2、對同一個(gè)對象進(jìn)行多次初始化會(huì)降低代碼的執(zhí)行效率;
3、將字段的初始化放到構(gòu)造器中有利于進(jìn)行異常處理。  

使用靜態(tài)構(gòu)造器初始化靜態(tài)成員

1、靜態(tài)構(gòu)造器會(huì)在一個(gè)類的任何方法、變量或者屬性訪問之前執(zhí)行;
2、靜態(tài)字段同樣會(huì)在靜態(tài)構(gòu)造器之前運(yùn)行,同時(shí)靜態(tài)構(gòu)造器有利于異常處理。  

利用構(gòu)造器鏈(在.NET 4.0已經(jīng)用可選參數(shù)解決了這個(gè)問題)

1、用this將初始化工作交給另一個(gè)構(gòu)造器,用base調(diào)用基類的構(gòu)造器;
2、類型實(shí)例的操作順序是:將所有的靜態(tài)字段都設(shè)置為0;執(zhí)行靜態(tài)字段初始化器;執(zhí)行基類的靜態(tài)構(gòu)造器;執(zhí)行當(dāng)前類型的靜態(tài)構(gòu)造器;
將所有的實(shí)例字段設(shè)置為0;執(zhí)行實(shí)例字段初始化器;執(zhí)行合適的基類實(shí)例構(gòu)造器;執(zhí)行當(dāng)前類型的實(shí)例構(gòu)造器。  

利用using和try/finally語句來清理資源

在IDisposable接口的Dispose()方法中用GC.SuppressFinalize()可通知垃圾收集器不再執(zhí)行終結(jié)操作。  

盡量減少內(nèi)存垃圾

1、分配和銷毀一個(gè)堆上的對象都要花費(fèi)額外的處理器時(shí)間;
2、減少分配對象數(shù)量的技巧:經(jīng)常使用的局部變量提升為字段;提供一個(gè)類,用于存儲(chǔ)Singleton對象來表達(dá)特定類型的常用實(shí)例。
3、用StringBuilder進(jìn)行復(fù)雜的字符串操作。  

盡量減少裝箱和拆箱

1、關(guān)注一個(gè)類型到System.Object的隱式轉(zhuǎn)換,同時(shí)值類型不應(yīng)該被替換為System.Object類型;
2、使用接口而不是使用類型可以避免裝箱,即將值類型從接口實(shí)現(xiàn),然后通過接口調(diào)用成員。  

實(shí)現(xiàn)標(biāo)準(zhǔn)Dispose模式

1、使用非內(nèi)存資源,它必須有一個(gè)終結(jié)器,垃圾收集器在完成沒有終結(jié)其的內(nèi)存對象后,會(huì)將實(shí)現(xiàn)了終結(jié)器對象的添加到終結(jié)隊(duì)列中,然后垃圾收集器會(huì)啟動(dòng)一個(gè)新的線程來運(yùn)行這些對象上的終結(jié)器,這種防御性的變成方式是因?yàn)槿绻脩敉浟苏{(diào)用Dispose()方法,垃圾回收器總是會(huì)調(diào)用終結(jié)器方法的,這樣可以避免出現(xiàn)非托管的內(nèi)存資源不被釋放引起內(nèi)存泄漏的問題;
2、使用IDisposable.Dispose()方法需要做四個(gè)方面的工作:釋放所有的非托管資源;釋放所有的托管資源;設(shè)置一個(gè)狀態(tài)標(biāo)記來表示是否已經(jīng)執(zhí)行了Dispose();調(diào)用GC.SuppressFinalize(this)取消對象的終結(jié)操作;
3、為需要多態(tài)的類型添加一個(gè)受保護(hù)的虛方法Dispose(),派生類通過重寫這個(gè)方法來釋放自己的任務(wù);
4、在需要IDisoposable接口的類型中,即使我們不需要一個(gè)終結(jié)器也應(yīng)該實(shí)現(xiàn)一個(gè)終結(jié)器。  

定義并實(shí)現(xiàn)接口優(yōu)于繼承類型

1、不相關(guān)的類型可以共同實(shí)現(xiàn)一個(gè)共同的接口,而且實(shí)現(xiàn)接口比繼承更容易;
2、接口比較穩(wěn)定,他將一組功能封裝在一個(gè)接口中,作為其他類型的實(shí)現(xiàn)合同,而基類則可以隨著時(shí)間的推移進(jìn)行擴(kuò)展。  

明辨接口實(shí)現(xiàn)和虛方法重寫

1、在基類中實(shí)現(xiàn)一個(gè)接口時(shí),派生類需要使用new來隱藏對基類方法的使用;
2、可以將基類接口的方法申明為虛方法,然后再派生類中實(shí)現(xiàn)。  

使用委托表達(dá)回調(diào)

1、委托對象本身不提供任何異常捕獲,所以任何的多播委托調(diào)用都會(huì)結(jié)束整個(gè)調(diào)用鏈;
2、通過顯示調(diào)用委托鏈上的每個(gè)委托目標(biāo)可以避免多播委托僅返回最后一個(gè)委托的輸出。  

使用事件定義外部接口

1、應(yīng)當(dāng)聲明為共有的事件,讓編譯器為我們創(chuàng)建add和renmove方法;
2、使用System.ComponentModel.EventHandlerList容器來存儲(chǔ)各個(gè)事件處理器,在類型中包含大量事件時(shí)可以使用他來隱藏所有事件的復(fù)雜性。  

避免返回內(nèi)部類對象的引用

1、由于值類型對象的訪問會(huì)創(chuàng)建一個(gè)該對象的副本,所以定義一個(gè)值類型的的屬性完全不會(huì)改變類型對象內(nèi)部的狀態(tài);
2、常量類型可以避免改變對象的狀態(tài);
3、定義接口將訪問限制在一個(gè)子集中從而最小化對對象內(nèi)部狀態(tài)的破壞;
4、定義一個(gè)包裝器對象來限制另一個(gè)對象的訪問;
5、希望客戶代碼更改內(nèi)部數(shù)據(jù)元素時(shí)可以實(shí)現(xiàn)Observer模式,以使對象可以對更改進(jìn)行校驗(yàn)或相應(yīng)。  

聲明式編程優(yōu)于命令式編程

可以避免在多個(gè)類似的手工編寫的算法中犯錯(cuò)誤的可能性,并提供清晰和可讀的代碼。  

盡可能將類型實(shí)現(xiàn)為可序列化的類型

1、類型表示的不是UI控件、窗口或者表單,都應(yīng)使類型支持序列化;
2、在添加了NonSerializedAttribute的反序列化的屬性時(shí)可以通過實(shí)現(xiàn)IDeserializationCallback的OnDeserialization()方法裝入默認(rèn)值;
3、在版本控制中可以使用ISerializable接口來進(jìn)行靈活的控制,同時(shí)提供一個(gè)序列化的構(gòu)造器來根據(jù)流中的數(shù)據(jù)初始化對象,在實(shí)現(xiàn)時(shí)還要求SerializationFormatter異常的許可;
4、如果需要?jiǎng)?chuàng)建派生類則需要提供一個(gè)掛鉤方法供派生類使用。  

使用IComparable和IComparer接口實(shí)現(xiàn)排序關(guān)系

1、IComparable接口用于為類型實(shí)現(xiàn)最自然的排序關(guān)系,重載四個(gè)比較操作符,可以提供一個(gè)重載版的CompareTo()方法,讓其接受具體類型作為參數(shù);
2、IComparer用于提供有別于IComparable的排序關(guān)系,或者為我們提供類型本身說沒有實(shí)現(xiàn)的排序關(guān)系。  

避免ICloneable接口

1、對于值類型永遠(yuǎn)不需要支持ICloneable接口,使用默認(rèn)的賦值操作即可;
2、對于可能需要支持ICloneable接口的基類,應(yīng)該為其創(chuàng)造一個(gè)受保護(hù)的復(fù)制構(gòu)造器,并應(yīng)當(dāng)避免支持IConeable接口。  

避免強(qiáng)制轉(zhuǎn)換操作符

通過使用構(gòu)造器來代替轉(zhuǎn)換操作符可以使轉(zhuǎn)換工作變得更清晰,由于在轉(zhuǎn)換后使用的臨時(shí)對象,容易導(dǎo)致一些詭異的BUG。  

只有當(dāng)新版積累導(dǎo)致問題時(shí)才考慮使用new修飾符   

盡可能實(shí)現(xiàn)CLS兼容的程序集

1、創(chuàng)建一個(gè)兼容的程序集需要遵循兩條規(guī)則:程序集中所有公有和受保護(hù)成員所使用的參數(shù)和返回值類型都必須與CLS兼容;任何與CLS不兼容的公有和受保護(hù)成員都必須有一個(gè)與CLS兼容的替代品;
2、可以通過顯式實(shí)現(xiàn)接口來避開CLS兼容類型檢查,及CLSCompliantAttribute不會(huì)檢查私有的成員的CLS兼容性。  

盡可能實(shí)現(xiàn)短小簡潔的方法

1、JIT編譯器以方法為單位進(jìn)行編譯,沒有被調(diào)用的方法不會(huì)被JIT編譯;
2、如果將較長的Switch中的Case語句的代碼替換成一個(gè)一個(gè)的方法,則JIT編譯器所節(jié)省的時(shí)間將成倍增加;
3、短小精悍的方法并選擇較少的局部變量可以獲得優(yōu)化的寄存器使用;
4、方法內(nèi)的控制分支越少,JIT編譯器越容易將變量放入寄存器。  

盡可能實(shí)現(xiàn)小尺寸、高內(nèi)聚的程序集

1、將所有的公有類以及共用的基類放到一些程序集中,把為公有類提供功能的工具類也放入同樣的程序集中,把相關(guān)的公有接口打包到他們自己的程序集中,最后處理遍布應(yīng)用程序中水平位置的類;
2、原則上創(chuàng)建兩種組件:一種為小而聚合、具有某項(xiàng)特定功能的程序集,另一種為大而寬、包含共用功能的程序集。  

限制類型的可見性

1、使用接口來暴露類型的功能,可以使我們更方便地創(chuàng)建內(nèi)部類,同時(shí)又不會(huì)限制他們在程序集外的可用性;
2、向外暴露的公有類型越少,未來擴(kuò)展和更改實(shí)現(xiàn)所擁有的選擇就越多。  

創(chuàng)建大粒度的Web API

這是在機(jī)器之間的交易的頻率和載荷都降到最低,將大的操作和細(xì)粒度的執(zhí)行放到服務(wù)器執(zhí)行。  

重寫優(yōu)于事件處理器

1、一個(gè)事件處理器拋出異常,則事件鏈上的其他處理器將不會(huì)被調(diào)用,而重寫的虛方法則不會(huì)出現(xiàn)這種情況;
2、重寫要比關(guān)聯(lián)事件處理器高效得多,事件處理器需要迭代整個(gè)請求列表,這樣占用了更多的CPU時(shí)間;
3、事件能在運(yùn)行時(shí)響應(yīng),具有更多的靈活性,可以對同一個(gè)事件關(guān)聯(lián)多個(gè)響應(yīng);
4、通行的規(guī)則是處理一個(gè)派生類的事件是,重寫方式較好。  

合理使用.NET運(yùn)行時(shí)診斷

1、System.Diagnostics.Debug\Trace\EventLog為運(yùn)行時(shí)提供了程序添加診斷信息所需要的所有工具,EventLog提供入口時(shí)的應(yīng)用程序能寫到系統(tǒng)事件日志中;
2、最后不要寫自己的診斷庫,.NET FCL 已經(jīng)擁有了我們需要的核心庫。  

使用標(biāo)準(zhǔn)配置機(jī)制

1、.NET框架的System.Windows.Application類為我們定義了建立通用配置路徑的屬性;
2、Application.LocalAppDataPath 和 Application.userDataPath 會(huì)生成本地?cái)?shù)據(jù)目錄和用戶數(shù)據(jù)的路徑名;
3、不要在ProgramFiles和Windows系統(tǒng)目錄中寫入數(shù)據(jù),這些位置需要更高的安全權(quán)限,不要指望用戶擁有寫入的權(quán)限。  

定制和支持?jǐn)?shù)據(jù)綁定

1、BindingMananger和CurrencyManager這兩個(gè)對象實(shí)現(xiàn)了控件和數(shù)據(jù)源之間的數(shù)據(jù)傳輸;
2、數(shù)據(jù)綁定的優(yōu)勢:使用數(shù)據(jù)綁定要比編寫自己的代碼簡單得多;應(yīng)該將它用于文本數(shù)據(jù)項(xiàng)之外的范圍 —— 其他顯示屬性也可以被綁定;對于 Windowos Forms 數(shù)據(jù)綁定能夠處理多個(gè)控件同步的檢查相關(guān)數(shù)據(jù)源;
3、在對象不支持所需的屬性時(shí),可以通過屏蔽當(dāng)前的對象,然后添加一個(gè)想要的對象來支持?jǐn)?shù)據(jù)綁定。     

DataSet優(yōu)于自定義結(jié)構(gòu)

1、DataSet有兩個(gè)缺點(diǎn)個(gè):使用XML序列化機(jī)制的DataSet與非.NET 代碼之間的交互不是很好;DataSet是一個(gè)非常通用的容器;
2、強(qiáng)類型的DataSet打破了更多的設(shè)計(jì)規(guī)則,其獲得的開發(fā)效率要遠(yuǎn)遠(yuǎn)高于自己編寫的看上去更為優(yōu)雅的設(shè)計(jì)。  

利用特性簡化反射

通過設(shè)計(jì)和實(shí)現(xiàn)特性類,強(qiáng)制開發(fā)人員用他們來聲明可被動(dòng)態(tài)使用的類型、方法和屬性,可以減少應(yīng)用程序的運(yùn)行時(shí)錯(cuò)誤,提高軟件的用戶滿意度。  

避免過度使用反射

1、Invoke成員使用的參數(shù)和返回值都是System.Object,在運(yùn)行時(shí)進(jìn)行類型的轉(zhuǎn)換,但出現(xiàn)問題的可能性也變得更多了;
2、接口使我們可以得到一個(gè)更為清晰、也更具可維護(hù)性的系統(tǒng),反射是一個(gè)很強(qiáng)大的晚期綁定機(jī)制,.NET框架使用它來實(shí)現(xiàn)Windows控件和Web控件的數(shù)據(jù)綁定。  

為應(yīng)用程序創(chuàng)建特定的異常類

1、需要不同的異常類的唯一原因是讓用戶在編寫catch處理器時(shí)能夠方便地對不同的錯(cuò)誤采取不同的做法;
2、可能有不同的修復(fù)行為時(shí),我們才應(yīng)該創(chuàng)建多種不同的異常類,通過提供異常基類所支持的所有構(gòu)造器,可以為應(yīng)用程序創(chuàng)建功能完整的異常類,使用InnerException屬性可以保存更低級別錯(cuò)誤條件所產(chǎn)生的所有錯(cuò)誤信息。  

優(yōu)先選擇異常安全保證

1、強(qiáng)異常保證在從異常中恢復(fù)和簡化異常處理之間提供了最好的平衡,在操作因?yàn)楫惓6袛啵绦虻臓顟B(tài)保留不變;
2、對將要修改的數(shù)據(jù)做防御性的復(fù)制,對這些數(shù)據(jù)的防御性復(fù)制進(jìn)行修改,這中間的操作可能會(huì)引發(fā)異常,將臨時(shí)的副本和原對象進(jìn)行交換;
3、終結(jié)器、Dispose()方法和委托對象所綁定的目標(biāo)方法在任何情況下都應(yīng)當(dāng)確保他們不會(huì)拋出異常。  

最小化互操作

1、互操作有三個(gè)方面的代價(jià):數(shù)據(jù)在托管堆和非托管堆之間的列舉成本,托管代碼和非托管代碼之間切換的成本,對開發(fā)人員來說與混合環(huán)境打交道的開發(fā)工作;
2、在interop中使用blittable類型可以有效地在托管和非托管環(huán)境中來回復(fù)制,而不受對象內(nèi)部結(jié)構(gòu)的影響;
3、使用In/Out特性來確保最貼切的不必要的多次復(fù)制,通過聲明數(shù)據(jù)如何被列舉來提高性能;
4、使用COM Interop用最簡單的方式實(shí)現(xiàn)和COM組件的互操作,使用P/Invoke調(diào)用Win32 API,或者使用C++編譯器的/CLR開關(guān)來混合托管和非托管的代碼;  

優(yōu)先選擇安全代碼

1、盡可能的避免訪問非托管內(nèi)存,隔離存儲(chǔ)不能防止來自托管代碼和受信用戶的訪問;
2、程序集在Web上運(yùn)行時(shí)可以考慮使用隔離存儲(chǔ),當(dāng)某些算法確實(shí)需要更高的安全許可時(shí),應(yīng)該將那些代碼隔離在一個(gè)單獨(dú)的程序集中。
 


該文章在 2023/5/15 22:01:43 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 国产在线www | 国产精品夜夜春夜夜 | 91福利在线播放 | 区视频在线观看 | 国产基zz视 | 国产免费观看 | 黑人又粗又| 国产真实 | 日韩欧美色射高 | 区二区在线欧美 | 成人区一区| 动漫一区二区中文 | 国产不卡精品1 | 91香蕉破解版 | 3d成人动漫资源 | 亚洲无码偷拍福利 | 最新日韩欧美不卡一二三区 | 午夜在线视频 | 国产午夜不卡一区 | 中文字幕福利一 | 亚洲无码午间福利小电影 | 精品在线中 | 国产尤物尤物在线看 | 91精选国产大片 | 国产熟女 | 精品成人一区二区 | 日本亚洲国产黄m | 日韩专区在线观 | 精品尤物视频 | 成人区在线播放 | 日本成a| 欧美日韩国产直播 | 成人一级淫妇视频 | 乱伦国产欧美三级 | 国产综合网在线 | 国产午夜羞羞 | 国产精品婷婷午夜 | 午夜国产福利 | 天美麻花星空视 | 成人拍拍视频 | 91福利专区 |