精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JavaScript代碼優(yōu)化技巧

開發(fā) 前端
本文主要討論了JavaScript代碼性能優(yōu)化的技巧。許多JavaScript代碼的性能沒有達(dá)到最佳,主要是因?yàn)闆]有進(jìn)行適當(dāng)?shù)膬?yōu)化。

我經(jīng)常覺得JavaScript代碼通常運(yùn)行得慢僅僅是因?yàn)樗鼪]有得到適當(dāng)?shù)膬?yōu)化。下面是我發(fā)現(xiàn)有用的常用優(yōu)化技術(shù)的總結(jié)。

性能優(yōu)化的權(quán)衡通常是可讀性,因此何時(shí)選擇性能還是可讀性是留給讀者的問題。討論優(yōu)化必然需要討論基準(zhǔn)測(cè)試。如果一個(gè)函數(shù)只代表了實(shí)際運(yùn)行時(shí)間的一小部分,那么花幾個(gè)小時(shí)對(duì)函數(shù)進(jìn)行微優(yōu)化以使其運(yùn)行速度提高100倍是毫無意義的。如果要進(jìn)行優(yōu)化,第一步也是最重要的一步是基準(zhǔn)測(cè)試。

我已經(jīng)為所有的場(chǎng)景提供了可運(yùn)行的示例。默認(rèn)顯示的是在我的機(jī)器上得到的結(jié)果(brave 122 on archlinux),你可以自己運(yùn)行它們。這里不建議使用Firefox上的結(jié)果作為參考指標(biāo)。

1.避免字符串比較

如果你需要在C中比較字符串,你可以使用strcmp(a, b)函數(shù)。JavaScript使用===,所以你看不到strcmp。但是它在那里,字符串比較通常需要將字符串中的每個(gè)字符與另一個(gè)字符串中的字符進(jìn)行比較,字符串比較是O(n)。要避免的一種常見JavaScript模式是字符串枚舉。但隨著TypeScript的出現(xiàn),這應(yīng)該很容易避免,因?yàn)槊杜e默認(rèn)為整數(shù)。

以下是比較成本:

// 1. string compare
const Position = {
  TOP: 'TOP',
  BOTTOM: 'BOTTOM',
}
 
let _ = 0
for (let i = 0; i < 1000000; i++) {
  let current = i % 2 === 0 ?
    Position.TOP : Position.BOTTOM
  if (current === Position.TOP)
    _ += 1
}
// 2. int compare
const Position = {
  TOP: 0,
  BOTTOM: 1,
}
 
let _ = 0
for (let i = 0; i < 1000000; i++) {
  let current = i % 2 === 0 ?
    Position.TOP : Position.BOTTOM
  if (current === Position.TOP)
    _ += 1
}

圖片


關(guān)于基準(zhǔn): 百分比結(jié)果表示在1秒內(nèi)完成的操作數(shù)除以最高得分案例的操作數(shù)。越高越好。

正如你所看到的,差異可能很大。這種差異并不一定是由于strcmp成本,因?yàn)橐嬗袝r(shí)可以使用字符串池并通過引用進(jìn)行比較,但這也是由于整數(shù)通常在JS引擎中通過值傳遞,而字符串總是作為指針傳遞,并且內(nèi)存訪問是昂貴的。在字符串密集的代碼中,這可能會(huì)產(chǎn)生巨大的影響。

2.避免不同的shapes

JavaScript引擎試圖通過假設(shè)對(duì)象具有特定形狀來優(yōu)化代碼,并且函數(shù)將接收相同形狀的對(duì)象。這允許它們?yōu)樵撔螤畹乃袑?duì)象存儲(chǔ)該形狀的鍵一次,并將值存儲(chǔ)在單獨(dú)的平面數(shù)組中。用JavaScript表示:

const objects = [
  {
    name: 'Anthony',
    age: 36,
  },
  {
    name: 'Eckhart',
    age: 42
  },
]

