日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java编码规范总结(腾讯+阿里)

發布時間:2023/12/10 java 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java编码规范总结(腾讯+阿里) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

以下內容轉自他人,總結,感謝他人的分享!!!

Java編碼規范總結(參考騰訊編碼規范)

一、java文件組織

文件組織規則:由于超過2000行的程序難以閱讀,應該盡量避免出現超過2000行的程序。一個Java源文件都包含一個單一的公共類或接口。若私有類和接口與一個公共類相關聯,可以將它們和公共類放入同一個源文件。公共類必須是這個文件中的第一個類或接口。

文件組織順序

1.文件注釋:所有的源文件都應該在開頭有一個注釋,其中列出文件的版權聲明、文件名、功能描述以及創建、修改記錄:

?

2.包和引入語句:在多數Java源文件中,第一個非注釋行是包語句。在它之后可以跟導包語句

3. 類或接口注釋:采用JavaDoc文檔注釋,在類、接口定義之前應當對其進行注釋,包括類、接口的描述、最新修改者、版本號、參考鏈接等;

?

注:JavaDoc文檔注釋:描述Java的類、接口、構造方法、方法、以及字段。每個文檔注釋都會被置于注釋定界符/**...*/之中,一個注釋對應一個類、接口或成員。該注釋應位于聲明之前。文檔注釋的第一行(/**)不需縮進,隨后的文檔注釋每行都縮進1格(使星號縱向對齊)。

4. 類或接口的聲明

5. 類或接口的實現注釋:如果有關類或接口的信息不適合作為“類或接口文檔注釋”,可以在類或接口的實現注釋中給出;

6. 類的(靜態)變量:首先是類的公共變量,隨后是保護變量,再后是包一級別的變量(沒有訪問修飾符),最后是私有變量;

7. 實例變量:首先是公共級別的,隨后是保護級別的,再后是包一級別的(沒有訪問修飾符),最后是私有級別的;

8. 構造方法;

9. 普通方法:方法應該按功能分組,而不應該按作用域或訪問權限進行分組。

二、代碼風格

????? 1.縮進:程序塊要采用縮進風格編寫,縮進只使用TAB鍵,不能使用空格鍵(編輯器中請將TAB設置為4格);方法體的開始、類的定義、以及if、for、do、while、switch、case語句中的代碼都要采用縮進方式;

????? 2.對齊:程序塊的分界符左大括號"{" 和右大括號"}"都另起一行,應各獨占一行并且位于同一列,同時與引用它們的語句左對齊;對齊只使用TAB鍵,不使用空格鍵;不允許把多個短語句寫在一行中,即一行只寫一條語句;if、for、do、while、case、switch、default等語句自占一行。

????? 3.換行:一行的長度超過80個字符需要換行,換行規則如下:

在一個逗號后面斷開;

在一個操作符前面斷開;

長表達式要在低優先級操作符處劃分新行;

新行縮進2個TAB。

4.間隔:類、方法及相對獨立的程序塊之間、變量說明之后必須加空行;關鍵字之后要留空格,?象if、for、while??等關鍵字之后應留一個空格再跟左括號"(", 以突出關鍵字;方法名與其左括號"("之間不要留空格, 以與關鍵字區別;二元操作符如?? " ="、" +="? " >="、" <="、" +"、" *"、" %"、" &&"、" ||"、" <<" ," ^" 等的前后應當加空格;一元操作符如" !"、" ~"、" ++"、" --"等前后不加空格;xiang"[ ]"、" ." 這類操作符前后不加空格;for語句中的表達式應該被空格分開;強制轉型后應該跟一個空格。

三、注釋

1.原則:對已經不推薦使用的類和方法需要注明@Deprecated,并說明替代的類或者方法;對于針對集合、開關的方法,要在方法注釋中表明是否多線程安全。

2.字段注釋: 采用JavaDoc文檔注釋,定義為public的字段必需給出注釋,在類的(靜態)變量、實例變量定義之前當對其進行注釋,給出該字段的描述等:

?

3.方法注釋:采用JavaDoc文檔注釋,在方法定義之前當對其進行注釋,包括方法的描述、輸入、輸出及返回值說明、拋出異常說明、參考鏈接等:

?

4.單行注釋格式//

6.多行注釋格式/*……*/

三、命名規則

1.基本規則:使用可以準確說明變量、字段、類、接口、包等完整的英文描述符;采用大小寫混合,提高名字的可讀性;采用該領域的術語;盡量少用縮寫,但如果一定要使用,當使用公共縮寫和習慣縮寫等;避免使用相似或者僅在大小寫上有區別的名字。

2.包命名:包名一律小寫, 少用縮寫和長名;采用以下規則:

??????????????????????????????????[基本包].[項目名].[模塊名].[子模塊名]...

不得將類直接定義在基本包下,所有項目中的類、接口等都應當定義在各自的項目和模塊包中。

3.類或接口命名:類或接口名是個一名詞,采用大小寫混合的方式,每個單詞的首字母大寫。盡量使你的類名簡潔而富于描述。使用完整單詞,避免用縮寫詞(除非該縮寫詞被更廣泛使用,像URL,HTML)。

4.變量命名: 采用大小寫混合的方式,第一個單詞的首字母小寫,其后單詞的首字母大寫;變量名不應以下劃線或美元符號開頭;盡量避免單個字符的變量名,除非是一次性的臨時變量。臨時變量通常被取名為i,j,k,m和n,它們一般用于整型;c,d,e,它們一般用于字符型;不采用匈牙利命名法則,對不易清楚識別出該變量類型的變量應使用類型名或類型名縮寫作其后綴;組件或部件變量使用其類型名或類型名縮寫作其后綴;集合類型變量,例如數組和矢量,應采用復數命名或使用表示該集合的名詞做后綴。

5.常量命名:全部采用大寫,單詞間用下劃線隔開。

6.方法命名:方法名是一個動詞,采用大小寫混合的方式,第一個單詞的首字母小寫,其后單詞的首字母大寫;取值類可使用get前綴,設值類可使用set前綴,判斷類可使用is(has)前綴。

四、聲明

1.類或接口的聲名:類、接口定義語法規范如下

[可見性][('abstract'|'final')] [Class|Interface] class_name

[('extends'|'implements')][父類或接口名]{

//方法體

}

2.方法聲明:良好的程序設計應該盡可能減小類與類之間耦合,所遵循的經驗法則是:盡量限制成員函數的可見性。如果成員函數沒必要公有 (public),就定義為保護 (protected);沒必要保護 (protected),就定義為私有 (private);方法定義語法規范:

[可見性]['abstract']?[‘static’]?['final'] ['synchronized'][返回值類型] method_name(參數列表)[('throws')][異常列表]{

//方法體

}

聲明順序:構造方法、靜態公共方法、靜態私有方法、公共方法、友元方法、受保護方法、私有方法、main方法;方法參數建議順序:(被操作者,操作內容,操作標志,其他)。

3.變量聲明:一行一個聲明;聲明局部變量的同時初始化(在變量的初始值依賴于某些先前發生的計算的特殊情況下可以不用同時初始化);只在代碼塊的開始處聲明變量,(一個塊是指任何被包含在大括號"{"和"}"中間的代碼)不要在首次用到該變量時才聲明;避免聲明的局部變量覆蓋上一級聲明的變量,即不要在內部代碼塊中聲明相同的變量名;公共和保護的可見性應當盡量避免,所有的字段都建議置為私有,由獲取和設置成員函數(Getter、Setter)訪問;定義一個變量或者常量的時候,不要包含包名(類似java.security.MessageDigest digest = null),除非是兩個包有相同的類名;數組聲明時應當將"[]"跟在類型后,而不是字段名后;聲明順序:常量、類變量、實例變量、公有字段、受保護字段、友元字段、私有字段。

五、異常

????? 1.捕捉異常的目的是為了處理它

????? 2. 多個異常應分別捕捉并處理,避免使用一個單一的catch來處理。

六、習慣

1. if、for、do、while等語句的執行語句部分無論多少都要加括號"{}"

2.?每當一個case順著往下執行時(因為沒有break語句),通常應在break語句的位置添加注釋;

3.?盡量避免在循環中構造和釋放對象

4.?在使用局部變量的過程,按就近原則處理。不允許定義一個局部變量,然后在很遠的地方才使用;

5.相同的功能不允許復制成N份代碼;

6.?在處理 String 的時候要盡量使用 StringBuffer 類。

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

阿里開發規范終極版整理(精簡)

Java開發規范

命名

【規范】類名使用UpperCamelCase?風格,必須遵從駝峰形式,但以下情形例外: ( 領域模型的相關命名 )DO / BO / DTO / VO 等。

正例: MarcoPolo / UserDO / XmlService / TcpUdpDeal / TaPromotion

反例: macroPolo / UserDo / XMLService / TCPUDPDeal / TAPromotion

?

【規范】方法名、參數名、成員變量、局部變量都統一使用lowerCamelCase?風格,必須遵從駝峰形式。

正例: localValue / getHttpMessage() / inputUserId

?

【規范】常量命名全部大寫,單詞間用下劃線隔開,力求語義表達完整清楚,不要嫌名字長。

?

【規范】抽象類命名使用 Abstract 或 Base 開頭 ; 異常類命名使用 Exception 結尾 ; 測試類命名以它要測試的類的名稱開始,以 Test 結尾。枚舉類名建議帶上 Enum 后綴,枚舉成員名稱需要全大寫,單詞間用下劃線隔開。

?

【規范】POJO 類中布爾類型的變量,都不要加 is ,否則部分框架解析會引起序列化錯誤。

?

【規范】各層命名規約:

A) Service / DAO 層方法命名規約

1 ) 獲取單個對象的方法用 get 做前綴。

2 ) 獲取多個對象的方法用 list 做前綴(習慣:getXXXList)。

3 ) 獲取統計值的方法用 count 做前綴。

4 ) 插入的方法用 save( 推薦 ) 或 insert 做前綴。

5 ) 刪除的方法用 remove( 推薦 ) 或 delete 做前綴。

6 ) 修改的方法用 update 做前綴(或modify)。

B) 領域模型命名規約

1 ) 數據對象: xxxDO , xxx 即為數據表名。

