成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識(shí)庫(kù) > 實(shí)例解析Ruby設(shè)計(jì)模式編程中Strategy策略模式的使用

實(shí)例解析Ruby設(shè)計(jì)模式編程中Strategy策略模式的使用

熱門標(biāo)簽:滴滴外呼系統(tǒng) 電銷機(jī)器人廠商代理 高德地圖標(biāo)注客服 湖州u友防封電銷卡 地圖標(biāo)注賺錢項(xiàng)目注冊(cè) 百度地圖標(biāo)注自定義圖片 白銀外呼paas系統(tǒng) 常德電銷平臺(tái)外呼系統(tǒng)軟件價(jià)格 徐州網(wǎng)絡(luò)外呼系統(tǒng)哪個(gè)好

今天你的leader興致沖沖地找到你,希望你可以幫他一個(gè)小忙,他現(xiàn)在急著要去開會(huì)。要幫什么忙呢?你很好奇。
他對(duì)你說,當(dāng)前你們項(xiàng)目的數(shù)據(jù)庫(kù)中有一張用戶信息表,里面存放了很用戶的數(shù)據(jù),現(xiàn)在需要完成一個(gè)選擇性查詢用戶信息的功能。他說會(huì)傳遞給你一個(gè)包含許多用戶名的數(shù)組,你需要根據(jù)這些用戶名把他們相應(yīng)的數(shù)據(jù)都給查出來。
這個(gè)功能很簡(jiǎn)單的嘛,你爽快地答應(yīng)了。由于你們項(xiàng)目使用的是MySQL數(shù)據(jù)庫(kù),你很快地寫出了如下代碼:

require 'mysql' 
 
class QueryUtil 
  def find_user_info usernames 
    @db = Mysql.real_connect("localhost","root","123456","test",3306); 
    sql = "select * from user_info where " 
    usernames.each do |user| 
      sql  "username = '" 
      sql  user 
      sql  "' or " 
    end 
    puts sql 
    result = @db.query(sql); 
    result.each_hash do |row| 
      #處理從數(shù)據(jù)庫(kù)讀出來的數(shù)據(jù) 
    end 
    #后面應(yīng)將讀到的數(shù)據(jù)組裝成對(duì)象返回,這里略去 
  ensure 
    @db.close 
  end 
end 

這里根據(jù)傳入的用戶名數(shù)組拼裝了SQL語句,然后去數(shù)據(jù)庫(kù)中查找相應(yīng)的行。為了方面調(diào)試,你還將拼裝好的SQL語句打印了出來。
然后,你寫了如下代碼來測(cè)試這個(gè)方法:

qUtil = QueryUtil.new 
qUtil.find_user_info ["Tom", "Jim", "Anna"] 

現(xiàn)在運(yùn)行一下測(cè)試代碼,你發(fā)現(xiàn)程序出錯(cuò)了。于是你立刻去檢查了一下打印的SQL語句,果然發(fā)現(xiàn)了問題。

select * from user_info where username = 'Tom' or username = 'Jim' or username = 'Anna' or  
拼裝出來的SQL語句在最后多加了一個(gè) or 關(guān)鍵字!因?yàn)閒or循環(huán)執(zhí)行到最后一條數(shù)據(jù)時(shí)不應(yīng)該再加上or,可是代碼很笨地給最后一條數(shù)據(jù)也加了or關(guān)鍵字,導(dǎo)致SQL語句語法出錯(cuò)了。
這可怎么辦呢?
有了!你靈光一閃,想出了一個(gè)解決辦法。等SQL語句拼裝完成后,截取到最后一個(gè)or之前的位置不就好了么。于是你將代碼改成如下所示:

require 'mysql' 
 