=> 

const shape = [
  { name: 'name', type: 'string' },
  { name: 'age',  type: 'integer' },
]
 
const objects = [
  ['Anthony', 36],
  ['Eckhart', 42],
]


我使用了“ shapes 形狀”這個(gè)詞來描述這個(gè)概念,但要注意,您可能也會(huì)發(fā)現(xiàn)“隱藏類”或“映射”用于描述它。

例如運(yùn)行時(shí),如果下面的函數(shù)接收到兩個(gè)具有形狀{ x: number, y: number }的對(duì)象,則引擎將推測(cè)未來的對(duì)象將具有相同的形狀,并生成針對(duì)該形狀優(yōu)化的機(jī)器代碼。

function add(a, b) {
  return {
    x: a.x + b.x,
    y: a.y + b.y,
  }
}

如果傳遞的對(duì)象不是形狀{ x, y }而是形狀{ y, x },則引擎將需要撤銷其推測(cè),并且函數(shù)將突然變得相當(dāng)慢。我要強(qiáng)調(diào)的是,V8特別有3種模式用于訪問:?jiǎn)螒B(tài)(1個(gè)形狀),多態(tài)(2-4個(gè)形狀),和megamorphic(5+形狀)。

// setup
let _ = 0

// 1. monomorphic
const o1 = { a: 1, b: _, c: _, d: _, e: _ }
const o2 = { a: 1, b: _, c: _, d: _, e: _ }
const o3 = { a: 1, b: _, c: _, d: _, e: _ }
const o4 = { a: 1, b: _, c: _, d: _, e: _ }
const o5 = { a: 1, b: _, c: _, d: _, e: _ } // all shapes are equal

// 2. polymorphic
const o1 = { a: 1, b: _, c: _, d: _, e: _ }
const o2 = { a: 1, b: _, c: _, d: _, e: _ }
const o3 = { a: 1, b: _, c: _, d: _, e: _ }
const o4 = { a: 1, b: _, c: _, d: _, e: _ }
const o5 = { b: _, a: 1, c: _, d: _, e: _ } // this shape is different

// 3. megamorphic
const o1 = { a: 1, b: _, c: _, d: _, e: _ }
const o2 = { b: _, a: 1, c: _, d: _, e: _ }
const o3 = { b: _, c: _, a: 1, d: _, e: _ }
const o4 = { b: _, c: _, d: _, a: 1, e: _ }
const o5 = { b: _, c: _, d: _, e: _, a: 1 } // all shapes are different

// test case
function add(a1, b1) {
  return a1.a + a1.b + a1.c + a1.d + a1.e +
         b1.a + b1.b + b1.c + b1.d + b1.e }
 
let result = 0
for (let i = 0; i < 1000000; i++) {
  result += add(o1, o2)
  result += add(o3, o4)
  result += add(o4, o5)
}

圖片

3.避免使用數(shù)組/對(duì)象方法

我和其他人一樣喜歡函數(shù)式編程,但是除非你在Haskell/OCaml/Rust中工作,函數(shù)式代碼被編譯成高效的機(jī)器代碼,否則函數(shù)式總是比命令式慢。

// setup:
const numbers = Array.from({ length: 10_000 }).map(() => Math.random())

// 1. functional
const result =
  numbers
    .map(n => Math.round(n * 10))
    .filter(n => n % 2 === 0)
    .reduce((a, n) => a + n, 0)
    
// 2. imperative
let result = 0
for (let i = 0; i < numbers.length; i++) {
  let n = Math.round(numbers[i] * 10)
  if (n % 2 !== 0) continue
  result = result + n
}

Object.values()Object.keys()Object.entries()這樣的對(duì)象方法也有類似的問題,因?yàn)樗鼈円卜峙淞烁嗟臄?shù)據(jù),而內(nèi)存訪問是所有性能問題的根源。

4.避免代理

