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

為什么有些時候 Python 中乘法比位運算更快

開發 后端
某天,一個技術群里老哥提出了這樣一個問題,為什么在一些情況下,Python 中的簡單乘/除法比位運算要慢。

我本來以為我不再會寫水文了,但是突然發現自己現在也只能勉強寫寫水文才能維持生活這樣子。那就繼續寫水文吧!

某天,一個技術群里老哥提出了這樣一個問題,為什么在一些情況下,Python 中的簡單乘/除法比位運算要慢。

首先秉持著實事求是的精神,我們先來驗證一下:

  1. In [33]: %timeit 1073741825*2                                                                                                                                                                                                                                                                            
  2. 7.47 ns ± 0.0843 ns per loop (mean ± std. dev. of 7 runs, 100000000 loops each) 
  3.  
  4. In [34]: %timeit 1073741825<<1                                                                                                                                                                                                                                                                           
  5. 7.43 ns ± 0.0451 ns per loop (mean ± std. dev. of 7 runs, 100000000 loops each) 
  6.  
  7. In [35]: %timeit 1073741823<<1                                                                                                                                                                                                                                                                           
  8. 7.48 ns ± 0.0621 ns per loop (mean ± std. dev. of 7 runs, 100000000 loops each) 
  9.  
  10. In [37]: %timeit 1073741823*2                                                                                                                                                                                                                                                                            
  11. 7.47 ns ± 0.0564 ns per loop (mean ± std. dev. of 7 runs, 100000000 loops each) 

我們發現幾個很有趣的現象:

  • 在值 x<=2^30 時,乘法比直接位運算要快
  • 在值 x>2^32 時,乘法顯著慢于位運算

這個現象很有趣,那么這個現象的 root cause 是什么?實際上這和 Python 底層的實現有關。

簡單聊聊

1. PyLongObject 的實現

在 Python 2.x 時期,Python 中將整型分為兩類,一類是 long, 一類是 int 。在 Python3 中這兩者進行了合并。目前在 Python3 中這兩者做了合并,僅剩一個 long。

首先來看看 long 這樣一個數據結構底層的實現:

  1. struct _longobject { 
  2.     PyObject_VAR_HEAD 
  3.     digit ob_digit[1]; 
  4. }; 

在這里不用關心,PyObject_VAR_HEAD 的含義,我們只需要關心 ob_digit 即可。

在這里,ob_digit 是使用了 C99 中的“柔性數組”來實現任意長度的整數的存儲。這里我們可以看一下官方代碼中的文檔:

Long integer representation.The absolute value of a number is equal to SUM(for i=0 through abs(ob_size)-1) ob_digit[i] * 2**(SHIFT*i) Negative numbers are represented with ob_size < 0; zero is represented by ob_size == 0. In a normalized number, ob_digit[abs(ob_size)-1] (the most significant digit) is never zero. Also, in all cases, for all valid i,0 <= ob_digit[i] <= MASK. The allocation function takes care of allocating extra memory so that ob_digit[0] ... ob_digit[abs(ob_size)-1] are actually available. CAUTION: Generic code manipulating subtypes of PyVarObject has to aware that ints abuse ob_size's sign bit.

簡而言之,Python 是將一個十進制數轉為 2^(SHIFT) 進制數來進行存儲。這里可能不太好了理解。我來舉個例子,在我的電腦上,SHIFT 為 30 ,假設現在有整數 1152921506754330628 ,那么將其轉為 2^30 進制表示則為: 4*(2^30)^0+2*(2^30)^1+1*(2^30)^2 。那么此時 ob_digit 是一個含有三個元素的數組,其值為 [4,2,1]。

OK,在明白了這樣一些基礎知識后,我們回過頭去看看 Python 中的乘法運算。

2. Python 中的乘法運算