class QueryUtil 
  def find_user_info usernames 
    @db = Mysql.real_connect("localhost","root","123456","test",3306); 
    sql = "select * from user_info where " 
    usernames.each do |user| 
      sql  "username = '" 
      sql  user 
      sql  "' or " 
    end 
    sql = sql[0 .. -" or ".length] 
    puts sql 
    result = @db.query(sql); 
    result.each_hash do |row| 
      #處理從數(shù)據(jù)庫(kù)讀出來的數(shù)據(jù) 
    end 
    #后面應(yīng)將讀到的數(shù)據(jù)組裝成對(duì)象返回,這里略去 
  ensure 
    @db.close 
  end 
end 

使用String的截取子字符串方法,只取到最后一個(gè)or之前的部分,這樣再運(yùn)行測(cè)試代碼,一切就正常了,打印的SQL語句如下所示:

select * from user_info where username = 'Tom' or username = 'Jim' or username = 'Anna' 

好了,完工!你自信滿滿。
你的leader開完會(huì)后,過來看了下你的成果??傮w來說,他還挺滿意,但對(duì)于你使用的SQL語句拼裝算法,他總是感覺有些不對(duì)勁,可是又說不上哪里不好。于是他告訴了你另一種拼裝SQL語句的算法,讓你加入到代碼中,但是之前的那種算法也不要?jiǎng)h除,先保留著再說,然后他又很忙似的跑開了。于是,你把他剛剛教你的算法加了進(jìn)去,代碼如下所示:

require 'mysql' 
 
class QueryUtil 
  def find_user_info(usernames, strategy) 
    @db = Mysql.real_connect("localhost","root","123456","test",3306); 
    sql = "select * from user_info where " 
    if strategy == 1 
      usernames.each do |user| 
        sql  "username = '" 
        sql  user 
        sql  "' or " 
      end 
      sql = sql[0 .. -" or ".length] 
    elsif strategy == 2 
      need_or = false 
      usernames.each do |user| 
        sql  " or " if need_or 
        sql  "username = '" 
        sql  user 
        sql  "'" 
        need_or = true 
      end 
    end 
    puts sql 
    result = @db.query(sql); 
    result.each_hash do |row| 
      #處理從數(shù)據(jù)庫(kù)讀出來的數(shù)據(jù) 
    end 
    #后面應(yīng)將讀到的數(shù)據(jù)組裝成對(duì)象返回,這里略去 
  ensure 
    @db.close 
  end 
end 

可以看到,你leader教你的拼裝算法,使用了一個(gè)布爾變量來控制是否需要加個(gè)or這個(gè)關(guān)鍵字,第一次執(zhí)行for循環(huán)的時(shí)候因?yàn)樵摬紶栔禐閒alse,所以不會(huì)加上or,在循環(huán)的最后將布爾值賦值為true,這樣以后循環(huán)每次都會(huì)在頭部加上一個(gè)or關(guān)鍵字,由于使用了頭部添加or的方法,所以不用再擔(dān)心SQL語句的尾部會(huì)多出一個(gè)or來。然后你為了將兩個(gè)算法都保留,在find_user_info方法上加了一個(gè)參數(shù),strategy值為1表示使用第一種算法,strategy值為2表示使用第二種算法。
這樣測(cè)試代碼也需要改成如下方式:

qUtil = QueryUtil.new 
qUtil.find_user_info(["Tom", "Jim", "Anna"], 2) 

這里你通過參數(shù)指明了使用第二種算法來拼裝SQL語句,打印的結(jié)果和使用第一種算法是完全相同的。
你立刻把你的leader從百忙之中拖了過來,讓他檢驗(yàn)一下你當(dāng)前的成果,可是他還是一如既往的挑剔。
“你這樣寫的話,find_user_info這個(gè)方法的邏輯就太復(fù)雜了,非常不利于閱讀,也不利于將來的擴(kuò)展,如果我還有第三第四種算法想加進(jìn)去,這個(gè)方法還能看嗎?”  你的leader指點(diǎn)你,遇到這種情況,就要使用策略模式來解決,策略模式的核心思想就是把算法提取出來放到一個(gè)獨(dú)立的對(duì)象中。
為了指點(diǎn)你,他不顧自己的百忙,開始教你如何使用策略模式進(jìn)行優(yōu)化。
首先定義一個(gè)父類,父類中包含了一個(gè)get_sql方法,這個(gè)方法就是簡(jiǎn)單的拋出了一個(gè)異常:

class Strategy 
  def get_sql usernames 
    raise "You should override this method in subclass." 
  end 
end 

然后定義兩個(gè)子類都繼承上述父類,并將兩種拼裝SQL語句的算法分別加入兩個(gè)子類中:

class Strategy1 
  def get_sql usernames 
    sql = "select * from user_info where " 
    usernames.each do |user| 
      sql  "username = '" 
      sql  user 
      sql  "' or " 
    end 
    sql = sql[0 .. -" or ".length] 
  end 
end 

class Strategy2 
  def get_sql usernames 
    sql = "select * from user_info where " 
    need_or = false 
    usernames.each do |user| 
      sql  " or " if need_or 
      sql  "username = '" 
      sql  user 
      sql  "'" 
      need_or = true 
    end 
  end 
end 

然后在QueryUtil的find_user_info方法中調(diào)用Strategy的get_sql方法就可以獲得拼裝好的SQL語句,代碼如下所示:

require 'mysql' 
 
class QueryUtil 
  def find_user_info(usernames, strategy) 
    @db = Mysql.real_connect("localhost","root","123456","test",3306); 
    sql = strategy.get_sql(usernames) 
    puts sql 
    result = @db.query(sql); 
    result.each_hash do |row| 
      #處理從數(shù)據(jù)庫(kù)讀出來的數(shù)據(jù) 
    end 
    #后面應(yīng)將讀到的數(shù)據(jù)組裝成對(duì)象返回,這里略去 
  ensure 
    @db.close 
  end 
end 

最后,測(cè)試代碼在調(diào)用find_user_info方法時(shí),只需要顯示地指明需要使用哪一個(gè)策略對(duì)象就可以了:

qUtil = QueryUtil.new 
qUtil.find_user_info(["Tom", "Jim", "Anna"], Strategy1.new) 
qUtil.find_user_info(["Jac", "Joe", "Rose"], Strategy2.new) 

打印出的SQL語句絲毫不出預(yù)料,如下所示:

select * from user_info where username = 'Tom' or username = 'Jim' or username = 'Anna' 
select * from user_info where username = 'Jac' or username = 'Joe' or username = 'Rose' 

使用策略模式修改之后,代碼的可讀性和擴(kuò)展性都有了很大的提高,即使以后還需要添加新的算法,你也是手到擒來了!

策略模式和簡(jiǎn)單工廠模式結(jié)合的實(shí)例

需求:

商場(chǎng)收銀軟件,根據(jù)客戶購(gòu)買物品的單價(jià)和數(shù)量,計(jì)算費(fèi)用,會(huì)有促銷活動(dòng),打八折,滿三百減一百之類的。

1.使用工廠模式

# -*- encoding: utf-8 -*-

#現(xiàn)金收費(fèi)抽象類
class CashSuper
  def accept_cash(money)
  end
end

#正常收費(fèi)子類
class CashNormal  CashSuper
  def accept_cash(money)
    money
  end
end

#打折收費(fèi)子類
class CashRebate  CashSuper
  attr_accessor :mony_rebate
  
  def initialize(mony_rebate)
    @mony_rebate = mony_rebate
  end

  def accept_cash(money)
    money * mony_rebate
  end
end

#返利收費(fèi)子類
class CashReturn  CashSuper
  attr_accessor :mony_condition, :mony_return
  
  def initialize(mony_condition, mony_return)
    @mony_condition = mony_condition
    @mony_return = mony_return
  end

  def accept_cash(money)
    if money > mony_condition
      money - (money/mony_condition) * mony_return
    end
  end
end

#現(xiàn)金收費(fèi)工廠類
class CashFactory
  def self.create_cash_accept(type)
    case type
    when '正常收費(fèi)'
      CashNormal.new()
    when '打8折'
      CashRebate.new(0.8)
    when '滿三百減100'
      CashReturn.new(300,100)
    end
  end