另一個(gè)尋找優(yōu)化收益的地方是避免任何間接來源,通過以下數(shù)據(jù)可以看出差距。

// 1. proxy access
const point = new Proxy({ x: 10, y: 20 }, { get: (t, k) => t[k] })
 
for (let _ = 0, i = 0; i < 100_000; i++) { _ += point.x }

// 2. direct access
const point = { x: 10, y: 20 }
const x = point.x
 
for (let _ = 0, i = 0; i < 100_000; i++) { _ += x }

另外一個(gè)是訪問深度嵌套對(duì)象與直接訪問的對(duì)比:

// 1. nested access
const a = { state: { center: { point: { x: 10, y: 20 } } } }
const b = { state: { center: { point: { x: 10, y: 20 } } } }
const get = (i) => i % 2 ? a : b

let result = 0
for (let i = 0; i < 100_000; i++) {
  result = result + get(i).state.center.point.x 
}
  
// 2. direct access
const a = { x: 10, y: 20 }.x
const b = { x: 10, y: 20 }.x
const get = (i) => i % 2 ? a : b
 
let result = 0
for (let i = 0; i < 100_000; i++) {
  result = result + get(i) 
}

5.避免未命中緩存

這一點(diǎn)需要一些低級(jí)的知識(shí),但即使在JavaScript中也有含義。從CPU的角度來看,從RAM中檢索內(nèi)存是很慢的。為了加快速度,它主要使用兩種優(yōu)化。

5.1 預(yù)取

第一個(gè)是預(yù)取:它提前獲取更多的內(nèi)存,希望它是你需要的內(nèi)存。它會(huì)猜測(cè)你請(qǐng)求一個(gè)內(nèi)存地址后,你會(huì)對(duì)緊接著的內(nèi)存區(qū)域有需要。所以順序訪問數(shù)據(jù)是關(guān)鍵。在下面的例子中,我們可以觀察到以隨機(jī)順序訪問內(nèi)存的影響。

// setup:
const K = 1024
const length = 1 * K * K
 
// Theses points are created one after the other, so they are allocated
// sequentially in memory.
const points = new Array(length)
for (let i = 0; i < points.length; i++) {
  points[i] = { x: 42, y: 0 }
}
 
// This array contains the *same data* as above, but shuffled randomly.
const shuffledPoints = shuffle(points.slice())
// 1. sequential
let _ = 0
for (let i = 0; i < points.length; i++) { _ += points[i].x }

// 2. random
let _ = 0
for (let i = 0; i < shuffledPoints.length; i++) { _ += shuffledPoints[i].x }

5.2 緩存在L1/2/3

CPU使用的第二個(gè)優(yōu)化是L1/L2/L3緩存:它們就像更快的RAM,但它們也更昂貴,所以它們要小得多。它們包含RAM數(shù)據(jù),但充當(dāng)LRU緩存。當(dāng)新的工作數(shù)據(jù)需要空間時(shí),數(shù)據(jù)被寫回主RAM。因此,這里的關(guān)鍵是使用盡可能少的數(shù)據(jù)來將工作數(shù)據(jù)集保留在快速緩存中。在下面的例子中,我們可以觀察到破壞每個(gè)連續(xù)緩存的效果。

// setup:
const KB = 1024
const MB = 1024 * KB
 
const L1  = 256 * KB
const L2  =   5 * MB
const L3  =  18 * MB
const RAM =  32 * MB
 
const buffer = new Int8Array(RAM)
buffer.fill(42)
 
const random = (max) => Math.floor(Math.random() * max)
// 1. L1
let r = 0; for (let i = 0; i < 100000; i++) { r += buffer[random(L1)] }

// 2. L2
let r = 0; for (let i = 0; i < 100000; i++) { r += buffer[random(L2)] }

// 3. L3
let r = 0; for (let i = 0; i < 100000; i++) { r += buffer[random(L3)] }

