午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 詳解組合模式的結構及其在Ruby設計模式編程中的運用

詳解組合模式的結構及其在Ruby設計模式編程中的運用

熱門標簽:白銀外呼paas系統 滴滴外呼系統 高德地圖標注客服 常德電銷平臺外呼系統軟件價格 電銷機器人廠商代理 百度地圖標注自定義圖片 湖州u友防封電銷卡 地圖標注賺錢項目注冊 徐州網絡外呼系統哪個好

定義:也叫合成模式,或者部分-整體模式,主要是用來描述部分與整體的關系,定義,將對象組合成樹形結構以表示“部分-整體”的層次結構,使得用戶對單個對象和組合對象的使用具有一致性。

類圖:

角色說明:

Componnent抽象構件角色:定義參加組合對象的共有方法和屬性,可以定義一些默認的行為或屬性。
Leaf葉子構件:葉子對象,其下再也沒有其他的分支,也就是遍歷的最小單位。
Composite樹枝構件:樹枝對象,它的作用是組合樹枝節點和葉子節點形成一個樹形結構。

實例:
聽說你們公司最近新推出了一款電子書閱讀應用,市場反應很不錯,應用里還有圖書商城,用戶可以在其中隨意選購自己喜歡的書籍。你們公司也是對此項目高度重視,加大了投入力度,決定給此應用再增加點功能。
好吧,你也知道你是逃不過此劫了,沒過多久你的leader就找到了你。他告訴你目前的應用對每本書的瀏覽量和銷售量做了統計,但現在想增加對每個書籍分類的瀏覽量和銷售量以及所有書籍總的瀏覽量和銷售量做統計的功能,希望你可以來完成這項功能。
領導安排的工作當然是推脫不掉的,你只能硬著頭皮上了,不過好在這個功能看起來也不怎么復雜。
你比較喜歡看小說,那么就從小說類的統計功能開始做起吧。首先通過get_all_novels方法可以獲取到所有的小說名,然后將小說名傳入get_browse_count方法可以得到該書的瀏覽量,將小說名傳入get_sale_count方法可以得到該書的銷售量。你目前只有這幾個已知的API可以使用,那么開始動手吧!

def get_novels_browse_count 
  browse_count = 0 
  all_novels = get_all_novels() 
  all_novels.each do |novel| 
    browse_count += get_browse_count(novel) 
  end 
  browse_count 
end 
 
def get_novels_sale_count 
  sale_count = 0 
  all_novels = get_all_novels() 
  all_novels.each do |novel| 
    sale_count += get_browse_count(novel) 
  end 
  sale_count 
end 

很快你就寫下了以上兩個方法,這兩個方法都是通過獲取到所有的小說名,然后一一計算每本小說的瀏覽量和銷售量,最后將結果相加得到總量。
小說類的統計就完成了,然后你開始做計算機類書籍的統計功能,代碼如下所示:

def get_computer_books_browse_count 
  browse_count = 0 
  all_computer_books = get_all_computer_books() 
  all_computer_books.each do |computer_book| 
    browse_count += get_browse_count(computer_book) 
  end 
  browse_count 
end 
 
def get_computer_books_sale_count 
  sale_count = 0 
  all_computer_books = get_all_computer_books() 
  all_computer_books.each do |computer_book| 
    sale_count += get_browse_count(computer_book) 
  end 
  sale_count 
end 

除了使用了get_all_computer_books方法獲取到所有的計算機類書名,其它的代碼基本和小說統計中的是一樣的。
現在你才完成了兩類書籍的統計功能,后面還有醫學類、自然類、歷史類、法律類、政治類、哲學類、旅游類、美食類等等等等書籍。你突然意識到了一些問題的嚴重性,工作量大倒還不算什么,但再這么寫下去,你的方法就要爆炸了,這么多的方法讓人看都看不過來,別提怎么使用了。
這個時候你只好向你的leader求助了,跟他說明了你的困惑。只見你的leader思考了片刻,然后自信地告訴你,使用組合模式不僅可以輕松消除你的困惑,還能出色地完成功能。
他立刻向你秀起了編碼操作,首先定義一個Statistics類,里面有兩個方法:

class Statistics 
   
  def get_browse_count 
    raise "You should override this method in subclass." 
  end 
   
  def get_sale_count 
    raise "You should override this method in subclass." 
  end 
   
end 

這兩個方法都是簡單地拋出一個異常,因為需要在子類中重寫這兩個方法。
然后定義一個用于統計小說類書籍的NovelStatistics類,繼承剛剛定義的Statistics類,并重寫Statistics中的兩個方法:

class NovelStatistics  Statistics 
 
  def get_browse_count 
    browse_count = 0 
    all_novels = get_all_novels() 
    all_novels.each do |novel| 
      browse_count += get_browse_count(novel) 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    all_novels = get_all_novels() 
    all_novels.each do |novel| 
      sale_count += get_browse_count(novel) 
    end 
    sale_count 
  end 
 
end 

在這兩個方法中分別統計了小說類書籍的瀏覽量和銷售量。那么同樣的方法,你的leader又定義了一個ComputerBookStatistics類用于統計計算機類書籍的瀏覽量和銷售量:

class ComputerBookStatistics  Statistics 
 
  def get_browse_count 
    browse_count = 0 
    all_computer_books = get_all_computer_books() 
    all_computer_books.each do |computer_book| 
      browse_count += get_browse_count(computer_book) 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    all_computer_books = get_all_computer_books() 
    all_computer_books.each do |computer_book| 
      sale_count += get_browse_count(computer_book) 
    end 
    sale_count 
  end 
 
end 

這樣將具體的統計實現分散在各個類中,就不會再出現你剛剛那種方法爆炸的情況了。不過這還沒開始真正使用組合模式呢,好戲還在后頭,你的leader吹噓道。

再定義一個MedicalBookStatistics類繼承Statistics,用于統計醫學類書籍的瀏覽量和銷售量,代碼如下如示:

class MedicalBookStatistics  Statistics 
 
  def get_browse_count 
    browse_count = 0 
    all_medical_books = get_all_medical_books() 
    all_medical_books.each do |medical_book| 
      browse_count += get_browse_count(medical_book) 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    all_medical_books = get_all_medical_books() 
    all_medical_books.each do |medical_book| 
      sale_count += get_browse_count(medical_book) 
    end 
    sale_count 
  end 
 
end 

不知道你發現了沒有,計算機類書籍和醫學類書籍其實都算是科技類書籍,它們是可以組合在一起的。這個時候你的leader定義了一個TechnicalStatistics類用于對科技這一組合類書籍進行統計:

class TechnicalStatistics  Statistics 
 
  def initialize 
    @statistics = [] 
    @statistics  ComputerBookStatistics.new 
    @statistics  MedicalBookStatistics.new 
  end 
 
  def get_browse_count 
    browse_count = 0 
    @statistics.each do |s| 
      browse_count += s.get_browse_count 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    @statistics.each do |s| 
      sale_count += s.get_sale_count 
    end 
    sale_count 
  end 
 
end 

可以看到,由于這個類是組合類,和前面幾個類還是有不少區別的。首先TechnicalStatistics中有一個構造函數,在構造函數中將計算機類書籍和醫學類書籍作為子分類添加到statistics數組當中,然后分別在get_browse_count和get_sale_count方法中遍歷所有的子分類,計算出它們各自的瀏覽量和銷售量,然后相加得到總額返回。
組合模式的擴展性非常好,沒有各種條條框框,想怎么組合就怎么組合,比如所有書籍就是由各個分類組合而來的,你的leader馬上又向你炫耀了統計所有書籍的瀏覽量和銷售量的辦法。
定義一個AllStatistics類繼承Statistics,具體代碼如下所示:

class AllStatistics  Statistics 
 
  def initialize 
    @statistics = [] 
    @statistics  NovelStatistics.new 
    @statistics  TechnicalStatistics.new 
  end 
 
  def get_browse_count 
    browse_count = 0 
    @statistics.each do |s| 
      browse_count += s.get_browse_count 
    end 
    browse_count 
  end 
   
  def get_sale_count 
    sale_count = 0 
    @statistics.each do |s| 
      sale_count += s.get_sale_count 
    end 
    sale_count 
  end 
 