Python 中的乘法運算,分為兩部分,其中關于大數的乘法,Python 使用了 Karatsuba 算法1,具體實現如下:

  1. static PyLongObject * 
  2. k_mul(PyLongObject *a, PyLongObject *b) 
  3.     Py_ssize_t asize = Py_ABS(Py_SIZE(a)); 
  4.     Py_ssize_t bsize = Py_ABS(Py_SIZE(b)); 
  5.     PyLongObject *ah = NULL
  6.     PyLongObject *al = NULL
  7.     PyLongObject *bh = NULL
  8.     PyLongObject *bl = NULL
  9.     PyLongObject *ret = NULL
  10.     PyLongObject *t1, *t2, *t3; 
  11.     Py_ssize_t shift;           /* the number of digits we split off */ 
  12.     Py_ssize_t i; 
  13.  
  14.     /* (ah*X+al)(bh*X+bl) = ah*bh*X*X + (ah*bl + al*bh)*X + al*bl 
  15.      * Let k = (ah+al)*(bh+bl) = ah*bl + al*bh  + ah*bh + al*bl 
  16.      * Then the original product is 
  17.      *     ah*bh*X*X + (k - ah*bh - al*bl)*X + al*bl 
  18.      * By picking X to be a power of 2, "*X" is just shifting, and it's 
  19.      * been reduced to 3 multiplies on numbers half the size. 
  20.      */ 
  21.  
  22.     /* We want to split based on the larger number; fiddle so that b 
  23.      * is largest. 
  24.      */ 
  25.     if (asize > bsize) { 
  26.         t1 = a
  27.         a = b
  28.         b = t1
  29.  
  30.         i = asize
  31.         asize = bsize
  32.         bsize = i; 
  33.     } 
  34.  
  35.     /* Use gradeschool math when either number is too small. */ 
  36.     i = a == b ? KARATSUBA_SQUARE_CUTOFF : KARATSUBA_CUTOFF; 
  37.     if (asize <= i) { 
  38.         if (asize == 0) 
  39.             return (PyLongObject *)PyLong_FromLong(0); 
  40.         else 
  41.             return x_mul(a, b); 
  42.     } 
  43.  
  44.     /* If a is small compared to b, splitting on b gives a degenerate 
  45.      * case with ah==0, and Karatsuba may be (even much) less efficient 
  46.      * than "grade school" then.  However, we can still win, by viewing 
  47.      * b as a string of "big digits", each of width a->ob_size.  That 
  48.      * leads to a sequence of balanced calls to k_mul. 
  49.      */ 
  50.     if (2 * asize <= bsize) 
  51.         return k_lopsided_mul(a, b); 
  52.  
  53.     /* Split a & b into hi & lo pieces. */ 
  54.     shift = bsize >> 1; 
  55.     if (kmul_split(a, shift, &ah, &al) < 0) goto fail; 
  56.     assert(Py_SIZE(ah) > 0);            /* the split isn't degenerate */ 
  57.  
  58.     if (a == b) { 
  59.         bh = ah
  60.         bl = al
  61.         Py_INCREF(bh); 
  62.         Py_INCREF(bl); 
  63.     } 
  64.     else if (kmul_split(b, shift, &bh, &bl) < 0) goto fail; 
  65.  
  66.     /* The plan: 
  67.      * 1. Allocate result space (asize + bsize digits:  that's always 
  68.      *    enough). 
  69.      * 2. Compute ah*bh, and copy into result at 2*shift. 
  70.      * 3. Compute al*bl, and copy into result at 0.  Note that this 
  71.      *    can't overlap with #2. 
  72.      * 4. Subtract al*bl from the result, starting at shift.  This may 
  73.      *    underflow (borrow out of the high digit), but we don't care: 
  74.      *    we're effectively doing unsigned arithmetic mod 
  75.      *    BASE**(sizea + sizeb), and so long as the *final* result fits, 
  76.      *    borrows and carries out of the high digit can be ignored. 
  77.      * 5. Subtract ah*bh from the result, starting at shift. 
  78.      * 6. Compute (ah+al)*(bh+bl), and add it into the result starting 
  79.      *    at shift. 
  80.      */ 
  81.  
  82.     /* 1. Allocate result space. */ 
  83.     ret = _PyLong_New(asize + bsize); 
  84.     if (ret == NULL) goto fail; 
  85. #ifdef Py_DEBUG 
  86.     /* Fill with trash, to catch reference to uninitialized digits. */ 
  87.     memset(ret->ob_digit, 0xDF, Py_SIZE(ret) * sizeof(digit)); 
  88. #endif 
  89.  
  90.     /* 2. t1 <- ah*bh, and copy into high digits of result. */ 
  91.     if ((t1 = k_mul(ah, bh)) == NULL) goto fail; 
  92.     assert(Py_SIZE(t1) >= 0); 
  93.     assert(2*shift + Py_SIZE(t1) <= Py_SIZE(ret)); 
  94.     memcpy(ret->ob_digit + 2*shift, t1->ob_digit, 
  95.            Py_SIZE(t1) * sizeof(digit)); 
  96.  
  97.     /* Zero-out the digits higher than the ah*bh copy. */ 
  98.     i = Py_SIZE(ret) - 2*shift - Py_SIZE(t1); 
  99.     if (i) 
  100.         memset(ret->ob_digit + 2*shift + Py_SIZE(t1), 0, 
  101.                i * sizeof(digit)); 
  102.  
  103.     /* 3. t2 <- al*bl, and copy into the low digits. */ 
  104.     if ((t2 = k_mul(al, bl)) == NULL) { 
  105.         Py_DECREF(t1); 
  106.         goto fail; 
  107.     } 
  108.     assert(Py_SIZE(t2) >= 0); 
  109.     assert(Py_SIZE(t2) <= 2*shift); /* no overlap with high digits */ 
  110.     memcpy(ret->ob_digit, t2->ob_digit, Py_SIZE(t2) * sizeof(digit)); 
  111.  
  112.     /* Zero out remaining digits. */ 
  113.     i = 2*shift - Py_SIZE(t2);          /* number of uninitialized digits */ 
  114.     if (i) 
  115.         memset(ret->ob_digit + Py_SIZE(t2), 0, i * sizeof(digit)); 
  116.  
  117.     /* 4 & 5. Subtract ah*bh (t1) and al*bl (t2).  We do al*bl first 
  118.      * because it's fresher in cache. 
  119.      */ 
  120.     i = Py_SIZE(ret) - shift;  /* # digits after shift */ 
  121.     (void)v_isub(ret->ob_digit + shift, i, t2->ob_digit, Py_SIZE(t2)); 
  122.     Py_DECREF(t2); 
  123.  
  124.     (void)v_isub(ret->ob_digit + shift, i, t1->ob_digit, Py_SIZE(t1)); 
  125.     Py_DECREF(t1); 
  126.  
  127.     /* 6. t3 <- (ah+al)(bh+bl), and add into result. */ 
  128.     if ((t1 = x_add(ah, al)) == NULL) goto fail; 
  129.     Py_DECREF(ah); 
  130.     Py_DECREF(al); 
  131.     ah = al = NULL; 
  132.  
  133.     if (a == b) { 
  134.         t2 = t1
  135.         Py_INCREF(t2); 
  136.     } 
  137.     else if ((t2 = x_add(bh, bl)) == NULL) { 
  138.         Py_DECREF(t1); 
  139.         goto fail; 
  140.     } 
  141.     Py_DECREF(bh); 
  142.     Py_DECREF(bl); 
  143.     bh = bl = NULL; 
  144.  
  145.     t3 = k_mul(t1, t2); 
  146.     Py_DECREF(t1); 
  147.     Py_DECREF(t2); 
  148.     if (t3 == NULL) goto fail; 
  149.     assert(Py_SIZE(t3) >= 0); 
  150.  
  151.     /* Add t3.  It's not obvious why we can't run out of room here. 
  152.      * See the (*) comment after this function. 
  153.      */ 
  154.     (void)v_iadd(ret->ob_digit + shift, i, t3->ob_digit, Py_SIZE(t3)); 
  155.     Py_DECREF(t3); 
  156.  
  157.     return long_normalize(ret); 
  158.  
  159.   fail: 
  160.     Py_XDECREF(ret); 
  161.     Py_XDECREF(ah); 
  162.     Py_XDECREF(al); 
  163.     Py_XDECREF(bh); 
  164.     Py_XDECREF(bl); 
  165.     return NULL; 