end

cash0 = CashFactory.create_cash_accept('正常收費(fèi)')
p cash0.accept_cash(700)

cash1 = CashFactory.create_cash_accept('打8折')
p cash1.accept_cash(700)

cash2 = CashFactory.create_cash_accept('滿三百減100')
p cash2.accept_cash(700)

做到了自定義折扣比例和滿減的數(shù)量。

存在的問題:

增加活動(dòng)的種類時(shí),打五折,滿五百減二百,需要在工廠類中添加分支結(jié)構(gòu)。

活動(dòng)是多種多樣的,也有可能增加積分活動(dòng),滿100加10積分,積分一定可以領(lǐng)取活動(dòng)獎(jiǎng)品,這時(shí)就要增加一個(gè)子類。

但是每次增加活動(dòng)的時(shí)候,都要去修改工廠類,是很糟糕的處理方式,面對(duì)算法有改動(dòng)時(shí),應(yīng)該有更好的辦法。

2.策略模式

CashSuper和子類都是不變的,增加以下內(nèi)容:

class CashContext
  
  attr_accessor :cs
  
  def initialize(c_super)
    @cs = c_super
  end
  
  def result(money)
    cs.accept_cash(money)
  end

end

type = '打8折'
cs=case type
  when '正常收費(fèi)'
    CashContext.new(CashNormal.new())
  when '打8折'
    CashContext.new(CashRebate.new(0.8))
  when '滿三百減100'
    CashContext.new(CashReturn.new(300,100))
  end
p cs.result(700)

CashContext類對(duì)不同的CashSuper子類進(jìn)行了封裝,會(huì)返回對(duì)應(yīng)的result。也就是對(duì)不同的算法進(jìn)行了封裝,無論算法如何變化。都可以使用result得到結(jié)果。
不過,目前有一個(gè)問題,使用者需要去做判斷,來選擇使用哪個(gè)算法??梢院秃?jiǎn)單工場(chǎng)類結(jié)合。

3.策略和簡(jiǎn)單工場(chǎng)結(jié)合

class CashContext
  
  attr_accessor :cs
  
  def initialize(type)
    case type
    when '正常收費(fèi)'
      @cs = CashNormal.new()
    when '打8折'
      @cs = CashRebate.new(0.8)
    when '滿三百減100'
      @cs = CashReturn.new(300,100)
    end
  end
  
  def result(money)
    cs.accept_cash(money)
  end

end

cs=CashContext.new('打8折')

p cs.result(700)

CashContext中實(shí)例化了不同的子類。(簡(jiǎn)單工廠)
將子類選擇的過程轉(zhuǎn)移到了內(nèi)部,封裝了算法(策略模式)。

調(diào)用者使用更簡(jiǎn)單,傳入?yún)?shù)(活動(dòng)類型,原價(jià)),即可得到最終的結(jié)果。
這里使用者只需要知道一個(gè)類(CashContext)就可以了,而簡(jiǎn)單工場(chǎng)需要知道兩個(gè)類(CashFactory的accept_cash方法和CashFactory),也就是說封裝的更徹底。

您可能感興趣的文章:
  • 設(shè)計(jì)模式中的觀察者模式在Ruby編程中的運(yùn)用實(shí)例解析
  • 實(shí)例解析Ruby設(shè)計(jì)模式開發(fā)中對(duì)觀察者模式的實(shí)現(xiàn)
  • 深入剖析Ruby設(shè)計(jì)模式編程中對(duì)命令模式的相關(guān)使用
  • Ruby設(shè)計(jì)模式編程中對(duì)外觀模式的應(yīng)用實(shí)例分析
  • 詳解組合模式的結(jié)構(gòu)及其在Ruby設(shè)計(jì)模式編程中的運(yùn)用
  • 設(shè)計(jì)模式中的模板方法模式在Ruby中的應(yīng)用實(shí)例兩則
  • 實(shí)例講解Ruby使用設(shè)計(jì)模式中的裝飾器模式的方法
  • Ruby設(shè)計(jì)模式編程中使用Builder建造者模式的實(shí)例
  • 詳解Ruby設(shè)計(jì)模式編程中對(duì)單例模式的運(yùn)用
  • Ruby設(shè)計(jì)模式編程之適配器模式實(shí)戰(zhàn)攻略
  • Ruby使用設(shè)計(jì)模式中的代理模式與裝飾模式的代碼實(shí)例
  • Ruby中使用設(shè)計(jì)模式中的簡(jiǎn)單工廠模式和工廠方法模式
  • 解析proxy代理模式在Ruby設(shè)計(jì)模式開發(fā)中的運(yùn)用