end 

在AllStatistics的構造函數中將小說類書籍和科技類書籍作為子分類添加到了statistics數組當中,目前你也就只寫好了這幾個分類。然后使用同樣的方法在get_browse_count和get_sale_count方法中統計出所有書籍的瀏覽量和銷售量。
當前組合結構的示意圖如下:

現在你就可以非常方便的得到任何分類書籍的瀏覽量和銷售量了,比如說獲取科技類書籍的瀏覽量,你只需要調用:

TechnicalStatistics.new.get_browse_count 

而獲取所有書籍的總銷量,你只需要調用:

AllStatistics.new.get_sale_count 

當然你后面還可以對這個組合結構隨意地改變,添加各種子分類書籍,而且子分類的層次結構可以任意深,正如前面所說,組合模式的擴展性非常好。
你的leader告訴你,目前他寫的這份代碼重復度比較高,其實還可以好好優化一下的,把冗余代碼都去除掉。當然這個任務就交給你來做了,你的leader可是大忙人,早就一溜煙跑開了。

總結

組合模式的優點:
能夠靈活的組合局部對象和整體對象之間的關心,對客戶端來說,局部對象和整體對象的調用沒有差別,使調用簡單。

組合模式的缺點:
1.組合操作的成本很高,如果一個對象樹中有很多子對象,可能一個簡單的調用就可能使系統崩潰;
2.對象持久化的問題,組合模式是樹形結構,不能很好地在關系數據庫中保存數據,但是卻非常適合用于xml持久化。

組合模式的適用場景:
1.維護和展示部分—整體關系得場景,如樹形菜單、文件和文件夾管理。
2.從一個整體中能夠獨立出部分模塊或功能的場景。

您可能感興趣的文章:
  • 設計模式中的觀察者模式在Ruby編程中的運用實例解析
  • 實例解析Ruby設計模式開發中對觀察者模式的實現
  • 深入剖析Ruby設計模式編程中對命令模式的相關使用
  • Ruby設計模式編程中對外觀模式的應用實例分析
  • 設計模式中的模板方法模式在Ruby中的應用實例兩則
  • 實例解析Ruby設計模式編程中Strategy策略模式的使用
  • 實例講解Ruby使用設計模式中的裝飾器模式的方法
  • Ruby設計模式編程中使用Builder建造者模式的實例
  • 詳解Ruby設計模式編程中對單例模式的運用
  • Ruby設計模式編程之適配器模式實戰攻略
  • Ruby使用設計模式中的代理模式與裝飾模式的代碼實例
  • Ruby中使用設計模式中的簡單工廠模式和工廠方法模式
  • 解析proxy代理模式在Ruby設計模式開發中的運用

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