// 4. RAM
let r = 0; for (let i = 0; i < 100000; i++) { r += buffer[random(RAM)] }

盡可能的去除每一個(gè)可以消除的數(shù)據(jù)或內(nèi)存分配。數(shù)據(jù)集越小,程序運(yùn)行的速度就越快。內(nèi)存I/O是95%程序的瓶頸。另一個(gè)好的策略是將您的工作分成塊,并確保您一次處理一個(gè)小數(shù)據(jù)集。

6.避免大型對(duì)象

如第2節(jié)所述,引擎使用固定形狀來優(yōu)化對(duì)象。然而當(dāng)對(duì)象變得太大時(shí),引擎別無選擇,只能使用常規(guī)的散列表(如Map對(duì)象)。正如我們?cè)诘?節(jié)中看到的,緩存未命中會(huì)顯著降低性能。哈希圖很容易出現(xiàn)這種情況,因?yàn)樗鼈兊臄?shù)據(jù)通常隨機(jī)均勻地分布在它們所占用的內(nèi)存區(qū)域中。

// setup:
const USERS_LENGTH = 1_000

// setup:
const byId = {}
Array.from({ length: USERS_LENGTH }).forEach((_, id) => {
  byId[id] = { id, name: 'John'}
})
let _ = 0

// 1. [] access
Object.keys(byId).forEach(id => { _ += byId[id].id })

// 2. direct access
Object.values(byId).forEach(user => { _ += user.id })

圖片

我們還可以觀察到性能如何隨著對(duì)象大小的增加而不斷下降:

// setup:
const USERS_LENGTH = 100_000

圖片

如上所述,避免頻繁索引大型對(duì)象。最好事先將對(duì)象轉(zhuǎn)換為數(shù)組。組織數(shù)據(jù)以在模型上包含 ID 會(huì)有所幫助,因?yàn)槟梢允褂?code style="background-color: rgb(231, 243, 237); padding: 1px 3px; border-radius: 4px; overflow-wrap: break-word; text-indent: 0px; display: inline-block;">Object.values()而不必引用鍵映射來獲取ID。

7.使用eval

有一些JavaScript很難為引擎優(yōu)化,通過使用eval()或其衍生物可以進(jìn)行優(yōu)化。在這個(gè)例子中,我們可以觀察到使用eval()如何避免使用動(dòng)態(tài)對(duì)象鍵創(chuàng)建對(duì)象的成本:

// setup:
const key = 'requestId'
const values = Array.from({ length: 100_000 }).fill(42)
// 1. without eval
function createMessages(key, values) {
  const messages = []
  for (let i = 0; i < values.length; i++) {
    messages.push({ [key]: values[i] })
  }
  return messages
}
 
createMessages(key, values)

// 2. with eval
function createMessages(key, values) {
  const messages = []
  const createMessage = new Function('value',
    `return { ${JSON.stringify(key)}: value }`
  )
  for (let i = 0; i < values.length; i++) {
    messages.push(createMessage(values[i]))
  }
  return messages
}
 
createMessages(key, values)

圖片

關(guān)于eval()的常見警告適用于:不要相信用戶輸入,清理傳入eval()代碼的任何內(nèi)容,不要?jiǎng)?chuàng)建任何XSS可能性。還要注意,某些環(huán)境不允許訪問eval(),例如帶有CSP的瀏覽器頁面。

8.數(shù)據(jù)結(jié)構(gòu)

我不會(huì)詳細(xì)介紹數(shù)據(jù)結(jié)構(gòu),因?yàn)樗鼈冃枰獑为?dú)說明。但是請(qǐng)注意,為您的用例使用不正確的數(shù)據(jù)結(jié)構(gòu)可能會(huì)比上面的任何優(yōu)化都產(chǎn)生更大的影響。我建議你熟悉本地的,比如Map和Set,并學(xué)習(xí)鏈表,優(yōu)先級(jí)隊(duì)列,樹(RB和B+)。