這里不對 Karatsuba 算法1 的實現做單獨解釋,有興趣的朋友可以參考文末的 reference 去了解具體的詳情。

在普通情況下,普通乘法的時間復雜度為 n^2 (n 為位數),而 K 算法的時間復雜度為 3n^(log3) ≈ 3n^1.585 ,看起來 K 算法的性能要優于普通乘法,那么為什么 Python 不全部使用 K 算法呢?

很簡單,K 算法的優勢實際上要在當 n 足夠大的時候,才會對普通乘法形成優勢。同時考慮到內存訪問等因素,當 n 不夠大時,實際上采用 K 算法的性能將差于直接進行乘法。

所以我們來看看 Python 中乘法的實現:

  1. static PyObject * 
  2. long_mul(PyLongObject *a, PyLongObject *b) 
  3.     PyLongObject *z; 
  4.  
  5.     CHECK_BINOP(a, b); 
  6.  
  7.     /* fast path for single-digit multiplication */ 
  8.     if (Py_ABS(Py_SIZE(a)) <= 1 && Py_ABS(Py_SIZE(b)) <= 1) { 
  9.         stwodigits v = (stwodigits)(MEDIUM_VALUE(a)) * MEDIUM_VALUE(b); 
  10.         return PyLong_FromLongLong((long long)v); 
  11.     } 
  12.  
  13.     z = k_mul(a, b); 
  14.     /* Negate if exactly one of the inputs is negative. */ 
  15.     if (((Py_SIZE(a) ^ Py_SIZE(b)) < 0) && z) { 
  16.         _PyLong_Negate(&z); 
  17.         if (z == NULL) 
  18.             return NULL; 
  19.     } 
  20.     return (PyObject *)z; 