2 ) 數據傳輸對象: xxxDTO , xxx 為業務領域相關的名稱。

3 ) 展示對象: xxxVO , xxx 一般為網頁名稱。

4 ) POJO 是 DO / DTO / BO / VO 的統稱,禁止命名成 xxxPOJO 。

?

常量

【規范】不允許任何魔法值( 即未經定義的常量 ) 直接出現在代碼中。

反例: String key =" Id # taobao _"+ tradeId;

cache . put(key , value);

?

格式規約

【風格】單行太長需換行

?

【風格】方法體內的執行語句組、變量的定義語句組、不同的業務邏輯之間或者不同的語義之間插入一個空行。相同業務邏輯和語義之間不需要插入空行。

?

OOP規約

【效率】避免通過一個類的對象引用訪問此類的靜態變量或靜態方法,無謂增加編譯器解析成本,直接用類名來訪問即可。

?

【規范】所有的覆寫方法,必須加@ Override 注解。

?

【規范】對外暴露的接口簽名,原則上不允許修改方法簽名,避免對接口調用方產生影響。接口過時必須加@Deprecated 注解,并清晰地說明采用的新接口或者新服務是什么

?

【規范】Object 的 equals 方法容易拋空指針異常,應使用常量或確定有值的對象來調用equals

正例: " test " .equals(object);

反例: object.equals( " test " );

?

【規范】所有的相同類型的包裝類對象之間值的比較,全部使用 equals 方法比較。(注意空指針)

說明:對于 Integer var =?在-128 至 127 之間的賦值, Integer 對象是在IntegerCache . cache 產生,會復用已有對象,這個區間內的 Integer 值可以直接使用==進行判斷,但是這個區間之外的所有數據,都會在堆上產生,并不會復用已有對象,這是一個大坑,推薦使用 equals 方法進行判斷。

?

【規范】關于基本數據類型與包裝數據類型的使用標準如下:

1 ) 所有的 POJO 類屬性必須使用包裝數據類型。

2 ) RPC 方法的返回值和參數必須使用包裝數據類型。

3 ) 所有的局部變量【推薦】使用基本數據類型。

?

【強制】序列化類新增屬性時,請不要修改 serialVersionUID 字段,避免反序列失敗 ; 如果完全不兼容升級,避免反序列化混亂,那么請修改 serialVersionUID 值。

?

【規范】構造方法里面禁止加入任何業務邏輯,如果有初始化邏輯,請放在 init 方法中。

?

【規范】使用索引訪問用 String 的 split 方法得到的數組時,需做最后一個分隔符后有無內容的檢查,否則會有拋 IndexOutOfBoundsException 的風險。

說明:

String str = "a,b,c,,";

String[] ary = str.split(",");

//預期大于 3,結果是 3

System.out.println(ary.length);

?

【規范】當一個類有多個構造方法,或者多個同名方法,這些方法應該按順序放置在一起,便于閱讀。

?

【風格】類內方法定義順序依次是:公有方法或保護方法 > 私有方法 > getter / setter方法。

?

【效率】final 可提高程序響應效率,聲明成 final 的情況:

1 ) 不需要重新賦值的變量,包括類屬性、局部變量。

2 ) 對象參數前加 final ,表示不允許修改引用的指向。

3 ) 類方法確定不允許被重寫。

4 )例子:final boolean existed = (file.open(fileName, "w") != null) && (...) || (...);

?

集合處理

【強制】關于 hashCode 和 equals 的處理,遵循如下規則

1) 只要重寫 equals ,就必須重寫 hashCode 。

2) 因為 Set 存儲的是不重復的對象,依據 hashCode 和 equals 進行判斷,所以 Set 存儲的對象必須重寫這兩個方法。

3) 如果自定義對象做為 Map 的鍵,那么必須重寫 hashCode 和 equals 。

?

【強制】不要在 foreach 循環里進行元素的 remove / add 操作。 remove 元素請使用 Iterator方式,如果并發操作,需要對 Iterator 對象加鎖。

反例:

List<String> a = new ArrayList<String>();

a.add("1");

a.add("2");

for (String temp : a) {

if("1".equals(temp)){

a.remove(temp);

}

}

說明:以上代碼的執行結果肯定會出乎大家的意料,那么試一下把“1”換成“2”,會是同樣的結果嗎?(java.util.ConcurrentModificationException)

正例:

Iterator<String> it = a.iterator();

while(it.hasNext()){

String temp = it.next();

if(刪除元素的條件){

it.remove();

}

}

?

【規范】集合初始化時,盡量指定集合初始值大小。

說明: ArrayList 盡量使用 ArrayList(int initialCapacity) 初始化。

?

【規范】使用 entrySet 遍歷 Map 類集合 KV,而不是 keySet 方式進行遍歷。

說明:keySet 其實是遍歷了 2 次,一次是轉為 Iterator 對象,另一次是從 hashMap 中取出 key 所對應的 value。而 entrySet 只是遍歷了一次就把 key 和 value 都放到了 entry 中,效 率更高。如果是 JDK8,使用 Map.foreach 方法

Map<String, String> map = new HashMap<String, String>();

map.put("1", "@@");

map.put("2", "##");

?

/**

* JDK8推薦使用

*/

map.forEach((K, V) -> {

System.out.println("Key : " + K);

System.out.println("Value : " + V);

});

?

/**

* foreach推薦使用

*/

for (Map.Entry<String, String> entry : map.entrySet()) {

System.out.println("Key : " + entry.getKey());

System.out.println("Value : " + entry.getValue());

}

?

/**

* 不推薦使用

*/

for (String key : map.keySet()) {

System.out.println("Key : " + key);

System.out.println("Value : " + map.get(key));

}

?

【強制】高度注意 Map 類集合 K/V 能不能存儲 null 值的情況,如下表格:

集合類

Key

Value

Super

說明

Hashtable

不允許為 null

不允許為 null

Dictionary

線程安全

ConcurrentHashMap

不允許為 null

不允許為 null

AbstractMap

分段鎖技術

TreeMap

不允許為 null

允許為 null

AbstractMap

線程不安全

HashMap

允許為 null

允許為 null

AbstractMap

線程不安全

?

并發處理

【規范】獲取單例對象需要保證線程安全,其中的方法也要保證線程安全。

說明:資源驅動類、工具類、單例工廠類都需要注意。

?

【規范】創建線程或線程池時請指定有意義的線程名稱,方便出錯時回溯。

正例:

public class TimerTaskThread extends Thread { public TimerTaskThread(){

super.setName("TimerTaskThread"); ... }

?

【規范】線程資源必須通過線程池提供,不允許在應用中自行顯式創建線程。

說明:使用線程池的好處是減少在創建和銷毀線程上所花的時間以及系統資源的開銷,解決資 源不足的問題。如果不使用線程池,有可能造成系統創建大量同類線程而導致消耗完內存或者 “過度切換”的問題。

?

【規范】線程池不允許使用 Executors 去創建,而是通過 ThreadPoolExecutor 的方式,這樣 的處理方式讓寫的同學更加明確線程池的運行規則規避資源耗盡的風險。 說明:Executors 返回的線程池對象的弊端如下:

1)FixedThreadPool 和 SingleThreadPool:

允許的請求隊列長度為 Integer.MAX_VALUE,可能會堆積大量的請求,從而導致 OOM。

2)CachedThreadPool 和 ScheduledThreadPool:

允許的創建線程數量為 Integer.MAX_VALUE,可能會創建大量的線程,從而導致 OOM。

?

【效率】高并發時,同步調用應該去考量鎖的性能損耗。能用無鎖數據結構,就不要用鎖;能 鎖區塊,就不要鎖整個方法體;能用對象鎖,就不要用類鎖。

?

【強制】對多個資源、數據庫表、對象同時加鎖時,需要保持一致的加鎖順序,否則可能會造 成死鎖。

說明:線程一需要對表 A、B、C 依次全部加鎖后才可以進行更新操作,那么線程二的加鎖順序 也必須是 A、B、C,否則可能出現死鎖。

?

【規范】并發修改同一記錄時,避免更新丟失,要么在應用層加鎖,要么在緩存加鎖,要么在 數據庫層使用樂觀鎖,使用 version 作為更新依據。

說明:如果每次訪問沖突概率小于 20%,推薦使用樂觀鎖,否則使用悲觀鎖。樂觀鎖的重試次 數不得小于 3 次。

?

【規范】多線程并行處理定時任務時,Timer?運行多個 TimeTask 時,只要其中之一沒有捕獲 拋出的異常,其它任務便會自動終止運行,使用ScheduledExecutorService?則沒有這個問題。

?

【規范】HashMap 在容量不夠進行 resize 時由于高并發可能出現死鏈,導致 CPU 飆升,在 開發過程中注意規避此風險。

?

控制語句

【規范】在一個 switch 塊內,每個 case 要么通過 break/return 等來終止,要么注釋說明程 序將繼續執行到哪一個 case 為止;在一個 switch 塊內,都必須包含一個 default 語句并且 放在最后,即使它什么代碼也沒有

?

【規范】在 if/else/for/while/do 語句中必須使用大括號,即使只有一行代碼,避免使用 下面的形式:if (condition) statements;

?

【規范】推薦盡量少用 else, if-else 的方式可以改寫成:

if(condition){

...

return obj; }

// 接著寫 else 的業務邏輯代碼;

說明:如果非得使用if()...else if()...else...方式表達邏輯,【強制】請勿超過3層,

超過請使用狀態設計模式 或者 衛語句