作為一個(gè)快速的例子,讓我們比較一下Array.includesSet.has在一個(gè)小列表中的表現(xiàn):

// setup:
const userIds = Array.from({ length: 1_000 }).map((_, i) => i)
const adminIdsArray = userIds.slice(0, 10)
const adminIdsSet = new Set(adminIdsArray)
// 1. Array
let _ = 0
for (let i = 0; i < userIds.length; i++) {
  if (adminIdsArray.includes(userIds[i])) { _ += 1 }
}

// 2. Set
let _ = 0
for (let i = 0; i < userIds.length; i++) {
  if (adminIdsSet.has(userIds[i])) { _ += 1 }
}

圖片

正如你所看到的,數(shù)據(jù)結(jié)構(gòu)的選擇產(chǎn)生了非常大的影響。

最后

本文主要討論了JavaScript代碼性能優(yōu)化的技巧。許多JavaScript代碼的性能沒有達(dá)到最佳,主要是因?yàn)闆]有進(jìn)行適當(dāng)?shù)膬?yōu)化。

在優(yōu)化時(shí)要考慮性能和可讀性之間的權(quán)衡,并建議在優(yōu)化前進(jìn)行基準(zhǔn)測(cè)試。也要考慮實(shí)際的運(yùn)行環(huán)境,并使用合適的工具和方法來測(cè)試和驗(yàn)證優(yōu)化效果。希望你能學(xué)到一些有用的技巧。

責(zé)任編輯:武曉燕 來源: 南城大前端
相關(guān)推薦

2020-12-17 07:52:38

JavaScript

2022-07-04 08:51:43

條件語句JavaScript

2022-08-31 12:15:09

JavaScript代碼優(yōu)化

2012-07-23 10:22:15

Python性能優(yōu)化優(yōu)化技巧

2011-06-14 11:14:10

性能優(yōu)化代碼

2011-07-13 09:46:23

javaScript

2015-09-15 08:30:23

Android代碼優(yōu)化

2022-11-28 23:44:26

JavaScript技巧程序員

2022-02-25 23:46:54

JavaScript網(wǎng)站開發(fā)

2011-09-29 09:50:44

JavaScript

2009-11-27 13:24:20

PHP代碼性能優(yōu)化

2015-09-16 14:47:14

Android性能優(yōu)化代碼

2011-03-01 16:08:46

2024-09-26 08:36:11

JavaScript性能優(yōu)化

2022-11-24 10:34:05

CSS前端

2024-09-26 15:00:06

2022-03-10 08:01:06

CSS技巧選擇器

2023-10-10 10:57:12

JavaScript代碼優(yōu)化

2023-05-04 23:54:02

JavaScrip代碼技巧

2020-09-26 21:50:26