在這里我們看到,當兩個數皆小于 2^30-1 時,Python 將直接使用普通乘法并返回,否則將使用 K 算法進行計算

這個時候,我們來看一下位運算的實現,以右移為例:

  1. static PyObject * 
  2. long_rshift(PyObject *a, PyObject *b) 
  3.     Py_ssize_t wordshift; 
  4.     digit remshift; 
  5.  
  6.     CHECK_BINOP(a, b); 
  7.  
  8.     if (Py_SIZE(b) < 0) { 
  9.         PyErr_SetString(PyExc_ValueError, "negative shift count"); 
  10.         return NULL; 
  11.     } 
  12.     if (Py_SIZE(a) == 0) { 
  13.         return PyLong_FromLong(0); 
  14.     } 
  15.     if (divmod_shift(b, &wordshift, &remshift) < 0
  16.         return NULL; 
  17.     return long_rshift1((PyLongObject *)a, wordshift, remshift); 
  18.  
  19. static PyObject * 
  20. long_rshift1(PyLongObject *a, Py_ssize_t wordshift, digit remshift) 
  21.     PyLongObject *z = NULL
  22.     Py_ssize_t newsize, hishift, i, j; 
  23.     digit lomask, himask; 
  24.  
  25.     if (Py_SIZE(a) < 0) { 
  26.         /* Right shifting negative numbers is harder */ 
  27.         PyLongObject *a1, *a2; 
  28.         a1 = (PyLongObject *) long_invert(a); 
  29.         if (a1 == NULL) 
  30.             return NULL; 
  31.         a2 = (PyLongObject *) long_rshift1(a1, wordshift, remshift); 
  32.         Py_DECREF(a1); 
  33.         if (a2 == NULL) 
  34.             return NULL; 
  35.         z = (PyLongObject *) long_invert(a2); 
  36.         Py_DECREF(a2); 
  37.     } 
  38.     else { 
  39.         newsize = Py_SIZE(a) - wordshift; 
  40.         if (newsize <= 0) 
  41.             return PyLong_FromLong(0); 
  42.         hishift = PyLong_SHIFT - remshift; 
  43.         lomask = ((digit)1 << hishift) - 1; 
  44.         himask = PyLong_MASK ^ lomask; 
  45.         z = _PyLong_New(newsize); 
  46.         if (z == NULL) 
  47.             return NULL; 
  48.         for (i = 0j = wordshift; i < newsize; i++, j++) { 
  49.             z->ob_digit[i] = (a->ob_digit[j] >> remshift) & lomask; 
  50.             if (i+1 < newsize
  51.                 z->ob_digit[i] |= (a->ob_digit[j+1] << hishift) & himask; 
  52.         } 
  53.         z = maybe_small_long(long_normalize(z)); 
  54.     } 
  55.     return (PyObject *)z; 

在這里我們能看到,在兩側都是小數的情況下,位移動算法將比普通乘法,存在更多的內存分配等操作。這樣也會回答了我們文初所提到的一個問題,“為什么一些時候乘法比位運算更快”。

總結本文差不多就到這里了,實際上通過這次分析我們能得到一些很有趣但是也很冷門的知識。實際上我們目前看到這樣一個結果,是 Python 對于我們常見且高頻的操作所做的一個特定的設計。而這也提醒我們,Python 實際上對于很多操作都存在自己內建的設計哲學,在日常使用的時候,其余語言的經驗,可能無法復用。

 

責任編輯:趙寧寧 來源: Manjusaka的編程屋
相關推薦

2021-01-13 10:51:08

PromissetTimeout(函數

2023-09-14 15:48:53

排序測試

2023-09-20 00:06:30

Python代碼函數

2013-07-24 09:47:52

語言語速環境語言

2025-09-22 08:12:57

2012-08-23 09:28:01

編程編程語言

2021-04-23 11:11:59

加密貨幣硬幣數字貨幣

2021-01-30 10:51:07

Python編程語言開發

2021-07-23 16:30:36

PythonC++代碼

2014-08-29 09:56:47

排序數組編程技巧

2015-08-06 12:50:47

技術人員博客

2020-09-15 09:55:30

類比Python開發

2022-11-10 15:32:29

2024-02-05 22:51:49

AGIRustPython

2019-09-16 12:00:03

constC編程語言

2020-07-17 19:31:19

PythonR編程

2020-02-14 13:53:33

Python 開發編程語言

2015-07-31 16:29:15

DockerJavaLinux

2021-12-27 07:10:26

ClassmethodStaticmetho函數

2019-04-24 08:00:00

HTTPSHTTP前端
點贊
收藏

51CTO技術棧公眾號

一本一道久久a久久精品综合蜜臀| 久久精品国产色蜜蜜麻豆| 亚洲国产小视频| 午夜激情福利在线| 97超碰资源站在线观看| 成人美女在线视频| 国产精选久久久久久| 久草资源在线视频| 欧洲毛片在线视频免费观看| 日韩一级免费观看| av免费网站观看| 日本三级韩国三级欧美三级| 国产性做久久久久久| 99久久综合狠狠综合久久止| 无码人妻丰满熟妇精品区| 亚洲午夜精品一区 二区 三区| 日韩黄在线观看| 日本成人xxx| 最新欧美电影| 性做久久久久久久久| 永久免费精品视频网站| 天天干天天操av| 国产乱子伦视频一区二区三区| 日本中文字幕久久看| 欧美黄色免费观看| 日韩精品一卡| 亚洲人高潮女人毛茸茸| av在线天堂网| 国产午夜久久av| 欧美日韩在线电影| 国产成人亚洲精品无码h在线| 色av手机在线| 亚洲女人的天堂| 杨幂一区欧美专区| 川上优的av在线一区二区| 99re热这里只有精品免费视频| 亚洲自拍av在线| 国产又爽又黄免费软件| 日本特黄久久久高潮| 青青精品视频播放| 亚洲日本视频在线观看| 亚洲精品1区| 久久久亚洲国产天美传媒修理工| 小泽玛利亚一区二区免费| 欧美色图在线播放| 国产一区二区三区直播精品电影| 熟女人妻在线视频| 欧美1区2区3区4区| 亚洲精品日韩欧美| 少妇按摩一区二区三区| 亚洲免费专区| 亚洲日韩第一页| 一级片视频免费看| 精品国产一区二区三区四区| 国产婷婷97碰碰久久人人蜜臀| 欧美大喷水吹潮合集在线观看| 成人午夜三级| 亚洲国产三级网| 一区二区视频观看| 国产成人精品免费视| 亚洲欧美国产视频| 日韩毛片无码永久免费看| 国产成人av| 中文日韩电影网站| 男人av资源站| 欧美日韩国产一区精品一区| 欧美风情在线观看| 中文字幕在线字幕中文| 久久高清免费观看| 国产免费成人av| 国产91视频在线| 北岛玲一区二区三区四区| 精品一区二区三区免费毛片| 女人天堂在线| 中文字幕亚洲区| 麻豆映画在线观看| freexxx性亚洲精品| 日韩欧美在线免费观看| 亚洲娇小娇小娇小| 日韩精品成人| 精品偷拍一区二区三区在线看| 亚洲黄色小说视频| 66视频精品| 97视频免费在线观看| 无码人妻av一区二区三区波多野| 加勒比av一区二区| 国产在线精品一区| 97最新国自产拍视频在线完整在线看| 亚洲人成在线观看一区二区| www.国产在线视频| 麻豆精品蜜桃| 精品久久一区二区| 97人妻人人揉人人躁人人| 欧美片第1页综合| 国产精品99久久久久久久久久久久 | 国产在线青青草| 日韩欧乱色一区二区三区在线| 精品久久久久一区二区国产| 成人国产精品久久久网站| 一级欧洲+日本+国产 | 伊人婷婷久久| 女人让男人操自己视频在线观看| 欧美天天综合网| 无码成人精品区在线观看| 欧美精品一二| 97高清免费视频| 97人妻人人澡人人爽人人精品 | 日韩大片一区二区| 国产精品九九九九| 2020国产精品| www婷婷av久久久影片| 色天使综合视频| 亚洲成人av片在线观看| 人人艹在线视频| 久久久xxx| 国产欧美在线一区二区| 久久综合网导航| 色婷婷精品久久二区二区蜜臂av| 潘金莲一级淫片aaaaaaa| 国产一区99| 性亚洲最疯狂xxxx高清| 99国产在线播放| 国产精品你懂的在线| 精品视频一区二区在线| 99久久香蕉| 欧美成人精品在线播放| 中文字幕91爱爱| 久久免费国产精品| 免费成人午夜视频| 欧美三级自拍| 91精品国产成人| 亚洲av永久无码国产精品久久| 国产精品电影院| 在线观看av网页| 狠狠做深爱婷婷综合一区| 日本亚洲欧洲色α| 天天av综合网| 午夜伊人狠狠久久| 怡红院一区二区| 雨宫琴音一区二区在线| 国产精品永久入口久久久| 肉肉视频在线观看| 精品国产免费一区二区三区四区| 超碰手机在线观看| 国产毛片精品视频| 91看片淫黄大片91| 日韩成人在线观看视频| 欧美成人久久久| 性生活视频软件| 亚洲一本大道在线| 91视频在线免费| 亚洲黄页一区| 美乳视频一区二区| 性欧美videohd高精| 国产一级揄自揄精品视频| 樱花视频在线免费观看| 国产精品污网站| 五月天中文字幕在线| av免费在线视| 亚洲91精品| 青草成人免费视频| 黄色在线免费观看大全| 欧美亚洲日本一区| 久草手机视频在线观看| 国产做a爰片久久毛片| 日本免费黄色小视频| 中文字幕视频精品一区二区三区| 欧美华人在线视频| 日本免费网站在线观看| 欧美丝袜第一区| 欧美日韩国产黄色| 国产美女主播视频一区| 日韩 欧美 视频| 天天操综合520| 国产精品久久久久久久久久免费 | 久久久久久久久蜜桃| 午夜视频你懂的| 欧美一区二区| 九九九九九精品| 丁香婷婷久久| 欧美激情视频在线观看| 四虎国产精品永远| 欧美日韩高清一区二区| 国产主播在线观看| 日本一区二区三区四区在线视频 | xf在线a精品一区二区视频网站| 久久久久久香蕉| www.av成人| 国内精品伊人久久久久影院对白| 免费网站永久免费观看| 亚洲人和日本人hd| 成人女保姆的销魂服务| rebdb初裸写真在线观看| 亚洲网在线观看| 精品区在线观看| 91九色最新地址| 久久视频免费看| 欧美国产亚洲另类动漫| 丰满少妇xbxb毛片日本| 全部av―极品视觉盛宴亚洲| 隔壁人妻偷人bd中字| 日韩精品91| 久久伊人一区二区| 日韩精品成人在线观看| 国产精品高清免费在线观看| 色婷婷av在线| 日韩亚洲欧美中文高清在线| 视频国产在线观看| 日韩欧美第一区| 中文字幕一区二区三区人妻四季| 亚洲风情在线资源站| 强制高潮抽搐sm调教高h| 97久久超碰国产精品电影| 日韩av福利在线观看| 日韩福利视频导航| 91专区在线观看| 亚洲九九在线| 亚洲午夜精品久久| 九九免费精品视频在线观看| 国产精品免费一区二区| 日本美女久久| 日av在线播放中文不卡| 国产精品蜜臀| 精品综合久久久久久97| 日本三级在线视频| 中文字幕久久久| 毛片在线免费| 日韩经典一区二区三区| 国产1区在线观看| 51精品秘密在线观看| 中文无码av一区二区三区| 日韩欧美成人免费视频| 日韩成人免费观看| 一区二区三区免费| 欧美成人精品欧美一级| 亚洲激情自拍偷拍| 日本妇女毛茸茸| 一区二区三区自拍| 中文字幕在线有码| 自拍偷拍欧美激情| 91精品国产闺蜜国产在线闺蜜| 亚洲国产经典视频| 麻豆视频免费在线播放| 亚洲国产成人午夜在线一区 | 午夜久久久久久久久久| 日韩一区二区三区免费看| 国产精品视频无码| 6080午夜不卡| 国产熟女一区二区三区四区| 91麻豆精品国产91久久久久久久久 | 久久婷婷国产综合尤物精品| 精品精品国产三级a∨在线| 国产99午夜精品一区二区三区| 我要色综合中文字幕| 亚洲淫片在线视频| jizz18欧美18| 久久久久久久有限公司| 美女精品一区最新中文字幕一区二区三区 | 欧美综合精品| 久久久一本精品99久久精品| 综合综合综合综合综合网| 四虎一区二区| 婷婷综合在线| 男人添女荫道口喷水视频| 日韩一级大片| 国产裸体免费无遮挡| 久久成人羞羞网站| 日本黄色三级网站| 成人高清av在线| 丰满少妇在线观看资源站| 国产视频911| 亚洲国产精品免费在线观看| 亚洲自拍偷拍图区| 亚洲第一网站在线观看| 欧美日韩另类一区| 朝桐光av在线一区二区三区| 亚洲国内精品在线| 国产福利第一视频在线播放| 精品激情国产视频| av漫画网站在线观看| 国产成人精品综合| 国产精品igao视频网网址不卡日韩| 草莓视频一区| 国产真实有声精品录音| 做爰高潮hd色即是空| 亚洲精品欧洲| 国产三级生活片| 99re免费视频精品全部| 久草福利资源在线| 午夜精品一区二区三区三上悠亚| 青青国产在线视频| 精品久久久久久久久久久久包黑料 | 欧美日韩精品区| 91麻豆精品国产综合久久久久久 | 99爱视频在线| 国产一区二区三区免费在线观看| 中国av免费看| 一区视频在线播放| yjizz国产| 欧美电影免费观看完整版 | 欧美高清不卡在线| a∨色狠狠一区二区三区| 成人欧美视频在线| 成人免费电影网址| 人人妻人人添人人爽欧美一区| 蜜臀av一区二区在线观看| 国产十八熟妇av成人一区| 中文字幕在线一区二区三区| 国产成人精品一区二三区| 欧美疯狂做受xxxx富婆| 免费在线高清av| 韩国美女主播一区| 三级欧美日韩| 一本一本久久a久久精品综合妖精| 国产日韩欧美一区在线| 亚洲欧美激情一区二区三区| 国产精品免费av| 国产精品va无码一区二区三区| 精品三级在线看| 调教视频免费在线观看| 日韩免费黄色av| 日韩精选在线| 男女私大尺度视频| 国产福利一区在线| 91麻豆免费视频网站| 欧美人伦禁忌dvd放荡欲情| 韩国福利在线| 欧美在线观看网站| 日韩欧美国产大片| 欧美一级免费播放| 成人精品免费看| 久久久久久久国产精品毛片| 欧美一区二区三区四区在线观看| 91精彩在线视频| 国产精品免费视频xxxx| 国产尤物久久久| 中文字幕一区二区三区四区在线视频| 91视频在线看| 亚洲永久精品在线观看| 秋霞欧美视频| 欧美视频1区| 香蕉国产精品偷在线观看不卡| 五月天激情小说| 午夜伊人狠狠久久| 五月婷婷六月激情| 欧美在线www| 国产精品一国产精品| 女人另类性混交zo| 国产欧美一区二区在线| 黄色av网站免费观看| 永久免费看mv网站入口亚洲| 欧美精品资源| 亚洲人成网站在线观看播放| 日本不卡123| 小早川怜子一区二区的演员表| 在线不卡中文字幕| 羞羞视频在线观看免费| 成人动漫在线视频| 亚洲黄色毛片| 色欲AV无码精品一区二区久久 | 欧美巨乳在线观看| 日韩一区二区三区在线看| www.av91| 91蜜桃婷婷狠狠久久综合9色| 在线视频一区二区三区四区| 在线视频中文亚洲| 欧美一级做一级爱a做片性| 自拍偷拍视频在线| 豆国产96在线|亚洲| 亚洲一区欧美在线| 影音先锋日韩有码| av日韩久久| 久操网在线观看| 国产视频911| www.久久伊人| 国产999精品| 亚洲精品小说| 800av在线播放| 欧美性生交片4| 影院在线观看全集免费观看| 精品一卡二卡三卡四卡日本乱码| 日本欧美加勒比视频| 国产va在线播放| 亚洲欧美视频在线| 精品久久久久久久久久岛国gif| 欧美一级片免费播放| 国产精品灌醉下药二区| 空姐吹箫视频大全| 国产乱人伦真实精品视频| 亚洲性感美女99在线| 久久视频精品在线观看| 日韩福利视频网| 亚洲精品日韩在线观看| 国产一区二区三区免费在线观看| 中文字幕超碰在线| 久久九九国产精品怡红院| 婷婷精品在线| 亚洲 自拍 另类 欧美 丝袜| 91久久精品一区二区| 新版中文在线官网|