標(biāo)簽:張家界 永州 三沙 普洱 荊門 梧州 遼寧 公主嶺

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《實(shí)例解析Ruby設(shè)計(jì)模式編程中Strategy策略模式的使用》,本文關(guān)鍵詞  實(shí)例,解析,Ruby,設(shè)計(jì)模式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《實(shí)例解析Ruby設(shè)計(jì)模式編程中Strategy策略模式的使用》相關(guān)的同類信息!
  • 本頁收集關(guān)于實(shí)例解析Ruby設(shè)計(jì)模式編程中Strategy策略模式的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    久久99精品国产91久久来源| 一区二区视频在线免费| 亚洲自拍欧美另类| 久久免费精品国产久精品久久久久| 国产精品美女久久久久av爽| 91在线观看免费高清| 狠狠插狠狠操| 天天骑夜夜操| 777午夜精品电影免费看| 国内小视频在线看| 国产九色91| 91网站免费入口| 亚洲视频精品一区| 久久蜜桃资源一区二区老牛| 日本三级免费网站| 中文字幕日韩精品在线观看| 欧性猛交ⅹxxx乱大交| 天天干天天操av| 久久性色av| 久草网站在线| 中文字幕日本精品| 日本一区二区在线免费观看| 波多野结衣视频网址| 国产激情三区| 亚洲在线色站| 欧美日韩网站| 欧美一区二区三区观看| 国产精品视频yy9099| 91欧美一区二区| 亚洲色图欧美| 成人性生交视频免费观看| 懂色av中文一区二区三区| 欧美精品日韩在线| 综合婷婷亚洲小说| 国产羞羞视频在线播放| 国精品**一区二区三区在线蜜桃| 国内精品福利视频| 欧美性xxxxx极品少妇| 天堂av免费观看| 国产精品99久久久久久似苏梦涵| 懂色av一区二区三区四区| 国产成人免费视频网站视频社区| 五月婷婷导航| 精品视频免费看| 久久er热在这里只有精品66| 日本少妇在线观看| 中文字幕有码在线观看| 欧美大片欧美激情性色a∨久久| 岛国大片在线免费观看| 99久久伊人| 高清精品一区二区三区一区| 欧美一级片一区| 国产黄色一级电影| 热久久最新地址| 国产二级c片l毛片| 国产人妻大战黑人20p| 欧美精品一区二区高清在线观看| 久久久久久国产精品免费免费| 亚洲性日韩精品一区二区| 美女露胸一区二区三区| 欧美激情精品久久久久久| 久久精品国产99精品国产亚洲性色| 欧美视频网址| 日日噜噜噜噜夜夜爽亚洲精品| 国产成人毛片| 女同互添互慰av毛片观看| 999国产精品亚洲77777| 美国av在线播放| 久久97人妻无码一区二区三区| 欧美男人亚洲天堂| 精品欧美日韩在线| 成人免费淫片免费观看| 成人午夜视频在线播放| 国产精品久久久久久久久久久免费看| 欧美三级电影在线播放| 亚洲精品一区av| 国产一级免费黄色片| 日本日本精品二区免费| 欧美中文一区二区| 亚洲线精品久久一区二区三区| 亚洲18女电影在线观看| 国产精品美女视频网站| 亚洲色欲色欲www| 成人在线视频区| 精品二区三区线观看| 国产精品久久久久久久久久| 清纯粉嫩极品夜夜嗨av| 日本aⅴ在线观看| 男人的天堂亚洲| 美腿丝袜亚洲综合| 性色av一区二区三区四区| 免费欧美激情| 免费视频爱爱太爽了| 精品处破学生在线二十三| 欧美日韩在线网站| 亚洲福利在线视频| 亚洲精品免费一二三区| 久久av一区| 91传媒在线免费观看| 久久黄色精品视频| 91不卡在线观看| 五月婷婷综合网| 伊人网中文字幕| 日本高清在线观看视频| 国产剧情在线观看一区二区| 在线手机福利影院| 国产肉体ⅹxxx137大胆| 熟妇高潮一区二区高潮| 婷婷五月色综合| 国产在线观看网站| 欧美经典一区| 国产精品 欧美激情| 97视频资源在线观看| 久草在线免费二| 国产精品69久久久久| 国产97色在线|日韩| 尤物yw193can在线观看| 亚洲欧洲成视频免费观看| 久久久久久久久久久久久久久国产| 亚洲高清资源在线观看| 少妇人妻无码专区视频| 国产高清自拍视频在线观看| 欧美一乱一性一交一视频| 欧美精品第三页| 亚洲国产欧美日韩在线观看第一区| 日本在线观看高清完整版| 欧美电影网站| 欧洲一级视频| 中日韩黄色大片| 国产精成人品免费观看| 91精品秘密在线观看| 日韩在线视频免费| 91精品综合久久久久久| 丁香五六月婷婷久久激情| 狠狠色综合网站久久久久久久| 亚洲国产免费av| 四虎成人精品永久免费av| 黄色一级片网址| 精品视频在线免费观看| 国产日韩视频一区| 亚洲电影免费观看高清| 国产精久久久| 国产精品88a∨| 中文字幕亚洲在线观看| 日韩在线视频一区| 欧美精品久久久久久久| 日韩不卡免费视频| 亚洲国产一区在线| 日韩精品一区二区三区外面| 超污网站在线观看| 国产黄在线播放| 国产精品久久久免费视频| av免费观看一区二区| 久青草国产在线| 亚洲av无码精品一区二区| 国产日本在线视频| 成 人 黄 色 小说网站 s色| 国产亚洲精品久| 忘忧草在线日韩www影院| 1pon在线| 欧美激情黑人| 欧美在线视屏| 中文字幕一区二区三区乱码图片| 青青久久av北条麻妃海外网| 麻豆一二三区精品蜜桃| 欧美日韩视频精品二区| 精品久久人人做人人爱| 精品夜色国产国偷在线| 国产精品久久av| 性欧美视频videos6一9| 亚洲+变态+欧美+另类+精品| 欧洲美女免费图片一区| 盗摄牛牛av影视一区二区| av永久不卡| 国产精品20p| 91精品入口蜜桃| 男女啪啪无遮挡网站| 欧美 激情 在线| 国内av免费观看| 精品久久人妻av中文字幕| 国产日韩欧美夫妻视频在线观看| 丝袜连裤袜欧美激情日韩| 亚洲欧美国产制服动漫| 91精品一区二区三区综合在线爱| 在线成人h网| 奇米精品一区二区三区四区| 超碰免费97在线观看| 亚洲国产欧洲综合997久久| freexxx性亚洲精品| 国产videos| 免费在线观看成人| 年轻的保姆91精品| 国产精品视频专区| 国产三区视频在线观看| 91日韩一区二区三区| 国产卡二和卡三的视频| 久久综合伊人77777麻豆最新章节| 成人免费一区二区三区牛牛| 国产精品白丝久久av网站| 一级片免费观看视频| 免费精品99久久国产综合精品| 无码人妻aⅴ一区二区三区69岛| 久久精品毛片| 精品写真视频在线观看| 欧美在线视频免费| 日本成址在线观看| 九九精品在线观看视频| 奇米综合一区二区三区精品视频| 日本xxxxxxxxxx75| 国产农村妇女毛片精品久久麻豆| 国产三级三级看三级| 巨胸大乳www视频免费观看| 国产福利精品视频| 日本久久一二三四| 视频一区二区三区在线看免费看| 国内精品久久久久久中文字幕| 在线精品日韩| 黄色在线免费网站| 最新国产露脸在线观看| 成人综合在线网站| 欧美一区二区三区人| 亚洲美女免费视频| 精品人妻无码一区二区三区蜜桃一| 99久精品视频在线观看视频| 凹凸国产熟女精品视频| 久草视频免费播放| 日本欧美电影在线观看| 欧美日韩亚洲视频一区| 亚洲乱码一区二区三区| 丰满少妇高潮在线观看| 999大胆视频| 国产精品一级二级三级| 麻豆中文一区二区| 色多多视频在线播放| 欧美另类视频| 国产女大学生av| 91av资源网| 国产午夜精品理论片a级大结局| 欧美日韩中文字幕一区二区三区| 国产美女无遮挡网站| 伊人影院综合网| 日韩视频免费观看高清在线视频| 国产99久久久久久免费看农村| 国产日韩欧美a| 欧美日韩五月天| 中国视频免男男gay| 国内成人免费视频| 永久免费无码av网站在线观看| 8x国产一区二区三区精品推荐| 一二三四国产精品| 国产一区二区久久久久| 国产又大又黄又爽| 欧美天堂一区二区三区| 亚洲高清自拍| 僵尸世界大战2 在线播放| 日韩精品久久久久久福利| 国产日韩在线亚洲字幕中文| 亚洲人成网站精品片在线观看| 91情侣在线视频| 一级片视频免费| 佐山爱在线视频| 成人区精品一区二区不卡| 无码人妻aⅴ一区二区三区有奶水| 性xxxfllreexxx少妇| 丝袜连裤袜欧美激情日韩| 精品成人a区在线观看| 久久伊99综合婷婷久久伊| 欧美另类videosbest视频| 成人精品美女隐私视频| 欧洲一区在线电影| 国产精品一区二区三区在线播放| 日韩欧美一区二区三区四区五区| 欧美一区午夜精品| 91香蕉视频在线播放| 亚洲黄色小说网址| 国产999精品久久久影片官网| 精品视频中文字幕| 午夜精品免费看| 国产片高清在线观看| 欧美老熟妇乱大交xxxxx| 欧美三级午夜理伦三级中视频| 午夜不卡久久精品无码免费| videos性欧美另类高清| 国产精品久久久久久久第一福利| 亚亚洲欧洲精品| 亚洲一级二级在线| 精品久久av| 榴莲视频成人app| 成人精品视频一区| 91福利视频网站| 国产精品久久久久蜜臀| 在线视频cao| 男人午夜天堂| jizz视频播放器| 在线不卡视频一区二区| 中文字幕欧美一区| 国产精品186在线观看在线播放| 神马影院一区二区三区| 久久一区中文字幕| 亚洲国产欧美视频| 国产精品免费不| 狠狠噜天天噜日日噜| 亚洲欧美一区二区视频| 国产在线播精品第三| 7777精品伊人久久久大香线蕉完整版| 91高清视频免费观看| 国产一区二区精品丝袜| 8x国产一区二区三区精品推荐| 丁香激情综合五月| 久久综合激情网| 国产三级三级三级看三级| 亚洲精品久久久久久久久久久| 国产大片中文字幕| 成人免费电影网址| 国产视频在线一区| 欧美一级片在线免费观看| 97欧美成人| 欧美精品三级日韩久久| 国产福利一区二区三区| 一区二区三区在线影院| 国产原创一区二区| 亚洲一区亚洲二区| 国产黄色片在线播放| 中文文字幕一区二区三三| 国产黄色一区| 一区二区三区四区视频| 国产伦精品一区二区三区照片| caoporn免费在线视频|