衛語句示例:

  • public void today() { if (isBusy()) {
  • System.out.println(“change time.”); return;
  • }
  • if (isFree()) {
  • System.out.println(“go to travel.”);
  • return;
  • }
  • System.out.println(“stay at home to learn Alibaba Java Coding Guidelines.”);
  • return;
  • }

  • ?

    ?

    【規范】除常用方法(如 getXxx/isXxx)等外,不要在條件判斷中執行其它復雜的語句,將復 雜邏輯判斷的結果賦值給一個有意義的布爾變量名,以提高可讀性。

    說明:很多 if 語句內的邏輯相當復雜,閱讀者需要分析條件表達式的最終結果,才能明確什么 樣的條件執行什么樣的語句,那么,如果閱讀者分析邏輯表達式錯誤呢?

    正例:

    //偽代碼如下

    boolean existed = (file.open(fileName, "w") != null) && (...) || (...); if (existed) {

    ... }

    反例:

    if ((file.open(fileName, "w") != null) && (...) || (...)) { ...

    }

    ?

    【規范】方法中需要進行參數校驗的場景:

    1) 調用頻次低的方法。

    2) 執行時間開銷很大的方法,參數校驗時間幾乎可以忽略不計,但如果因為參數錯誤導致

    中間執行回退,或者錯誤,那得不償失。

    3) 需要極高穩定性和可用性的方法。

    4) 對外提供的開放接口,不管是RPC/API/HTTP接口。

    5) 敏感權限入口。

    ?

    【規范】方法中不需要參數校驗的場景:

    1) 極有可能被循環調用的方法,不建議對參數進行校驗。但在方法說明里必須注明外部參

    數檢查。

    2)?底層的方法調用頻度都比較高,一般不校驗。畢竟是像純凈水過濾的最后一道,參數錯誤不太可能到底層才會暴露問題。一般 DAO 層與 Service 層都在同一個應用中,部署在同一 臺服務器中,所以 DAO 的參數校驗,可以省略。

    3) 被聲明成private只會被自己代碼所調用的方法,如果能夠確定調用方法的代碼傳入參 數已經做過檢查或者肯定不會有問題,此時可以不校驗參數。

    ?

    注釋規約

    【規范】類、類屬性、類方法的注釋必須使用 Javadoc 規范,使用/**內容*/格式,不得使用 //xxx 方式。

    ?

    【規范】所有的抽象方法(包括接口中的方法)必須要用 Javadoc 注釋、除了返回值、參數、 異常說明外,還必須指出該方法做什么事情,實現什么功能。

    說明:對子類的實現要求,或者調用注意事項,請一并說明。

    ?

    【風格】方法內部單行注釋,在被注釋語句上方另起一行,使用//注釋。方法內部多行注釋使用/* */注釋,注意與代碼對齊。

    ?

    【規范】所有的枚舉類型字段必須要有注釋,說明每個數據項的用途。

    ?

    【規范】代碼修改的同時,注釋也要進行相應的修改,尤其是參數、返回值、異常、核心邏輯 等的修改。

    ?

    【規范】注釋掉的代碼盡量要配合說明,而不是簡單的注釋掉。

    說明:代碼被注釋掉有兩種可能性:

    1)后續會恢復此段代碼邏輯。

    2)永久不用。前者如果沒 有備注信息,難以知曉注釋動機。

    后者建議直接刪掉(代碼倉庫保存了歷史代碼)。

    ?

    【風格】特殊注釋標記,請注明標記人與標記時間。注意及時處理這些標記,通過標記掃描, 經常清理此類標記。線上故障有時候就是來源于這些標記處的代碼。

    1)?待辦事宜(TODO):( 標記人,標記時間,[預計處理時間]) 表示需要實現,但目前還未實現的功能。這實際上是一個 Javadoc 的標簽,目前的 Javadoc

    還沒有實現,但已經被廣泛使用。只能應用于類,接口和方法(因為它是一個 Javadoc 標簽)。

    2)?錯誤,不能工作(FIXME):(標記人,標記時間,[預計處理時間])

    在注釋中用 FIXME 標記某代碼是錯誤的,而且不能工作,需要及時糾正的情況。

    ?

    異常

    【規范】異常不要用來做流程控制,條件控制,因為異常的處理效率比條件分支低。

    ?

    【規范】對大段代碼進行 try-catch,這是不負責任的表現。catch 時請分清穩定代碼和非穩 定代碼,穩定代碼指的是無論如何不會出錯的代碼。對于非穩定代碼的 catch 盡可能進行區分 異常類型,再做對應的異常處理。

    ?

    【規范】捕獲異常是為了處理它,不要捕獲了卻什么都不處理而拋棄之,如果不想處理它,請 將該異常拋給它的調用者。最外層的業務使用者,必須處理異常,將其轉化為用戶可以理解的 內容。

    ?

    【強制】有 try 塊放到了事務代碼中,catch 異常后,如果需要回滾事務,一定要注意手動回 滾事務。

    ?

    【規范】不能在 finally 塊中使用 return,finally 塊中的 return 返回后方法結束執行,不 會再執行 try 塊中的 return 語句。

    ?

    【規范】方法的返回值可以為 null,不強制返回空集合,或者空對象等,必須添加注釋充分 說明什么情況下會返回 null 值。調用方需要進行 null 判斷防止 NPE 問題。

    ?

    【規范】防止 NPE,是程序員的基本修養,注意 NPE 產生的場景:

    1) 返回類型為包裝數據類型,有可能是null,返回int值時注意判空。

    反例:public int f(){ return Integer 對象}; 如果為 null,自動解箱拋 NPE。

    2) 數據庫的查詢結果可能為null。

    3) 集合里的元素即使isNotEmpty,取出的數據元素也可能為null。

    4) 遠程調用返回對象,一律要求進行NPE判斷。

    5) 對于Session中獲取的數據,建議NPE檢查,避免空指針。

    6) 級聯調用obj.getA().getB().getC();一連串調用,易產生NPE。

    ?

    【規范】在代碼中使用“拋異常”還是“返回錯誤碼”,對于公司外的 http/api 開放接口必須 使用“錯誤碼”;而應用內部推薦異常拋出;跨應用間 RPC 調用優先考慮使用 Result 方式,封 裝 isSuccess、“錯誤碼”、“錯誤簡短信息”。

    說明:關于 RPC 方法返回方式使用 Result 方式的理由:

    1)使用拋異常返回方式,調用方如果沒有捕獲到就會產生運行時錯誤。

    2)如果不加棧信息,只是new自定義異常,加入自己的理解的error message,對于調用 端解決問題的幫助不會太多。如果加了棧信息,在頻繁調用出錯的情況下,數據序列化和傳輸 的性能損耗也是問題。

    ?

    【規范】避免出現重復的代碼(Don’t Repeat Yourself),即DRY原則。

    ?

    日志

    【規范】應用中不可直接使用日志系統(Log4j、Logback)中的 API,而應依賴使用日志框架

    SLF4J 中的 API,使用門面模式的日志框架,有利于維護和各個類的日志處理方式統一。

    import org.slf4j.Logger;

    import org.slf4j.LoggerFactory;

    private static final Logger logger = LoggerFactory.getLogger(Abc.class);

    ?

    【規范】日志文件推薦至少保存 15 天,因為有些異常具備以“周”為頻次發生的特點。

    ?

    【規范】應用中的擴展日志(如打點、臨時監控、訪問日志等)命名方式: appName_logType_logName.log。

    logType:日志類型,推薦分類有 stats/desc/monitor/visit 等;

    logName:日志描述。這種命名的好處:通過文件名就可知 道日志文件屬于什么應用,什么類型,什么目的,也有利于歸類查找。

    正例:mppserver 應用中單獨監控時區轉換異常,如: mppserver_monitor_timeZoneConvert.log

    說明:推薦對日志進行分類,錯誤日志和業務日志盡量分開存放,便于開發人員查看,也便于 通過日志對系統進行及時監控。

    ?

    【規范】對 trace/debug/info 級別的日志輸出,必須使用條件輸出形式或者使用占位符的方式

    說明:logger.debug("Processing trade with id: " + id + " symbol: " + symbol); 如果日志級別是 warn,上述日志不會打印,但是會執行字符串拼接操作,如果 symbol 是對象, 會執行 toString()方法,浪費了系統資源,執行了上述操作,最終日志卻沒有打印。 正例:(條件)

    if (logger.isDebugEnabled()) {

    logger.debug("Processing trade with id: " + id + " symbol: " + symbol);

    }

    正例:(占位符)

    logger.debug("Processing trade with id: {} symbol : {} ", id, symbol);

    ?

    * 避免重復打印日志,浪費磁盤空間,務必在 log4j.xml 中設置 additivity=false。

    正例:<logger name="com.taobao.dubbo.config" additivity="false">

    ?

    【規范】可以使用warn 日志級別來記錄用戶輸入參數錯誤的情況,避免用戶投訴時,無所適 從。注意日志輸出的級別,error 級別只記錄系統邏輯出錯、異常等重要的錯誤信息。如非必 要,請不要在此場景打出 error 級別。

    ?

    【規范】謹慎地記錄日志。生產環境禁止輸出 debug 日志;有選擇地輸出 info 日志;如果使 用 warn 來記錄剛上線時的業務行為信息,一定要注意日志輸出量的問題,避免把服務器磁盤 撐爆,并記得及時刪除這些觀察日志。

    說明:大量地輸出無效日志,不利于系統性能提升,也不利于快速定位錯誤點。記錄日志時請

    ?

    思考:這些日志真的有人看嗎?看到這條日志你能做什么?能不能給問題排查帶來好處?

    ?

    其它

    【效率】在使用正則表達式時,利用好其預編譯功能,可以有效加快正則匹配速度。 說明:不要在方法體內定義:Pattern pattern = Pattern.compile(規則);

    ?

    【規范】獲取當前毫秒數 System.currentTimeMillis(); 而不是 new Date().getTime();

    說明:如果想獲取更加精確的納秒級時間值,用 System.nanoTime()。在 JDK8 中,針對統計 時間等場景,推薦使用Instant?類。

    ?

    【規范】對于“明確停止使用的代碼和配置”,如方法、變量、類、配置文件、動態配置屬性等要堅決從程序中清理出去,避免造成過多垃圾。

    ?

    單元測試

    【強制】好的單元測試必須遵守 AIR 原則。

    說明:單元測試在線上運行時,感覺像空氣(AIR)一樣并不存在,但在測試質量的保障上,卻是非常關鍵的。好的單元測試宏觀上來說,具有自動化、獨立性、可重復執行的特點。
    ? A:Automatic(自動化)
    ? I:Independent(獨立性)

    ? R:Repeatable(可重復)?

    【強制】單元測試應該是全自動執行的,并且非交互式的。測試框架通常是定期執行的,執行過程必須完全自動化才有意義。輸出結果需要人工檢查的測試不是一個好的單元測試。單元測 試中不準使用 System.out 來進行人肉驗證,必須使用 assert 來驗證。


    【強制】保持單元測試的獨立性。為了保證單元測試穩定可靠且便于維護,單元測試用例之間 決不能互相調用,也不能依賴執行的先后次序。
    反例:method2 需要依賴 method1 的執行,將執行結果做為 method2 的輸入。

    ?

    【強制】對于單元測試,要保證測試粒度足夠小,有助于精確定位問題。單測粒度至多是類級別,一般是方法級別。?

    說明:只有測試粒度小才能在出錯時盡快定位到出錯位置。單測不負責檢查跨類或者跨系統的 交互邏輯,那是集成測試的領域。


    【強制】核心業務、核心應用、核心模塊的增量代碼確保單元測試通過。?

    說明:新增代碼及時補充單元測試,如果新增代碼影響了原有單元測試,請及時修正。

    ?

    【推薦】單元測試的基本目標:語句覆蓋率達到 70%;核心模塊的語句覆蓋率和分支覆蓋率都 要達到 100%
    說明:在工程規約的應用分層中提到的 DAO 層,Manager 層,可重用度高的 Service,都應該 進行單元測試。

    ?

    【推薦】編寫單元測試代碼遵守 BCDE 原則,以保證被測試模塊的交付質量。
    l B:Border,邊界值測試,包括循環邊界、特殊取值、特殊時間點、數據順序等。

    C:Correct,正確的輸入,并得到預期的結果。

    l D:Design,與設計文檔相結合,來編寫單元測試
    l E:Error,強制錯誤信息輸入(:非法數據、異常流程、非業務允許輸入等),并得 到預期的結果。

    ?

    【推薦】和數據庫相關的單元測試,可以設定自動回滾機制,不給數據庫造成臟數據。或者 對單元測試產生的數據有明確的前后綴標識。
    正例:在 RDC 內部單元測試中,使用 RDC_UNIT_TEST_的前綴標識數據。


    【推薦】在設計評審階段,開發人員需要和測試人員一起確定單元測試范圍,單元測試最好 覆蓋所有測試用例(UC)。


    【推薦】單元測試作為一種質量保障手段,不建議項目發布后補充單元測試用例,建議在項 目提測前完成單元測試。

    ?

    【參考】不要對單元測試存在如下誤解:
    l 那是測試同學干的事情。本文是開發手冊,凡是本文內容都是與開發同學強相關的。

    單元測試代碼是多余的。汽車的整體功能與各單元部件的測試正常與否是強相關的。 l

    單元測試代碼不需要維護。一年半載后,那么單元測試幾乎處于廢棄狀態。
    l 單元測試與線上故障沒有辯證關系。好的單元測試能夠最大限度地規避線上故障。

    ?

    MySQL開發規范

    建表規約

    【規范】表達是與否概念的字段,必須使用 is_xxx 的方式命名,數據類型是 unsigned tinyint ( 1表示是,0表示否),此規則同樣適用于odps建表。 說明:任何字段如果為非負數,必須是 unsigned。

    ?

    【規范】表名、字段名必須使用小寫字母或數字;禁止出現數字開頭,禁止兩個下劃線中間只 出現數字。數據庫字段名的修改代價很大,因為無法進行預發布,所以字段名稱需要慎重考慮。

    正例:getter_admin,task_config,level3_name

    反例:GetterAdmin,taskConfig,level_3_name

    ?

    【規范】唯一索引名為 uk_字段名;普通索引名則為 idx_字段名。

    ?

    【規范】小數類型為 decimal,禁止使用 float 和 double。

    說明:float 和 double 在存儲的時候,存在精度損失的問題,很可能在值的比較時,得到不 正確的結果。如果存儲的數據范圍超過 decimal 的范圍,建議將數據拆成整數和小數分開存儲

    ?

    【規范】如果存儲的字符串長度幾乎相等,使用 char 定長字符串類型。

    ?

    【效率】varchar 是可變長字符串,不預先分配存儲空間,長度不要超過 5000,如果存儲長 度大于此值,定義字段類型為 text,獨立出來一張表,用主鍵來對應,避免影響其它字段索 引效率。

    ?

    【規范】表的命名最好是加上“業務名稱_表的作用”。

    正例:tiger_task / tiger_reader / mpp_config

    ?

    【規范】庫名與應用名稱盡量一致。

    ?

    【規范】如果修改字段含義或對字段表示的狀態追加時,需要及時更新字段注釋。

    ?

    【效率】字段允許適當冗余,以提高性能,但是必須考慮數據同步的情況。冗余字段應遵循:

    1)不是頻繁修改的字段。

    2)不是 varchar 超長字段,更不能是 text 字段。 正例:商品類目名稱使用頻率高,字段長度短,名稱基本一成不變,可在相關聯的表中冗余存 儲類目名稱,避免關聯查詢。

    ?

    【效率】單表行數超過 500 萬行或者單表容量超過 2GB,才推薦進行分庫分表。?說明:如果預計三年后的數據量根本達不到這個級別,請不要在創建表時就分庫分表。

    ?

    【效率】合適的字符存儲長度,不但節約數據庫表空間、節約索引存儲,更重要的是提升檢 索速度

    正例:人的年齡用 unsigned tinyint(表示范圍 0-255,人的壽命不會超過 255 歲);海龜 就必須是 smallint,但如果是太陽的年齡,就必須是 int;如果是所有恒星的年齡都加起來, 那么就必須使用 bigint。

    ?

    索引規約

    【效率】業務上具有唯一特性的字段,即使是組合字段,也必須建成唯一索引。

    說明:不要以為唯一索引影響了 insert 速度,這個速度損耗可以忽略,但提高查找速度是明 顯的;另外,即使在應用層做了非常完善的校驗和控制,只要沒有唯一索引,根據墨菲定律, 必然有臟數據產生

    ?

    【規范】超過三個表禁止 join。需要 join 的字段,數據類型保持絕對一致;多表關聯查詢 時,保證被關聯的字段需要有索引。

    說明:即使雙表 join 也要注意表索引、SQL 性能。

    ?

    【規范】在 varchar 字段上建立索引時,必須指定索引長度,沒必要對全字段建立索引,根據 實際文本區分度決定索引長度。

    說明:索引的長度與區分度是一對矛盾體,一般對字符串類型數據,長度為 20 的索引,區分 度會高達 90%以上,可以使用 count(distinct left(列名, 索引長度))/count(*)的區分度 來確定。

    ?

    【規范】頁面搜索嚴禁左模糊或者全模糊,如果需要請走搜索引擎來解決。

    說明:索引文件具有 B-Tree 的最左前綴匹配特性,如果左邊的值未確定,那么無法使用此索 引。

    ?

    【規范】如果有 order by 的場景,請注意利用索引的有序性。order by 最后的字段是組合 索引的一部分,并且放在索引組合順序的最后,避免出現 file_sort 的情況,影響查詢性能。

    正例:where a=? and b=? order by c; 索引:a_b_c

    反例:索引中有范圍查找,那么索引有序性無法利用,如:WHERE a>10 ORDER BY b; 索引 a_b 無法排序。

    ?

    【效率】利用覆蓋索引來進行查詢操作,來避免回表操作。

    說明:如果一本書需要知道第 11 章是什么標題,會翻開第 11 章對應的那一頁嗎?目錄瀏覽 一下就好,這個目錄就是起到覆蓋索引的作用。 正例:能夠建立索引的種類:主鍵索引、唯一索引、普通索引,而覆蓋索引是一種查詢的一種 效果,用explain的結果,extra列會出現:using index。

    ?

    【效率】利用延遲關聯或者子查詢優化超多分頁場景

    說明:MySQL 并不是跳過 offset 行,而是取 offset+N 行,然后返回放棄前 offset 行,返回 N 行,那當 offset 特別大的時候,效率就非常的低下,要么控制返回的總頁數,要么對超過 特定閾值的頁數進行 SQL 改寫。

    正例:先快速定位需要獲取的 id 段,然后再關聯:(優化在可以少查表1的很多字段

    SELECT a.* FROM 表 1 a, (select id from 表 1 where 條件 LIMIT 100000,20 ) b where a.id=b.id

    ?

    【效率】SQL 性能優化的目標:至少要達到 range 級別,要求是 ref 級別,如果可以是 consts 最好。

    說明:

    1)consts 單表中最多只有一個匹配行(主鍵或者唯一索引),在優化階段即可讀取到數據。

    2)ref 指的是使用普通的索引(normal index)。

    3)range 對索引進行范圍檢索。

    反例:explain 表的結果,type=index,索引物理文件全掃描,速度非常慢,這個 index 級 別比較 range 還低,與全表掃描是小巫見大巫。

    ?

    【規范】建組合索引的時候,區分度最高的在最左邊

    正例:如果 where a=? and b=? ,a 列的幾乎接近于唯一值,那么只需要單建 idx_a 索引即 可。

    說明:存在非等號和等號混合判斷條件時,在建索引時,請把等號條件的列前置。如:where a>? and b=? 那么即使 a 的區分度更高,也必須把 b 放在索引的最前列

    ?

    【說明】創建索引時避免有如下極端誤解:

    1)誤認為一個查詢就需要建一個索引。

    2)誤認為索引會消耗空間、嚴重拖慢更新和新增速度。

    3)誤認為唯一索引一律需要在應用層通過“先查后插”方式解決。

    ?

    SQL規約

    【規范】不要使用 count(列名)或 count(常量)來替代 count(*),count(*)就是 SQL92 定義 的標準統計行數的語法,跟數據庫無關,跟 NULL 和非 NULL 無關。

    說明:count(*)會統計值為 NULL 的行,而 count(列名)不會統計此列為 NULL 值的行。

    ?

    【說明】count(distinct col) 計算該列除 NULL 之外的不重復數量。注意 count(distinct col1, col2) 如果其中一列全為NULL,那么即使另一列有不同的值,也返回為0。

    ?

    【說明】當某一列的值全是 NULL 時,count(col)的返回結果為 0,但 sum(col)的返回結果為 NULL,因此使用 sum()時需注意 NPE 問題。

    正例:可以使用如下方式來避免sum的NPE問題:SELECT IF(ISNULL(SUM(g)),0,SUM(g)) FROM table;

    ?

    【說明】使用 ISNULL()來判斷是否為 NULL 值。注意:NULL 與任何值的直接比較都為 NULL。

    說明:

    1) NULL<>NULL的返回結果是NULL,而不是false。

    2) NULL=NULL的返回結果是NULL,而不是true。

    3) NULL<>1的返回結果是NULL,而不是true。

    ?

    【規范】不得使用外鍵與級聯,一切外鍵概念必須在應用層解決

    說明:(概念解釋)學生表中的 student_id 是主鍵,那么成績表中的 student_id 則為外鍵。 如果更新學生表中的 student_id,同時觸發成績表中的 student_id 更新,則為級聯更新。外鍵與級聯更新適用于單機低并發,不適合分布式、高并發集群;級聯更新是強阻塞,存在數 據庫更新風暴的風險;外鍵影響數據庫的插入速度。

    ?

    【規范】數據訂正時,刪除和修改記錄時,要先 select,避免出現誤刪除,確認無誤才能執行更新語句。

    ?

    【效率】in 操作能避免則避免,若實在避免不了,需要仔細評估 in 后邊的集合元素數量,控制在 1000 個之內。(可以用用 EXISTS ,NOT EXISTS 或 JOIN代替)

    ?

    【規范】如果有全球化需要,所有的字符存儲與表示,均以 utf-8 編碼,那么字符計數方法 注意:

    說明:

    SELECT LENGTH("輕松工作"); 返回為12

    SELECT CHARACTER_LENGTH("輕松工作"); 返回為4 如果要使用表情,那么使用 utfmb4 來進行存儲,注意它與 utf-8 編碼的區別。

    ?

    【規范】TRUNCATE TABLE 比 DELETE 速度快,且使用的系統和事務日志資源少,但 TRUNCATE無事務且不觸發 trigger,有可能造成事故,故不建議在開發代碼中使用此語句

    說明:TRUNCATE TABLE 在功能上與不帶 WHERE 子句的 DELETE 語句相同。

    ?

    ORM規約

    【規范】POJO 類的 boolean 屬性不能加 is,而數據庫字段必須加 is_,要求在 resultMap 中 進行字段與屬性之間的映射。

    說明:參見定義 POJO 類以及數據庫字段定義規定,在 sql.xml 增加映射,是必須的。

    ?

    【安全】配置XML文件時注意SQL注入問題。

    ?

    【規范】不允許直接拿 HashMap 與 Hashtable 作為查詢結果集的輸出。

    ?

    【強制】更新數據表記錄時,必須同時更新記錄對應的 gmt_modified 字段值為當前時間。

    ?

    【規范】不要寫一個大而全的數據更新接口,傳入為 POJO 類,不管是不是自己的目標更新字 段,都進行 update table set c1=value1,c2=value2,c3=value3; 這是不對的。執行 SQL 時,盡量不要更新無改動的字段,一是易出錯;二是效率低;三是 binlog 增加存儲。

    ?

    【規范】@Transactional 事務不要濫用。事務會影響數據庫的 QPS,另外使用事務的地方需 要考慮各方面的回滾方案,包括緩存回滾、搜索引擎回滾、消息補償、統計修正等。

    ?

    工程規約


    ?

    ?

    【說明】圖中默認上層依賴于下層,箭頭關系表示可直接依賴,如:開放接口層可以依賴于Web 層,也可以直接依賴于 Service 層,依此類推。

    ? 開放接口層:可直接封裝 Service接口暴露成 RPC 接口;通過 Web 封裝成 http 接口;網關控 制層等

    ? 終端顯示層:各個端的模板渲染并執行顯示層。當前主要是 velocity 渲染,JS 渲染,JSP 渲 染,移動端展示層等。

    ? Web 層:主要是對訪問控制進行轉發,各類基本參數校驗,或者不復用的業務簡單處理等。(Controller)

    ? Service 層:相對具體的業務邏輯服務層。

    ? Manager 層:通用業務處理層,它有如下特征:

    1)?對第三方平臺封裝的層,預處理返回結果及轉化異常信息;

    2)?對Service層通用能力的下沉,如緩存方案、中間件通用處理;

    3)?與DAO層交互,對DAO的業務通用能力的封裝。

    ? DAO 層:數據訪問層,與底層 MySQL、Oracle、Hbase 進行數據交互。

    ? 外部接口或第三方平臺:包括其它部門 RPC 開放接口,基礎平臺,其它公司的 HTTP 接口。

    ?

    【規范】(分層異常處理規約)在 DAO 層,產生的異常類型有很多,無法用細粒度的異常進 catch,使用catch(Exception e)方式,并throw new DAOException(e),不需要打印日志,因為日志在 Manager/Service 層一定需要捕獲并打到日志文件中去,如果同臺服務器 再打日志,浪費性能和存儲。在 Service 層出現異常時,必須記錄出錯日志到磁盤,盡可能帶 上參數信息,相當于保護案發現場。如果 Manager 層與 Service 同機部署,日志方式與 DAO 層處理一致,如果是單獨部署,則采用與 Service 一致的處理方式。Web 層絕不應該繼續往上拋異常,因為已經處于頂層,如果意識到這個異常將導致頁面無法正常渲染,那么就應該直接跳轉到友好錯誤頁面,加上用戶容易理解的錯誤提示信息。開放接口層要將異常處理成錯誤碼 和錯誤信息方式返回。

    ?

    【規范】分層領域模型規約:

    ? DO(Data Object):與數據庫表結構一一對應,通過 DAO 層向上傳輸數據源對象。(Entity)

    ? DTO(Data Transfer Object):數據傳輸對象,Service 和 Manager 向外傳輸的對象。

    ? BO(Business Object):業務對象。可以由 Service 層輸出的封裝業務邏輯的對象。

    ? QUERY:數據查詢對象,各層接收上層的查詢請求。注:超過 2 個參數的查詢封裝,禁止 使用 Map 類來傳輸。

    ? VO(View Object):顯示層對象,通常是 Web 向模板渲染引擎層傳輸的對象。

    ?

    服務器規約

    【效率】高并發服務器建議調小 TCP 協議的 time_wait 超時時間。

    說明:操作系統默認 240 秒后,才會關閉處于 time_wait 狀態的連接,在高并發訪問下,服務器端會因為處于 time_wait 的連接數太多,可能無法建立新的連接,所以需要在服務器上 調小此等待值。

    正例:在 linux 服務器上請通過變更/etc/sysctl.conf 文件去修改該缺省值(秒):

    net.ipv4.tcp_fin_timeout = 30

    ?

    【效率】調大服務器所支持的最大文件句柄數(File Descriptor,簡寫為fd)。

    說明:主流操作系統的設計是將 TCP/UDP 連接采用與文件一樣的方式去管理,即一個連接對 應于一個 fd。主流的 linux 服務器默認所支持最大 fd 數量為 1024,當并發連接數很大時很 容易因為 fd 不足而出現“open too many files”錯誤,導致新的連接無法建立。 建議將 linux 服務器所支持的最大句柄數調高數倍(與服務器的內存數量相關)。

    ?

    【規范】給 JVM 設置-XX:+HeapDumpOnOutOfMemoryError 參數,讓 JVM 碰到 OOM 場景時輸出 dump 信息。

    說明:OOM 的發生是有概率的,甚至有規律地相隔數月才出現一例,出現時的現場信息對查錯 非常有價值。

    ?

    【規范】服務器內部重定向使用 forward;外部重定向地址使用 URL 拼裝工具類來生成,否則 會帶來 URL 維護不一致的問題和潛在的安全風險。

    ?

    安全規約

    【安全】隸屬于用戶個人的頁面或者功能必須進行權限控制校驗。

    說明:防止沒有做水平權限校驗就可隨意訪問、操作別人的數據,比如查看、修改別人的訂單。

    ?

    【安全】用戶敏感數據禁止直接展示,必須對展示數據脫敏。

    說明:查看個人手機號碼會顯示成:158****9119,隱藏中間 4 位,防止隱私泄露。

    ?

    【安全】用戶輸入的 SQL 參數嚴格使用參數綁定或者 METADATA 字段值限定,防止 SQL 注入, 禁止字符串拼接 SQL 訪問數據庫。

    ?

    【安全】用戶請求傳入的任何參數必須做有效性驗證。

    說明:忽略參數校驗可能導致:

    l page size 過大導致內存溢出

    l 惡意 order by 導致數據庫慢查詢

    l 任意重定向

    l SQL 注入

    l 反序列化注入

    l 正則輸入源串拒絕服務 ReDoS

    說明:Java 代碼用正則來驗證客戶端的輸入,有些正則寫法驗證普通用戶輸入沒有問題, 但是如果攻擊人員使用的是特殊構造的字符串來驗證,有可能導致死循環的效果

    ?

    【安全】禁止向 HTML 頁面輸出未經安全過濾或未正確轉義的用戶數據。

    ?

    【安全】表單、AJAX 提交必須執行 CSRF 安全過濾。

    說明:CSRF(Cross-site request forgery)跨站請求偽造是一類常見編程漏洞。對于存在 CSRF 漏洞的應用/網站,攻擊者可以事先構造好 URL,只要受害者用戶一訪問,后臺便在用戶 不知情情況下對數據庫中用戶參數進行相應修改。

    ?

    【安全】在使用平臺資源,譬如短信、郵件、電話、下單、支付,必須實現正確的防重放限制, 如數量限制、疲勞度控制、驗證碼校驗,避免被濫刷、資損。

    說明:如注冊時發送驗證碼到手機,如果沒有限制次數和頻率,那么可以利用此功能騷擾到其 它用戶,并造成短信平臺資源浪費。

    ?

    【安全】發貼、評論、發送即時消息等用戶生成內容的場景必須實現防刷、文本內容違禁詞過 濾等風控策略。

    ?

    總結

    以上是生活随笔為你收集整理的Java编码规范总结(腾讯+阿里)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    免费在线观看av网站 | 国产在线精品视频 | 国产老太婆免费交性大片 | 久久久成人精品 | 在线观看黄网站 | 成 人 黄 色 免费播放 | 日韩理论影院 | 欧美巨大荫蒂茸毛毛人妖 | 亚洲国产美女精品久久久久∴ | 国产成本人视频在线观看 | 久久久久久国产精品美女 | 天天色天天射天天综合网 | 丝袜精品视频 | 天天摸天天操天天舔 | 久久99久久99免费视频 | 成人黄色短片 | 国产午夜三级一二三区 | 精品国产亚洲在线 | 天天视频色| 亚洲欧美日韩一二三区 | 黄色三级网站在线观看 | 国产夫妻性生活自拍 | 日韩视频精品在线 | www日韩欧美 | 九九久久在线看 | 国产成人精品一区一区一区 | 久久精品99国产 | 国产一级二级在线观看 | 日韩在线免费视频 | 国产精品久久久久免费观看 | 国产精品理论片在线播放 | 五月婷在线播放 | 国产 日韩 在线 亚洲 字幕 中文 | 97超碰在线免费观看 | 97高清视频 | av电影在线免费 | 亚洲精品美女在线观看播放 | 亚洲精品视频在线免费播放 | 江苏妇搡bbbb搡bbbb | 81精品国产乱码久久久久久 | 五月开心激情网 | 天天操福利视频 | 久久视频在线看 | 国产精品视频地址 | 成人黄色在线看 | 国产成人亚洲在线观看 | 丁香婷婷成人 | 中文字幕av日韩 | 久久夜夜操| av福利在线导航 | 国内成人精品视频 | 人人干人人模 | 综合婷婷| 一区二区电影在线观看 | 97国产超碰 | 国产高清免费av | 欧美久草网| a天堂免费| 久草在线免费资源站 | 97看片网| 日韩欧美高清在线 | 国产精品久久久久久久久久 | 在线成人欧美 | 亚洲精色 | 在线免费观看的av网站 | 黄色三级av| 日韩欧美在线视频一区二区三区 | 日韩免费电影一区二区 | 久久久久久久久久国产精品 | 国产看片网站 | a在线一区 | 五月婷婷色综合 | 久久成人18免费网站 | 一区二区 精品 | 国产高清视频免费观看 | 在线观看视频你懂得 | 精品a级片| 日日精品| 天天干天天干天天色 | 欧美精品乱码久久久久 | 伊人首页| 成人资源在线 | 免费日韩视| 美女视频永久黄网站免费观看国产 | 91高清完整版在线观看 | 欧美日韩一级久久久久久免费看 | 中文字幕在线视频一区二区三区 | www日韩| 国产亚洲人成网站在线观看 | 五月天中文字幕mv在线 | 成人夜晚看av | 国产视频精品视频 | 国产手机av在线 | 日韩免费看的电影 | 精品国产成人av在线免 | 黄色毛片在线 | 特级黄色视频毛片 | 日韩欧美在线视频一区二区 | 五月婷婷电影网 | 色婷婷一区 | 国产高清不卡一区二区三区 | 中文资源在线播放 | 夜夜骑首页 | 青春草视频 | 国产黄在线看 | 91福利社在线观看 | 国产精品久久久久久久久久久免费 | av成人免费网站 | 国产视频日韩视频欧美视频 | 涩涩网站在线观看 | 久久av影院 | 99视频在线免费看 | 日韩丝袜| 中文字幕一区二区三区视频 | 最近日韩中文字幕中文 | 中文字幕免费高清在线观看 | 日日干干| 狠狠色丁香婷婷综合橹88 | 午夜视频在线观看一区二区三区 | 国产精品一区久久久久 | 丰满少妇一级 | 视频福利在线 | 操操操com| 99tvdz@gmail.com| 国产69久久| 99色免费 | 麻豆传媒在线免费看 | 国产在线 一区二区三区 | 一区二区三区四区久久 | 久久黄色网页 | 精品人人爽| 激情av网址 | 欧美日韩午夜爽爽 | 激情综合国产 | 一级黄色片在线免费看 | 国产黄色成人av | 婷婷丁香花五月天 | 六月色播 | 韩国精品视频在线观看 | 不卡国产视频 | 一区二区高清在线 | 久久免费视屏 | www.天天射.com| 69中文字幕 | 国产精品视频专区 | 亚洲一区二区三区四区在线视频 | 欧美做受高潮 | 夜夜夜夜操 | 亚洲免费精品视频 | 久久久久免费精品视频 | 国产伦理剧 | 国产中文字幕一区二区 | 免费av网站观看 | 成人在线视频免费 | 日韩在线观看视频中文字幕 | 在线观看日韩中文字幕 | 97av色 | 久久久久福利视频 | 99在线观看视频网站 | 国产精品影音先锋 | 涩av在线 | 国产午夜在线观看视频 | 精品极品在线 | 五月天激情综合 | av免费高清观看 | 免费精品国产 | 中文国产字幕 | 国产专区免费 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 8x成人免费视频 | 欧美精品一区二区在线观看 | 在线观看国产v片 | 成人在线视频网 | 99爱爱| 不卡的av在线播放 | 999久久久欧美日韩黑人 | 国产 一区二区三区 在线 | 丁香伊人网 | 综合铜03| 亚洲成人精品av | 欧美精品久久久久久久久久白贞 | 88av网站 | 午夜精品久久久久久久99热影院 | 四虎在线免费视频 | 中文字幕婷婷 | 久久久九色精品国产一区二区三区 | 亚洲精品99久久久久中文字幕 | 九九视频免费在线观看 | 国产69久久久欧美一级 | 999久久久欧美日韩黑人 | 亚洲综合激情 | 99热在线观看 | 中文字幕在线视频一区 | 天天干,天天操,天天射 | 免费色视频在线 | 在线观看免费黄色 | 中文字幕在线高清 | 91成人国产 | 日本中文在线观看 | 亚州精品在线视频 | 精品国产理论片 | 国产精品一区二区三区观看 | 成人a视频 | 九九精品视频在线观看 | 国产日产精品久久久久快鸭 | 国产一区二区在线播放 | 国产成人精品久久久 | 激情五月激情综合网 | 日本三级久久 | 日本精品xxxx | 人人干在线 | 国产福利免费在线观看 | 午夜精品久久久久久久爽 | 国产精品一码二码三码在线 | av中文天堂在线 | 国产伦理久久精品久久久久_ | 丝袜制服综合网 | 美女视频a美女大全免费下载蜜臀 | 国产一级在线 | 婷婷亚洲综合五月天小说 | 日韩三级av | 91精品国产欧美一区二区 | 亚洲国产成人精品电影在线观看 | 日韩在线无 | 国产高清在线观看 | 久久久久女教师免费一区 | 欧美性脚交 | 97视频免费在线观看 | 97超碰国产精品女人人人爽 | 国产成人精品福利 | 日本二区三区在线 | 毛片网站在线观看 | 日本久久不卡视频 | 五月婷婷播播 | 日韩有码第一页 | 人人澡人人草 | 一区二区三区在线视频111 | 精品欧美日韩 | 国产网站色 | 天海翼一区二区三区免费 | 中文字幕日韩电影 | 精品免费观看 | 日韩中文字幕亚洲一区二区va在线 | 天天干天天看 | 视频在线观看一区 | 青青河边草免费观看 | 日韩高清在线看 | 在线观看视频一区二区 | 91精品综合在线观看 | 美女网站视频色 | 国产日本在线观看 | 狠狠狠狠狠狠操 | 黄色小说在线观看视频 | 丁香婷婷色月天 | 三级av小说 | 午夜天使 | 国产精品手机看片 | 国产免费视频一区二区裸体 | 欧美激情一区不卡 | 久精品视频免费观看2 | 国产视频一二三 | 五月激情综合婷婷 | 天天天天爱天天躁 | 丝袜美腿av | 日韩黄色一区 | 天天骚夜夜操 | 国产一级二级在线播放 | 懂色av一区二区在线播放 | 黄色app网站在线观看 | 国产国产人免费人成免费视频 | 亚洲理论在线观看 | 国产精品久久久久久久久久ktv | 日本久久久久久科技有限公司 | 天天操操操操操 | 天天综合狠狠精品 | 欧美一级片在线观看视频 | 日日夜夜人人精品 | 区一区二在线 | 亚洲资源在线 | 久久人人97超碰国产公开结果 | 国产视频在线播放 | 国产亚洲欧美精品久久久久久 | 97超碰中文字幕 | 91成版人在线观看入口 | 激情五月网站 | 人人模人人爽 | 欧美大片mv免费 | 国产精品久久久久久久午夜片 | 国产精品嫩草在线 | 在线播放 日韩专区 | 国产成人av在线 | 在线中文字幕电影 | 九九热免费精品视频 | 久久成人午夜视频 | 五月天九九 | 欧美精品二 | www激情网 | 91热精品 | 蜜臀av性久久久久蜜臀av | 色夜影院 | 亚洲精品视频在线观看免费视频 | 97成人在线观看 | 免费观看一级特黄欧美大片 | 国产色综合天天综合网 | 国产一级不卡视频 | 欧美一级片播放 | 五月天丁香视频 | 亚洲精品国产精品国自产在线 | 久久夜色精品国产欧美乱极品 | 成年人免费观看在线视频 | 91久久国产露脸精品国产闺蜜 | 精品国产免费久久 | 日韩中文字幕在线不卡 | 毛片精品免费在线观看 | 欧美最猛性xxxxx免费 | 99视屏| 精品国产乱码久久久久久天美 | 亚洲精品久久激情国产片 | 国产操在线 | 激情开心色 | 成人欧美亚洲 | 蜜臀av网站 | 精品国产伦一区二区三区观看方式 | 999男人的天堂 | 国产精品美女久久久久久久网站 | 欧美不卡视频在线 | 免费大片黄在线 | 亚洲国产精品va在线看黑人动漫 | av成人在线看| 黄色一级免费 | 国产精品99久久免费观看 | 国产手机av在线 | 国产亚洲精品久 | 亚洲精品久久久久中文字幕m男 | 天天操天天谢 | www激情com | 国产在线视频导航 | 超碰在线人人 | 精品成人久久 | 91精品婷婷国产综合久久蝌蚪 | 亚洲砖区区免费 | 夜夜躁狠狠燥 | 九九热99视频 | 国产视频一区二区在线播放 | 激情久久久久久久久久久久久久久久 | 99久久国产免费,99久久国产免费大片 | 国产亚洲成人精品 | 国产精品嫩草69影院 | 免费网址你懂的 | 亚洲国产欧美在线人成大黄瓜 | 成人黄色大片在线免费观看 | 亚洲专区视频在线观看 | av黄网站 | 精品国产一二三四区 | 97涩涩视频 | 亚洲黄色一级视频 | 亚洲丁香日韩 | 国产成人精品久久二区二区 | 国产美女网站在线观看 | 91精品久久久久久综合乱菊 | 国产精品久久99综合免费观看尤物 | 91精品国产91热久久久做人人 | 日韩有码欧美 | 欧美久久久一区二区三区 | 青春草免费在线视频 | 99精品国产一区二区三区不卡 | 91丨九色丨蝌蚪丰满 | 五月天综合激情 | 国产五月 | 日韩中文字幕免费在线观看 | 99久久99久久 | 欧美国产不卡 | 婷婷色五 | 精品中文字幕在线 | 天天操人人干 | 亚洲欧洲精品一区二区精品久久久 | 黄色av一区二区 | 欧美精品中文在线免费观看 | 国产精品18久久久久久久 | 99婷婷狠狠成为人免费视频 | 色偷偷888欧美精品久久久 | 在线免费观看视频一区二区三区 | 中文字幕第一页在线视频 | 日日草天天草 | 麻豆国产网站入口 | 欧美一区三区四区 | 中文字幕91在线 | a在线观看国产 | 欧美日韩免费观看一区=区三区 | 亚洲成人av在线电影 | 黄色福利网| 毛片无卡免费无播放器 | 干综合网 | 欧美日韩视频免费看 | 国产精品毛片一区二区在线 | 在线成人高清电影 | 视频二区在线 | 91观看视频| 一区二区三区电影 | 国产在线观看免费av | 午夜av一区二区三区 | 五月天高清欧美mv | 日本成人a | 久久精品资源 | 日日操网站 | 日韩精品一区二区三区电影 | 色丁香综合| 免费在线观看国产黄 | 白丝av免费观看 | 成人免费观看网址 | 久久精品亚洲精品国产欧美 | 国产精品成人av电影 | 国产精品 国内视频 | 国产丝袜高跟 | 亚洲精品国偷拍自产在线观看 | 在线观看视频免费播放 | 国内精品久久久久国产 | 久久视频这里有精品 | 久久精品国产一区二区三 | 久草精品视频在线播放 | 久久99在线观看 | 香蕉国产91 | 久久精品亚洲一区二区三区观看模式 | 超碰成人免费电影 | 日韩中文幕 | 欧美日韩一区二区在线观看 | 国产永久免费高清在线观看视频 | 亚洲视频专区在线 | 四月婷婷在线观看 | 日韩精品久久久免费观看夜色 | 中文字幕在线播放日韩 | 国产精品久久久久久久久久久久久久 | av资源免费看 | 亚洲a成人v| 国产激情电影综合在线看 | 97精品国产97久久久久久粉红 | 1024在线看片| 日韩www在线| 日韩在线观看 | 国产91丝袜在线播放动漫 | 日韩,中文字幕 | 国产成人a亚洲精品v | 国产精品久久久久久久av大片 | 欧美极品xxx| 亚洲国产午夜 | 亚洲一区二区视频在线 | 天天操操 | 久久久在线视频 | 久久人人爽人人人人片 | 国产97在线看 | 99热在线精品观看 | 国产精品国产三级在线专区 | 中文字幕第一 | 久久久久久久久久久久国产精品 | 亚洲精品综合一二三区在线观看 | 成人97人人超碰人人99 | 国产在线观看污片 | 亚洲乱码中文字幕综合 | 伊人婷婷色 | 园产精品久久久久久久7电影 | 91视视频在线直接观看在线看网页在线看 | 亚洲精品综合欧美二区变态 | 国产精品自产拍在线观看 | 午夜精品久久久久久久久久久久久久 | www.69xx| 99热手机在线 | 综合色中色 | 亚洲 欧美 另类人妖 | av在线在线| 日韩av线观看 | 97色婷婷成人综合在线观看 | 少妇bbb搡bbbb搡bbbb | 中文字幕乱视频 | 国产伦理精品一区二区 | 91av精品| 国产成人精品日本亚洲999 | 天天爽夜夜爽精品视频婷婷 | 国产精品嫩草影院99网站 | 中文字幕色在线视频 | a午夜电影 | 性色xxxxhd| 黄在线免费看 | 天天干夜夜想 | 成人黄色电影免费观看 | 97国产在线观看 | 亚洲国产中文字幕在线视频综合 | 国产在线精品观看 | 欧美性黑人 | 首页国产精品 | 精品a视频 | 一区av在线播放 | a色网站 | 久久精品一 | 三级黄色a | 天堂av在线免费 | 国产韩国精品一区二区三区 | 99 色 | 日韩在线观看一区二区 | 精品亚洲一区二区三区 | 成人aaa毛片 | 亚洲国产精品视频在线观看 | 日韩欧美高清一区二区三区 | 91高清免费观看 | 深爱婷婷网 | 精品美女视频 | 五月婷婷另类国产 | 日韩精品一区二 | 久久久精品国产一区二区 | 国产精品不卡av | 久久久精品国产免费观看同学 | 日韩高清不卡在线 | 91黄视频在线观看 | 久久久三级视频 | 激情动态| 91麻豆精品国产91久久久久久久久 | 国产精品久久久久久久久久久久午夜 | 精油按摩av| 日韩aa视频 | 欧美精品中文在线免费观看 | 国产一级视屏 | 亚洲精品视频在线观看免费视频 | 久久综合色8888 | 日韩精品欧美精品 | 一区二区三区在线影院 | 婷婷久久丁香 | 福利视频午夜 | 一区三区在线欧 | 91最新国产 | 久av电影| 日韩av资源站 | 81国产精品久久久久久久久久 | 国产不卡av在线播放 | 午夜影院一级 | 欧美日韩国产精品一区二区三区 | av爱干| 91精品视频免费观看 | 狠狠色丁婷婷日日 | 成人久久18免费 | 久久久国产精品成人免费 | 欧美日韩视频免费看 | 亚洲国产中文在线 | 天天干天天干天天射 | 亚洲人人爱 | 欧美天天干 | 亚洲精品裸体 | 999久久国精品免费观看网站 | 伊人宗合网 | 99爱国产精品 | 婷婷网站天天婷婷网站 | 日本美女xx| 久久国产精品二国产精品中国洋人 | 久久精品国产精品亚洲精品 | 91在线精品一区二区 | 亚洲成av人片| 91精品国产高清自在线观看 | 亚洲欧美日韩精品久久奇米一区 | 国产白浆在线观看 | 五月婷婷中文网 | 波多野结衣电影一区二区三区 | 日韩精品免费在线视频 | 免费试看一区 | 夜夜夜夜夜夜操 | 99久热在线精品 | 最新中文字幕 | 99久久超碰中文字幕伊人 | 日本不卡123 | 亚洲国产福利视频 | 久久久久中文 | 国产aaa大片 | 日日骑 | 久久婷婷国产 | 亚洲一区美女视频在线观看免费 | 中文字幕av最新更新 | 91精品在线播放 | 久久国产免费视频 | 99精品国产一区二区三区麻豆 | 手机在线看片日韩 | 99久久精品午夜一区二区小说 | 手机看片1042| 婷婷综合五月 | 一本一本久久a久久精品综合小说 | 免费视频久久久 | 99精品视频在线免费观看 | 亚洲在线精品视频 | 久久综合欧美 | 最近能播放的中文字幕 | 亚洲91精品在线观看 | 国产在线视频导航 | av成人动漫在线观看 | 国产福利91精品一区 | 国产日韩欧美在线免费观看 | 国产精品久免费的黄网站 | 在线观看亚洲国产精品 | 国产免费中文字幕 | 黄色小说网站在线 | 综合网在线视频 | 成人午夜剧场在线观看 | 国产 日韩 中文字幕 | 国产精品成人在线观看 | 久久人人爽爽人人爽人人片av | 国产精品久久久久av | 国产成人精品一二三区 | 久久婷婷国产色一区二区三区 | 91亚瑟视频 | 免费色婷婷 | 在线观看日本高清mv视频 | 在线免费观看一区二区三区 | 国产又粗又猛又黄视频 | av中文字幕网站 | 日韩欧美aaa | 五月开心婷婷网 | 亚洲国产成人精品久久 | 五月天天天操 | 在线观看成人小视频 | 干av在线| 婷婷在线免费视频 | 97免费在线观看视频 | 黄色在线观看免费 | 国产成人精品免高潮在线观看 | 久久久久 免费视频 | 欧美一级黄色视屏 | 一本一本久久a久久精品综合妖精 | 日本免费一二三区 | 国产精品久久9 | 色婷婷av国产精品 | 欧美精品在线观看免费 | 麻豆国产精品视频 | 欧美日韩亚洲在线观看 | 天天操天天干天天 | 久久开心激情 | 99精品偷拍视频一区二区三区 | 国产大片黄色 | 国产精品午夜在线 | 欧美日韩中文国产 | 蜜臀久久99精品久久久无需会员 | 99久久er热在这里只有精品66 | 亚洲精品高清视频 | 国产亚州av| 又黄又色又爽 | 国产亚洲免费的视频看 | 免费看黄色大全 | 99九九免费视频 | 五月婷婷av | 日韩欧美在线视频一区二区 | 天天色综合三 | 操操色| 国产精品欧美一区二区 | 日韩欧美一区二区三区黑寡妇 | 欧美黄色免费 | 一区二区三区中文字幕在线观看 | 国产精品一区二区av麻豆 | 99精品视频在线播放观看 | 国产精品18久久久久白浆 | 日韩成年视频 | 日本久久久久久久久久久 | 一区二区三区四区五区在线视频 | 色婷婷九月 | 久久免费在线观看视频 | 黄色毛片在线观看 | 人人爽影院 | 97在线视频网站 | 在线国产精品视频 | 亚洲免费国产视频 | 免费a网 | 婷婷激情站 | 欧美久久久久久久 | 亚洲午夜剧场 | 一区二区三区动漫 | 一本一本久久a久久精品牛牛影视 | 国产高清免费视频 | 精品国产乱码久久久久久1区二区 | 在线视频久久 | 99久久精品免费看国产一区二区三区 | 国产精品videossex国产高清 | 免费在线观看成人av | 国产探花 | 99国产成+人+综合+亚洲 欧美 | 在线电影日韩 | 久久精品国产一区二区三区 | 蜜桃视频在线视频 | 99精品欧美一区二区蜜桃免费 | 超碰97公开 | 国产精品麻豆免费版 | 久久人人爽人人爽人人 | 四虎永久免费网站 | 操操综合网 | 国产在线欧美在线 | 色国产精品一区在线观看 | 国产18精品乱码免费看 | 免费亚洲黄色 | 国产黄色观看 | 国产一区二区久久久久 | 伊人资源视频在线 | 久9在线| 久久www免费视频 | 99久久99久久精品国产片 | 久久久久一区二区三区 | 中文字幕一区二区在线观看 | 免费观看视频的网站 | 麻豆国产露脸在线观看 | 日韩视频在线观看视频 | 激情综合色综合久久综合 | 天天曰天天干 | 中文字幕在线网 | 日日夜夜精品免费视频 | 成人四虎 | 欧美精品你懂的 | 欧洲视频一区 | 久久综合狠狠综合 | 午夜久操 | 亚洲精品国产品国语在线 | 久久精品久久久久久久 | 色五月激情五月 | 精品久久一二三区 | 丁香花中文字幕 | 亚洲色图美腿丝袜 | 中文字幕在线播放视频 | 久久黄色片子 | 国产一区视频免费在线观看 | av黄色在线观看 | 九九热av | 一级性生活片 | 久久久不卡影院 | 超碰97人人干 | 国产成人av | 中文字幕国产精品 | av三级在线看 | 在线播放 亚洲 | 一级黄毛片 | 欧美一级片在线免费观看 | 在线观看香蕉视频 | 国产精品乱码一区二三区 | 四虎影视成人永久免费观看亚洲欧美 | 在线观看成人小视频 | 视频一区二区国产 | 亚洲精品麻豆视频 | 国产精品电影一区 | 亚洲精品在线观看中文字幕 | av电影一区二区三区 | 狠狠色噜噜狠狠狠合久 | 天天操夜夜摸 | 一区二区三区三区在线 | 国产精品福利在线 | 在线免费中文字幕 | 久久综合影视 | 91精品国产三级a在线观看 | 91成版人在线观看入口 | 色天天中文 | 亚洲精品美女久久17c | 日操干| 国产成人精品亚洲精品 | 国产韩国日本高清视频 | 国产麻豆精品久久一二三 | 欧美激情精品久久久久久变态 | 天堂av在线免费 | 成人91av| 国产 欧美 日产久久 | 亚洲成人av在线电影 | 最新av在线播放 | 亚洲爱av | 色婷婷久久久 | 免费av一级电影 | 国产精品久久免费看 | 久久综合色一综合色88 | 狠狠干婷婷色 | 免费人做人爱www的视 | 国产精品久久久久免费 | 操操操日日 | 91精品视屏| 亚洲永久精品视频 | 国产免费资源 | 国产一区二三区好的 | 国内视频1区 | 国产99久久久久久免费看 | 在线观看久草 | 亚洲国产成人精品在线 | 成人av高清在线 | 色一色在线| 久久视屏网 | 国产精品久久久久永久免费观看 | 国产理论免费 | 天天草天天干天天 | 欧美成年黄网站色视频 | 亚洲成人免费在线观看 | 在线视频观看你懂的 | 99爱爱 | 美女精品 | 亚洲a网 | 91av电影| 国产精品久久久毛片 | 免费网址你懂的 | 超碰在线人 | 五月天激情视频 | 欧美巨大荫蒂茸毛毛人妖 | 一区二区三区免费在线播放 | 欧美性色综合网 | 国产成人精品一区二区三区网站观看 | 不卡视频一区二区三区 | 亚洲精品中文字幕视频 | 日日干 天天干 | 激情五月在线 | 中文字幕一区二区三区四区视频 | 在线看国产视频 | 久久久高清一区二区三区 | 999国内精品永久免费视频 | 日韩在线视频线视频免费网站 | 夜夜操狠狠操 | 99综合电影在线视频 | 激情自拍av | 国产精品视频免费在线观看 | 亚洲视频第一页 | 日韩在线观看视频在线 | 日韩一级黄色大片 | 久久精品小视频 | 日韩欧美在线观看一区二区 | 欧洲一区二区三区精品 | 精品国产自在精品国产精野外直播 | 欧美日韩精品影院 | 蜜臀久久99精品久久久无需会员 | 欧美天天干 | 久久久www成人免费精品 | 日韩一区二区三区观看 | 久草91视频 | 国语精品视频 | 欧美极品少妇xbxb性爽爽视频 | 狠狠夜夜 | 天天射天天干 | 天天干人人干 | 91中文字幕在线观看 | 日韩av成人在线观看 | 久色伊人| 久久国产精品一区二区三区四区 | 黄色的网站在线 | 日韩天堂在线观看 | 国产一区二区电影在线观看 | 亚洲成人在线免费 | 深夜国产福利 | av在线播放国产 | 丁香花在线观看视频在线 | 伊色综合久久之综合久久 | 美女国产精品 | 中文字幕的 | 色婷婷六月天 | 日韩精品一区二区三区不卡 | 久久精品99国产精品亚洲最刺激 | 久久高清av | av免费看在线 | 久久久99精品免费观看app | 黄色小网站免费看 | 国产精品久99 | 久草国产在线观看 | 日韩精品高清视频 | 亚洲开心激情 | www.国产在线 | 美女久久精品 | 91精品婷婷国产综合久久蝌蚪 | 男女日麻批 | 成年免费在线视频 | 麻豆国产精品视频 | 国产视频精选在线 | 99久久精品免费看国产麻豆 | 欧美国产日韩一区二区 | 日韩专区在线 | 日日日天天天 | 丁香花在线视频观看免费 | 97操操操| 人人爽人人香蕉 | 天天综合网久久 | 婷婷视频在线播放 | 久久久久女教师免费一区 | 免费高清在线一区 | 国产麻豆成人传媒免费观看 | 2019中文最近的2019中文在线 | 成人黄视频 | 狠狠干婷婷色 | 日本性生活一级片 | 黄色亚洲大片免费在线观看 | 国产成人在线精品 | 久草手机视频 | 日韩一级黄色片 | 亚洲3级| 日韩精品中文字幕在线观看 | 麻豆 videos | av免费在线观看网站 | 日韩中文字幕视频在线 | 91热视频在线观看 | 在线精品视频免费播放 | 亚洲精品国产高清 | 91成人网在线观看 | a午夜在线 | 久久久久久美女 | 中文在线最新版天堂 | 毛片黄色一级 | 亚洲黄色高清 | 国产小视频在线播放 | 五月婷在线观看 | 婷婷在线不卡 | 天天草天天爽 | 精品国产自 | 在线观看mv的中文字幕网站 | 久久亚洲免费 | 99日精品| 国产福利在线免费 | 欧美精品色| 国产在线91在线电影 | 天天摸日日摸人人看 | 91在线视频在线 | 婷婷色影院| 亚洲精品视频免费观看 | 四虎永久免费网站 | 久久久久国产成人精品亚洲午夜 | wwwav视频| 成人一区二区三区在线观看 | av先锋中文字幕 | 91毛片在线观看 | a黄色影院 | 在线观看91视频 | 狠狠狠狠狠色综合 | 久操伊人 | 成人在线一区二区 | 成年人免费看av | 欧美日韩国产二区三区 | 亚洲人成在线观看 | 91视频在线网址 | 国产精品一区免费观看 | 日韩在线视频一区 | av在线免费在线 | 欧美一级性 | 少妇18xxxx性xxxx片| 日日干天天爽 | 黄色av一区二区 | 亚洲精品福利视频 | 国产精品一区二区久久 | 在线视频日韩欧美 | 美女网站在线观看 | 国产一区在线免费 | 91尤物国产尤物福利在线播放 | 天天爱天天操天天干 | 蜜桃麻豆www久久囤产精品 | 69国产成人综合久久精品欧美 | av 一区二区三区 | 一区二区三区影院 | 免费成人av网站 | 91免费网| 91福利视频在线 | 国产九色91| 欧美精品v国产精品v日韩精品 | 黄色成人av | 中文日韩在线视频 | 在线看片成人 | 色综合久久88色综合天天免费 | 亚洲毛片在线观看. | 免费的黄色的网站 | 美女视频黄是免费的 | 婷婷综合五月天 | 国产1区2区3区精品美女 | 欧美午夜精品久久久久久浪潮 | 粉嫩一区二区三区粉嫩91 | 免费观看www视频 | 999久久久免费视频 午夜国产在线观看 | 久草观看视频 | 国产综合婷婷 | 亚洲精品视频免费观看 | 偷拍视频一区 | 日本黄色免费电影网站 | 超级碰99| 最近日韩免费视频 | 九九九九热精品免费视频点播观看 | 国产在线精品视频 | 国产99视频在线观看 | 十八岁以下禁止观看的1000个网站 | 国产精品国产自产拍高清av | a级国产乱理论片在线观看 伊人宗合网 | 免费观看性生活大片3 | 国产日产欧美在线观看 | 中国老女人日b | 中文在线a∨在线 | 午夜国产一区二区三区四区 | 在线观看一 | 91av在线电影 | 国产最顶级的黄色片在线免费观看 | 99久久精品免费看国产麻豆 | 免费欧美 | 日本丰满少妇免费一区 | 97视频在线免费播放 | 349k.cc看片app| 亚洲一区免费在线 | 人人爽人人乐 | 91av社区| 6080yy精品一区二区三区 | www久久| 成人资源站 | 最近中文字幕国语免费av | 99热这里只有精品久久 | 精品久久久久久久久久久久久久久久 | 亚洲理论电影 | 亚洲精品视频免费在线 | 天天曰天天曰 |