JavaScript代碼開發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧美成人三级电影在线| 国产999精品久久久久久| 国产欧美日韩精品一区二区免费 | 蜜臀av.com| 国产老女人乱淫免费| 亚洲一区 二区 三区| 精品精品国产高清a毛片牛牛| 三上悠亚久久精品| 国产在线视频网站| 久久国产免费看| 久久夜色精品亚洲噜噜国产mv | 国产一区二区中文字幕免费看| 国产成人愉拍精品久久| 国产免费久久| 日韩一级黄色片| 91九色丨porny丨国产jk| 欧洲天堂在线观看| 日韩黄色片在线观看| 日韩一区二区三区国产| 日本不卡视频一区| 素人啪啪色综合| 一区二区三区免费在线观看| 一区二区在线视频播放| 日韩亚洲欧美成人| 免费不卡av网站| 中文不卡1区2区3区| 国产清纯美女被跳蛋高潮一区二区久久w| 成人观看高清在线观看免费| 亚欧视频在线观看| 亚洲91精品| 亚洲美女性视频| 亚洲国产欧美日韩在线| 日本久久免费| 亚洲一区二区三区国产| 神马影院我不卡午夜| 黄色aaa大片| 黑人巨大精品欧美一区| 欧美激情视频一区二区| 亚洲a∨无码无在线观看| 澳门成人av| 欧美精品777| 欧美成人黑人猛交| sm捆绑调教国产免费网站在线观看| 国产亚洲成av人在线观看导航| 97se国产在线视频| 中文在线观看免费高清| 亚洲欧美日韩国产一区| 亚洲欧洲av一区二区| 中文字幕天堂av| 国产精品va视频| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 免费看日b视频| 二区三区在线观看| 国产精品色眯眯| 欧洲高清一区二区| 污污网站在线免费观看| 成人综合在线网站| 91手机在线播放| 一区二区国产欧美| 日韩不卡在线观看日韩不卡视频| 性欧美激情精品| 亚洲视频精品在线| 人人妻人人添人人爽欧美一区| gogo在线高清视频| 亚洲欧洲成人精品av97| 亚洲看片网站| av电影在线网| 中文字幕在线观看不卡视频| 五码日韩精品一区二区三区视频| 国产精品久久久久一区二区国产| 91原创在线视频| 精品无码久久久久国产| 少妇一区二区三区四区| 成人av网址在线| 国产精品久久久久久久久久直播 | 亚洲久久在线| 久久免费视频在线| 久久久久久久久久99| 欧美另类专区| 欧美激情精品久久久久久大尺度| 日韩欧美在线视频播放| 97精品97| 欧美大尺度激情区在线播放 | 一区二区三区四区乱视频| 伊人色综合影院| 大片免费在线看视频| 亚洲精品久久嫩草网站秘色| 精品国产无码在线| 日本aa在线| 天天影视涩香欲综合网| 免费看欧美一级片| 精精国产xxxx视频在线中文版 | 亚洲白虎美女被爆操| 黄色在线免费播放| 精品人妻一区二区乱码| 色婷婷成人在线| 日韩另类视频| 91国产福利在线| 亚洲精品高清无码视频| 国精产品一区二区三区| 先锋欧美三级| 欧美丰满嫩嫩电影| 年下总裁被打光屁股sp| 日韩欧美ww| 亚洲一区二区国产| 国产一二三四区| 亚洲伦理精品| 国产精品日韩在线一区| 国内精品久久久久久久久久久 | 91黑丝在线观看| 91精品国产高清一区二区三密臀| 日韩高清不卡一区二区| 国产精品色视频| 超碰福利在线观看| 久久天天做天天爱综合色| 一区二区在线中文字幕电影视频| 婷婷在线播放| 日本高清不卡aⅴ免费网站| 中文字幕线观看| 911亚洲精品| 宅男66日本亚洲欧美视频| 青青草手机在线观看| 国产免费成人| **亚洲第一综合导航网站| 蝌蚪视频在线播放| 真实原创一区二区影院| heyzo在线欧美播放| 男人天堂资源在线| 日本妇乱大交xxxxx| 色爱综合av| 日韩最新在线视频| 日干夜干天天干| 久久er99精品| 麻豆成人在线播放| 怡红院av在线| 欧美中文字幕一区| 涩视频在线观看| 999国产精品999久久久久久| 日本不卡视频在线播放| 性猛交富婆╳xxx乱大交天津| 天使と恶魔の榨精在线播放| 精品一区二区三区香蕉蜜桃| 精品欧美一区二区久久久伦| 超碰在线观看免费| 在线观看亚洲精品视频| 亚洲高清无码久久| 精品国产一区探花在线观看| 欧美精品videossex性护士| 一区二区三区免费观看视频| 久久久久久久久久美女| 国产在线播放观看| 日韩中文字幕无砖| 综合久久五月天| 天堂网一区二区| 91视视频在线直接观看在线看网页在线看| 欧洲精品视频在线| 午夜精品久久久久久毛片| 国产亚洲精品久久久| 欧美激情黑白配| 99精品一区二区三区| 可以看毛片的网址| 136国产福利精品导航网址应用| 久久亚洲精品成人| 97国产精品久久久| 国产精品成人一区二区艾草 | 久久久久久久久久久久久久久久久久av| 亚洲在线观看av| 中文字幕欧美日韩一区| 日韩一级免费在线观看| 精品在线99| 国产精品久久久久久av| 五月婷婷在线观看| 欧美日本精品一区二区三区| 多男操一女视频| 国产一区二区三区免费看 | 日韩免费高清| 国产精品自产拍在线观看| 91精品大全| 日韩一级在线观看| 久久一级黄色片| 国产乱淫av一区二区三区| 午夜久久久久久久久久久| 日韩成人精品| 97视频网站入口| 黄色小视频在线免费观看| 一道在线中文一区二区三区| 中文字幕亚洲综合久久| 亚洲欧美日韩一区二区三区四区| 久久久久久久av麻豆果冻| 午夜激情福利在线| 99精品综合| 99久久精品无码一区二区毛片 | 亚洲欧美日本国产| 国内精品久久久久影院 日本资源| 三级小视频在线观看| 亚洲成人动漫一区| 亚洲精品成人无码熟妇在线| 免费成人在线影院| 男女裸体影院高潮| 日韩高清一级| 国产精品偷伦免费视频观看的| а√天堂官网中文在线| 欧美一区二区三区不卡| 国产极品在线播放| 国产亚洲一区二区在线观看| 小早川怜子一区二区三区| 在线国产日韩| 日韩中文不卡| www.豆豆成人网.com| 国产成人自拍视频在线观看| 国产1区在线| 亚洲男人的天堂在线| 国产视频一二三四区| 香蕉成人伊视频在线观看| 免费视频91蜜桃| 国产成人精品一区二区三区四区| 777久久久精品一区二区三区 | 神马影院一区二区三区| 亚洲视频精选| 国产精品久久久久久久久久久久久久| 污污的视频在线观看| 国产午夜精品一区二区三区| 亚洲国产综合网| 精品视频免费在线| 99精品视频99| 亚洲欧美偷拍另类a∨色屁股| 特级西西人体wwwww| 国产制服丝袜一区| 老熟妇仑乱视频一区二区| 成人精品视频| 丝袜美腿亚洲一区二区图片| 奇米色一区二区三区四区| 精品亚洲永久免费精品| 亚洲一级视频在线观看| 久久久人成影片免费观看| 日韩暖暖在线视频| 欧洲在线视频| 中文字幕亚洲天堂| 五月天久久久久久| 日韩一区二区免费高清| 黄页网站免费观看| 91综合久久爱com| 国产成人精品视频在线观看| 色综合久久影院| 日韩精品免费视频| 亚洲精品国产精品国| 欧美肥妇毛茸茸| 国产91av在线播放| 欧美日韩亚洲视频| 国产在线拍揄自揄拍| 亚洲欧美色一区| 国产成人免费在线观看视频| 久久精品人人做| 天堂久久久久久| yourporn久久国产精品| 精品人妻一区二区三| 精品在线一区二区三区| 最近中文字幕一区二区| 久久精品官网| 日韩视频第二页| 精品69视频一区二区三区Q| 福利在线小视频| 国产精品99久久久久久动医院| 亚洲mv在线看| 成人羞羞网站| 亚洲乱码一区二区三区| 成人羞羞动漫| 亚洲一区二区三区精品动漫| 日韩成人激情| 精品久久免费观看| 一区二区国产在线| 成人在线免费观看网址| 亚洲欧美一级二级三级| 欧美一级黄色录像片| 午夜国产精品视频免费体验区| www国产无套内射com| 欧美色图首页| av网站手机在线观看| 亚洲黄色av| www.com毛片| 视频在线观看国产精品| 无码人妻精品一区二区三区在线| 国产精品综合色区在线观看| 欧美视频第三页| 国产精久久一区二区| 成人免费视频网址| 一区二区日韩| 日产精品一线二线三线芒果| 天天影视欧美综合在线观看| 美女黄色免费看| 久久男女视频| 操人视频免费看| 久久综合色鬼综合色| 特级西西人体高清大胆| 亚洲自拍另类综合| 人人妻人人爽人人澡人人精品 | 中文字幕乱码视频| 91麻豆精品国产无毒不卡在线观看| 国产 日韩 欧美 精品| 亚洲视频一区二区三区| 中文精品在线观看| 乱精品一区字幕二区| 日韩在线观看一区| 欧美日韩一二区| 亚洲精品偷拍视频| av免费在线观看不卡| 亚洲情侣在线| 欧美xxxx在线观看| 日韩精品一区二区免费| 亚洲av无码一区二区乱子伦| 欧美一区二区三区久久精品| 欧美日本高清视频在线观看| 国产精品一区二区免费看| 日韩国产第一页| 日本精品不卡| 国产精品久久久久久久裸模| 海角国产乱辈乱精品视频| 国产高清视频免费在线观看| 亚洲一区二区欧美日韩| 又色又爽又黄无遮挡的免费视频| 亚洲国产精品中文| 3d玉蒲团在线观看| 国产精品欧美激情在线播放| 国产中文字幕在线播放| 精品国产乱码久久久久久天美 | 中文字幕 亚洲一区| 国产 日韩 欧美 综合 一区| 亚洲欧洲一二三| 午夜亚洲影视| 亚洲色图欧美另类| 亚洲欧洲性图库| 中文字幕一区二区免费| 亚洲美女av在线| 黄频免费在线观看| 国产精品免费一区二区三区四区| 一区二区三区毛片免费| 欧美成人三级在线播放| 国产日韩欧美在线一区| 特级毛片www| 日韩电影大片中文字幕| 17videosex性欧美| 福利视频久久| 欧美日韩岛国| 欧美一级片在线免费观看| 亚洲精品中文在线影院| 97视频免费在线| 精品国产拍在线观看| 欧美成人xxxx| 一区二区三区四区久久| 激情深爱一区二区| 希岛爱理中文字幕| 欧美一区二区三区精品| 性欧美猛交videos| 99re热精品| 伊人久久亚洲热| 国产精品麻豆入口| 欧美视频在线免费| 视频午夜在线| 国产精品久久久久久久久久免费 | 最近2019好看的中文字幕免费| 亚洲成人av观看| 亚洲精品一区二区三区四区五区| 麻豆精品视频在线观看视频| 多男操一女视频| 日韩免费高清av| 国产社区精品视频| 蜜桃av色综合| 日本午夜精品视频在线观看| 成人性视频免费看| 欧美一级在线视频| 99热99re6国产在线播放| 久久偷看各类wc女厕嘘嘘偷窃| 久久中文字幕一区二区三区| 激情五月激情综合| 欧美一区二区三区日韩| 成av人片在线观看www| 久久婷婷人人澡人人喊人人爽| 日韩精品一级中文字幕精品视频免费观看| 国产成人一区二区在线观看| 在线成人av网站| 96av在线| 亚洲精品成人久久久998| 国产酒店精品激情| 日韩手机在线观看| 中文字幕亚洲在线| 成人动态视频| 久久精品视频网站| 麻豆影院在线观看| 国产一级精品aaaaa看| 久久精品亚洲| 乱h高h女3p含苞待放| 亚洲精品久久久久久下一站 | 国产精品毛片一区视频| 麻豆九一精品爱看视频在线观看免费| 香蕉久久久久久久| 欧美精品一区二区三区蜜桃视频| 日本另类视频| 五十路熟女丰满大屁股| 国产精品久久久久久久久免费丝袜 | 欧美午夜电影网|