巨人網絡通訊聲明:本文標題《詳解組合模式的結構及其在Ruby設計模式編程中的運用》,本文關鍵詞  詳解,組合,模式,的,結構,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解組合模式的結構及其在Ruby設計模式編程中的運用》相關的同類信息!
  • 本頁收集關于詳解組合模式的結構及其在Ruby設計模式編程中的運用的相關信息資訊供網民參考!
  • 推薦文章
    亚洲欧美色图小说| 亚洲性生活视频| 中文字幕av一区二区三区高| 成人午夜免费视频| 国产成人免费在线观看不卡| 性网爆门事件集合av| 亚洲第一天堂久久| 国内精品小视频在线观看| www.激情成人| 91制片厂在线| 宅男av一区二区三区| 一个色综合av| 日韩欧美在线播放视频| 性感美女久久精品| 国产精品中文久久久久久| 午夜精品区一区二区三| 亚洲人成电影网站色xx| 国产精品白丝av| 欧美成人精品欧美一级私黄| xxxx 国产| 美国精品一区二区| xxxx黄色片| 亚洲精品鲁一鲁一区二区三区| 国产精品波多野结衣| 国产91精品久久久久久久| 最新成人av在线| 亚洲综合精品国产一区二区三区| 国产a级片视频| 欧美黑人巨大精品一区二区| 这里只有精品6| 亚洲成人在线视频播放| 无码人妻aⅴ一区二区三区有奶水 无码免费一区二区三区 | 欧美国产日本韩| 国产精品va无码一区二区三区| 成人久久久久久久久| 久久精品国产精品国产精品污| 亚洲精品国产综合区久久久久久久| 精品久久久无码中文字幕| 久久久999免费视频| 国产在线观看精品| 欧美精品一二三区| 一级黄色性视频| 人体精品一二三区| 国产精品66部| 亚洲激情 欧美| 欧美成人免费高清视频| 国产色综合天天综合网 | 一区二区冒白浆视频| 久久精品国产精品青草色艺| y111111国产精品久久婷婷| 国产亚洲美女精品久久久| 国产欧美精品区一区二区三区 | 三级a在线观看| 欧美一区二区三区婷婷月色| 一区二区三区精彩视频| 一本—道久久a久久精品蜜桃| 成人黄色av播放免费| 亚洲欧美日韩另类| 国产精品久久久久久亚洲伦 | av一区二区三区免费| 97在线日本国产| 欧美一区二区三区免费观看视频| 国产福利一区二区三区视频| 亚洲天堂aaa| 欧美人与性囗牲恔配| 800av在线免费观看| 欧美日韩成人一区二区| av高清一区二区| 日av中文字幕| 国产精品久久久久久久电影| 91高清视频免费观看| 91麻豆精品国产自产在线| 国产精品久久一级| 亚洲成在线观看| 91精品福利视频| 欧美酷刑日本凌虐凌虐| 午夜婷婷国产麻豆精品| 一级成人免费视频| 久草福利资源在线| 国产淫片av片久久久久久| 欧美成人精品激情在线观看| 丰满少妇一区二区| 日本乱人伦a精品| 秋霞av国产精品一区| 一本色道久久综合狠狠躁篇的优点| 日韩美女视频一区二区| 国产精品国产三级国产传播| 美女在线免费视频| 欧美激情一级二级| 欧美午夜无遮挡| 美女视频一区二区| 亚洲图片另类小说| 蜜臀在线免费观看| 国产精品国模在线| 欧美亚洲尤物久久| 国产精品中文有码| 国产亚洲成人av| 黄色a级片免费| 91网站免费观看| 日韩午夜精品电影| 久久久亚洲欧洲日产国码αv| 婷婷色在线视频| 欧美 日韩 国产在线观看| 欧美日韩一区二区欧美激情 | 国产爆乳无码一区二区麻豆| 国产精品wwwww| 男女性高潮免费网站| 麻豆成人久久精品二区三区小说| 欧美性xxxx极品高清hd直播| 一区二区三区久久精品| 天天影视涩香欲综合网| 精品人妻一区二区三区三区四区| 我和岳m愉情xxxⅹ视频| 爆乳熟妇一区二区三区霸乳| 91美女片黄在线观看游戏| 97视频在线观看视频免费视频 | 日韩av片网站| 激情五月六月婷婷| 中文字幕日韩综合| 精品在线不卡| 国产成人综合亚洲| 人成网站在线观看| 五月婷婷激情视频| 福利电影一区二区| 国产精品久久网站| 欧美xxxx老人做受| 欧美疯狂做受xxxx高潮| 欧美另类z0zxhd电影| 日韩精品免费一线在线观看| 日韩一二三在线视频播| 国产精品久久久久久免费观看 | 国产三级精品三级在线| 国产精品一区二区人人爽| 久久丝袜美腿综合| 亚洲色图欧洲色图| 在线区一区二视频| 亚洲毛片在线看| 丁香婷婷久久久综合精品国产 | xxxx国产精品| 人人妻人人爽人人澡人人精品| 久草视频手机在线观看| 婷婷激情四射网| 国产免费福利视频| 国产成人精品一区二区三区四区 | 亚州国产精品久久久| 日韩亚洲一区在线播放| 亚洲免费激情视频| 日本福利一区二区| 欧美一区二区三区四区在线观看地址| 国产黄色片视频| 久久影院午夜论| 欧美日韩成人综合天天影院| 欧美—级a级欧美特级ar全黄| 51国产成人精品午夜福中文下载| 一道本在线观看视频| 一区二区三区影视| 国产小视频在线观看免费| 国产精品99久久久久久成人| 久久国产精品国语对白| 男女做暖暖视频| 久久久一二三区| 99九九99九九九视频精品| 精品国产在天天线2019| 日本精品久久久| 国产精品沙发午睡系列| 精品乱码一区内射人妻无码| 亚洲精品成人网| 免费黄色在线播放| 黄色成人在线播放| 日韩久久午夜影院| 欧美日韩在线一区二区三区| 日本污视频网站| 熟妇人妻中文av无码| 一二三区精品视频| 日韩一区二区精品视频| 好吊色视频988gao在线观看| 韩国三级与黑人| 亚洲蜜桃精久久久久久久久久久久| 精品国产大片大片大片| 91好色先生tv| 国产精品一区二区在线观看不卡| 精品国产成人系列| 国产一区二区久久久| 男人女人拔萝卜视频| 日韩精品国产欧美| 欧美三区在线观看| 日韩一区二区视频在线观看| 精品国产综合久久| 日韩精品一区二区三区高清免费| 91一区二区三区在线观看| 欧美日韩综合久久| 国产99久久九九精品无码免费| 亚洲午夜色婷婷在线| 奇米影视四色在线| 亚洲综合色网站| 成人国产1314www色视频| 摸摸摸bbb毛毛毛片| 亚洲第一视频在线播放| 日韩免费高清视频| 清纯唯美一区二区三区| 亚洲欧美综合自拍| 亚洲av无码专区在线| 亚洲精品视频在线看| 欧美丰满片xxx777| 日本熟女一区二区| 欧美日韩国产精品| 久久久久成人网| 中文字幕成人免费视频| 美腿丝袜亚洲综合| 色哟哟一区二区在线观看| 91精品国产亚洲| 免费在线观看日韩| 91丨porny丨户外露出| 中日韩一级黄色片| 俄罗斯黄色录像| 日本高清久久久| 国产精品秘入口18禁麻豆免会员| 亚洲一区精品视频| 欧洲亚洲一区二区三区四区五区| 99porn视频在线| 日韩美女毛茸茸| 91精品国产91久久久久久久久| 中文字幕观看视频| 亚洲视频在线播放| 免费看的黄色大片| 成年人晚上看的视频| 在线观看国产三级| 午夜性福利视频| 自拍偷拍一区二区三区四区| 男人操女人免费软件| 欧美高清中文字幕| 欧美另类videosbestsex日本| 日韩欧美一区二区三区久久婷婷| 国产日韩二区| 99视频在线播放| 成人动漫视频在线观看免费| 91精品综合久久| 国产精品yjizz| 精品欧美国产| 欧美日韩大片一区二区三区| 免费亚洲精品视频| 日本免费高清不卡| 亚洲精品久久久久久一区二区| 亚洲精品国产一区| japanese在线播放| h无码动漫在线观看| 9久久9毛片又大又硬又粗| 青青草视频在线免费播放| 午夜免费福利小电影| 中国丰满人妻videoshd| 欧美视频第三页| 婷婷激情四射五月天| 手机av在线免费| 一级黄色免费视频| xxxxx在线观看| 色综合视频网站| 一区二区传媒有限公司| 中文字幕在线视频第一页| 日韩一区二区三区四区五区六区| 亚洲开发第一视频在线播放| 激情五月深爱五月| 国产精品视频一二三| 国产 欧美在线| 韩国成人av| 成人免费毛片嘿嘿连载视频| 成人欧美一区二区| 空姐吹箫视频大全| 国产丝袜精品第一页| 久久精品视频在线观看免费| 国产精品三级av| 警花观音坐莲激情销魂小说| 国产午夜精品在线观看| 国产精品福利视频| 国产黄色一级大片| 亚洲欧美制服另类日韩| 男女视频在线看| 国产精选一区二区三区| 日本高清视频一区| 久久久久99精品成人片毛片| 国产精品视频麻豆| 大陆极品少妇内射aaaaaa| 日韩精品视频网| 日韩免费精品视频| 久久免费激情视频| 亚洲第一偷拍网| 97超碰在线资源| 中文字幕一区电影| 三级不卡在线观看| 日本一区免费在线观看| 国产精品69久久久久水密桃| 久久久99精品视频| 亚洲精品伦理在线| 美女av免费观看| 久久综合给合久久狠狠狠97色69| 亚洲人成77777| 91免费观看国产| 国内不卡一区二区三区| 国产精品久久久久久久久久久久久久久久 | 久久久久久国产| 午夜国产福利一区二区| 精品国产乱码久久久久久夜甘婷婷| 在线免费黄色小视频| 精品久久中文字幕久久av| 国产精品av免费| 久久99精品一区二区三区三区| 欧美中文在线字幕| 日韩毛片在线播放| 久久中文字幕在线视频| 超碰97人人干| 一区二区欧美视频| 日韩欧美不卡在线| 久久亚洲精品国产精品紫薇| 色涩成人影视在线播放| 国产成人精品亚洲777人妖| 九九九久久久| 国产欧美视频一区二区三区| 久久99精品久久久久久秒播放器| 国产美女久久久久| 中文字幕第80页| 在线观看免费一区| 亚洲国产精品狼友在线观看| 精品久久五月天| 麻豆91精品91久久久| 在线中文字幕日韩| 日本免费在线观看视频| 最近2019中文字幕第三页视频| 特一级黄色录像| 欧美精品一区二区三区国产精品| 在线能看的av| 亚洲aⅴ男人的天堂在线观看| 国产精一品亚洲二区在线视频| 国产成人精品福利一区二区三区 | 黄网在线观看视频| 亚洲嫩模很污视频| 中文字幕91爱爱| 91日本在线视频| 2020国产精品自拍| 免费成人在线视频网站| 国产日韩在线不卡| 综合国产精品久久久| 久久青草国产手机看片福利盒子| 伊人情人网综合| 国产精品天干天干在线综合| 日韩Av无码精品| 亚洲成人精品在线播放| 日韩精品一区不卡| aaa欧美日韩| 欧美一级黄色大片| 国产精品成人播放| 日本手机在线视频| 欧美日韩在线国产| 91在线播放观看| 日本一区二区在线| av观看免费在线| 精品成人久久久| 国产成人精品1024| 69成人精品免费视频| 国产福利成人在线| 国模无码视频一区二区三区| 久久成人国产精品入口| 国产一二三精品| 欧美人与z0zoxxxx视频| 国产精品99一区| mm1313亚洲国产精品无码试看| 久久久久久久久久影院| 欧美日韩亚洲一区二区三区四区| 少妇网站在线观看| 欧美一区二区三区网站| 国产欧美视频一区二区| 亚洲图片在区色| 欧洲精品码一区二区三区免费看| 法国伦理少妇愉情| 日本91福利区| 欧美日韩国产一区二区三区地区| 国产精品高潮呻吟久久av黑人| 欧美伦理视频在线观看| 最新黄色网址在线观看| 国产精品三级av| 久久午夜a级毛片| 特级西西人体www高清大胆| 欧美人禽zoz0强交| av在线综合网| 亚洲毛片在线看| 视频一区不卡| 永久看片925tv| 91丨九色porny丨蝌蚪| 亚洲欧美日韩一区二区三区在线| 日韩国产欧美精品| av激情在线观看| 国产亚洲视频系列| 另类色图亚洲色图| 无码人妻丰满熟妇区96| 中文字幕免费观看视频| 亚洲高清免费观看高清完整版在线观看| 欧美激情综合色| 日韩中文字幕二区| 精品久久久久久亚洲综合网站| 色哟哟一区二区三区| 亚洲综合大片69999| 精品少妇人妻一区二区黑料社区 | 中文字幕人成人乱码亚洲电影| 亚洲日本在线看| 日本中文字幕不卡免费| 91视频免费入口| 麻豆精品国产91久久久久久| 精品少妇一区二区三区日产乱码| 欧美日韩成人一区二区三区| 麻豆视频在线观看| 亚洲素人一区二区| 国产成人av网|