<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    如何學(xué)好java

    如何學(xué)好java,其實(shí)很簡(jiǎn)單,只要用心體會(huì),慢慢積累!
    posts - 106, comments - 7, trackbacks - 0, articles - 3
      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

    2012年11月21日

    http://www.luocong.com/dsaanotes/index-Z-H-1.htm

    posted @ 2014-01-02 22:50 哈希 閱讀(135) | 評(píng)論 (0)編輯 收藏

         摘要: 冒泡排序(Bubble Sort)是一種簡(jiǎn)單的排序算法。它重復(fù)地走訪過(guò)要排序的數(shù)列,一次比較兩個(gè)元素,如果他們的順序錯(cuò)誤就把他們交換過(guò)來(lái)。走訪數(shù)列的工作是重復(fù)地進(jìn)行直到?jīng)]有再需要交換,也就是說(shuō)該數(shù)列已經(jīng)排序完成。這個(gè)算法的名字由來(lái)是因?yàn)樵叫〉脑貢?huì)經(jīng)由交換慢慢“浮”到數(shù)列的頂端。   冒泡排序算法的運(yùn)作如下:  比較相鄰的元素。如果第一個(gè)比第二個(gè)大,就交換他們...  閱讀全文

    posted @ 2014-01-02 22:32 哈希 閱讀(191) | 評(píng)論 (0)編輯 收藏

    http://www.cnblogs.com/szfei/archive/2012/08/08/2628208.html    hashmap遍歷

    posted @ 2012-12-22 10:45 哈希 閱讀(153) | 評(píng)論 (0)編輯 收藏

    基本介紹:
              showModalDialog()         (IE 4+ 支持)
              showModelessDialog()      (IE 5+ 支持)
              window.showModalDialog()                  方法用來(lái)創(chuàng)建一個(gè)顯示HTML內(nèi)容的模態(tài)對(duì)話框。
              window.showModelessDialog()             方法用來(lái)創(chuàng)建一個(gè)顯示HTML內(nèi)容的非模態(tài)對(duì)話框。
    使用方法:
              vReturnValue = window.showModalDialog(sURL [, vArguments] [,sFeatures])
              vReturnValue = window.showModelessDialog(sURL [, vArguments] [,sFeatures])
    參數(shù)說(shuō)明:
             sURL          --  必選參數(shù),類型:字符串。用來(lái)指定對(duì)話框要顯示的文檔的URL。
             vArguments    -- 可選參數(shù),類型:變體。用來(lái)向?qū)υ捒騻鬟f參數(shù)。傳遞的參數(shù)類型不限,包括數(shù)組等。對(duì)話框通過(guò)
     

                              window.dialogArguments來(lái)取得傳遞進(jìn)來(lái)的參數(shù)。
             sFeatures     -- 可選參數(shù),類型:字符串。用來(lái)描述對(duì)話框的外觀等信息,可以使用以下的一個(gè)或幾個(gè),用分號(hào)“;”隔開(kāi)。
    ----------------
    1.    dialogHeight:    對(duì)話框高度,不小于100px
    2.    dialogWidth:    對(duì)話框?qū)挾取?br />3.    dialogLeft:     離屏幕左的距離。
    4.    dialogTop:     離屏幕上的距離。
    5.    center:          { yes | no | 1 | 0 } :              是否居中,默認(rèn)yes,但仍可以指定高度和寬度。
    6.    help:             {yes | no | 1 | 0 }:                是否顯示幫助按鈕,默認(rèn)yes。
    7.    resizable:       {yes | no | 1 | 0 } [IE5+]:     是否可被改變大小。默認(rèn)no。
    8.    status:          {yes | no | 1 | 0 } [IE5+]:      是否顯示狀態(tài)欄。默認(rèn)為yes[ Modeless]或no[Modal]。
    9.    scroll:            { yes | no | 1 | 0 | on | off }:是否顯示滾動(dòng)條。默認(rèn)為yes。

    下面幾個(gè)屬性是用在HTA中的,在一般的網(wǎng)頁(yè)中一般不使用。
    10.    dialogHide:{ yes | no | 1 | 0 | on | off }:在
    打印或者打印預(yù)覽時(shí)對(duì)話框是否隱藏。默認(rèn)為no。
    11.    edge:{ sunken | raised }:指明對(duì)話框的邊框樣式。默認(rèn)為raised。
    12.    unadorned:{ yes | no | 1 | 0 | on | off }:默認(rèn)為no。

    參數(shù)傳遞:
    1. 要想對(duì)話框傳遞參數(shù),是通過(guò)vArguments來(lái)進(jìn)行傳遞的。類型不限制,對(duì)于字符串類型,最大為4096個(gè)字符。也可以傳遞對(duì)象,例如:
    -------------------------------
    parent.htm
    <script>
              var obj = new Object();
              obj.name="51js";
              window.showModalDialog("modal.htm",obj,"dialogWidth=200px;dialogHeight=100px");
    </script>
    modal.htm
    <script>
              var obj = window.dialogArguments
              alert("您傳遞的參數(shù)為:" + obj.name)
    </script>
    -------------------------------
    2.可以通過(guò)window.returnValue向打開(kāi)對(duì)話框的窗口返回信息,當(dāng)然也可以是對(duì)象。例如:
    ------------------------------
    parent.htm
    <script>
              str =window.showModalDialog("modal.htm",,"dialogWidth=200px;dialogHeight=100px");
              alert(str);
    </script>
    modal.htm
    <script>
              window.returnValue="http://homepage.yesky.com";
    </script>

    常見(jiàn)技巧:

    一、怎樣才讓在showModalDialog和showModelessDialog的超連接不彈出新窗口?
      在被打開(kāi)的網(wǎng)頁(yè)里加上<base target="_self">就可以了。這句話一般是放在<head>之間的。

    二、怎樣才刷新showModalDialog和showModelessDialog里的內(nèi)容?
      在showModalDialog和showModelessDialog里是不能按F5刷新的,又不能彈出菜單。這個(gè)只能依靠

    javascript了,以下是相關(guān)代碼:

    <body onkeydown="if (event.keyCode==116){reload.click()}">
    <a id="reload" href="filename.htm" style="display:none">reload...</a>

      將filename.htm替換成網(wǎng)頁(yè)的名字然后將它放到你打開(kāi)的網(wǎng)頁(yè)里,按F5就可以刷新了,注意,這個(gè)要

    配合<base target="_self">使用,不然你按下F5會(huì)彈出新窗口的。

    三、如何用javascript關(guān)掉showModalDialog(或showModelessDialog)打開(kāi)的窗口。
      <input type="button" value="關(guān)閉" onclick="window.close()">
      也要配合<base target="_self">,不然會(huì)打開(kāi)一個(gè)新的IE窗口,然后再關(guān)掉的。

    四、Math.random與showModalDialog。

       當(dāng)你設(shè)置的彈出網(wǎng)頁(yè)固定時(shí)(如上面的"modal.htm"頁(yè)面),ie很可能到臨時(shí)文件區(qū),下載上次產(chǎn)生的該頁(yè)面(openPage.html),而沒(méi)有重新加載,

       對(duì)于動(dòng)態(tài)加載的頁(yè)面來(lái)說(shuō),這樣往往產(chǎn)生誤會(huì),如沒(méi)有及時(shí)更新數(shù)據(jù),也就更不利于開(kāi)發(fā)者測(cè)試。所以,你可以采用如下方式:

          var strPage = “/medal.htm?random="+Math.random();

       這樣每次產(chǎn)生的strPage是不一樣的,原因也就不言自明了。

     

    下面舉兩個(gè)例子

    一、返回一個(gè)字符串

    首先是父頁(yè)面有個(gè)按鈕,用來(lái)打開(kāi)Modal頁(yè)面userList.aspx

    復(fù)制代碼
     function openWin()
        {
             str =window.showModalDialog("userList.aspx",window,"status:0;help:0;edge:sunken;dialogWidth=700px;dialogHeight=400px");

            if(str!=undefined && typeof(str)!=undefined && str!="undefined" && str!="")
            {
              document.getElementById("txtuserid").value=str;
            }else
            {
             document.getElementById("txtuserid").value="";
            }
        }
    復(fù)制代碼

    str就是子頁(yè)面返回過(guò)來(lái)的數(shù)據(jù),我們把它添加到父類的一個(gè)表單元素中

    子頁(yè)面

        function getValue()
            {          
             var selectValue=$(":radio:checked").val();
             window.returnValue=selectValue;
             window.close();
            }

    在這里我們把子頁(yè)面里的值返回到父頁(yè)面里就可以了,然后關(guān)閉頁(yè)面就可以了

    二、返回一個(gè)數(shù)據(jù)

    父頁(yè)面

    復(fù)制代碼
         function openWin()
         {
     
            array =window.showModalDialog("demo2.aspx",window,"status:0;help:0;edge:sunken;dialogWidth=700px;dialogHeight=400px;scroll:no");
           
              document.getElementById("username").value=array[0];
              document.getElementById("sex").value=array[0];
             
         
        }
    復(fù)制代碼

    子頁(yè)面

     

    復(fù)制代碼
       function getValue()
           {
             var array=new Array();
             
             array[0]=document.getElementById("username").value;
             Array[1]=document.getElementById("sex").value;
             window.returnValue=array;
             window.close();
           }
    復(fù)制代碼

    返回一個(gè)數(shù)組就可以了,如果用open打開(kāi)的話,在搜狗或者360瀏覽器打開(kāi)的是一個(gè)頁(yè)面或者阻攔什么的

     前段時(shí)間在后臺(tái)使用JS的winodw.showModalDialog來(lái)查看靜態(tài)頁(yè)面內(nèi)容,發(fā)現(xiàn)不能及時(shí)顯示更新后的頁(yè)面內(nèi)容,用open打開(kāi)有時(shí)也會(huì)出現(xiàn)這種問(wèn)題

    解決辦法 
      window.showModalDialog(getUrl+"?Rnd="+Math.random(),"","dialogWidth:600px;dialogHeight:400px;help:no;scroll:yes;center:yes;status:no;");
    這樣就不會(huì)有緩存了

    多思考,多創(chuàng)新,才是正道!

    posted @ 2012-11-26 12:51 哈希 閱讀(909) | 評(píng)論 (1)編輯 收藏

    1.判斷select選項(xiàng)中 是否存在Value="paraValue"的Item 
    $("#selectid option[@value='paraValue']").length>0
    2.向select選項(xiàng)中 加入一個(gè)Item 
    $("#selectid").append("<option value=''>1111<option>");
    3.從select選項(xiàng)中 刪除一個(gè)Item 
    $("#selectid").remove("<option value=''>1111<option>");
    4.修改select選項(xiàng)中 value="paraValue"的text為"paraText" 
    $("#selectid option:selected").attr("value","paraValue").attr("text","paraText");
    5. 設(shè)置select中text="paraText"的第一個(gè)Item為選中 
    $("#selectid option[@text='paraText']").attr("selected","true")
    6.設(shè)置select中 value="paraValue"的Item為選中 
    $("#selectid option[@value='paraValue']").attr("selected","true")

    7.設(shè)置select中第一 個(gè)Item為選中 
    $("#selectid option").eq(0).attr('selected', 'true');

    8. 得到select的當(dāng)前選中項(xiàng)的value 
    $("#selectid").val();
    9.得到select的當(dāng)前選中項(xiàng)的text 
    $("#selectid").text();
    10. 得到select的當(dāng)前選中項(xiàng)的Index 
    document.getElementById("select1").selectedIndex;
    $("#selectid").get(0).selectedIndex
    11. 清空select的項(xiàng)
    $("#selectid").empty();

    JS版本的:

  • //1.判斷select選項(xiàng)中 是否存在Value="paraValue"的Item   
  • function jsSelectIsExitItem(objSelect,objItemValue)   
  • {   
  •      var isExit = false ;   
  •      for ( var i=0;i;I++)   
  •      {   
  •          if (objSelect.options[i].value == objItemValue)   
  •          {   
  •              isExit = true ;   
  •              break ;   
  •          }   
  •      }        
  •      return isExit;   
  • }   
  •   
  • //2.向select選項(xiàng)中 加入一個(gè)Item   
  • function jsAddItemToSelect(objSelect,objItemText,objItemValue, objItemPos)   
  • {   
  •      //判斷是否存在   
  •      if (jsSelectIsExitItem(objSelect,objItemValue))   
  •      {   
  •          alert( "該Item的 Value值已經(jīng)存在" );   
  •      }   
  •      else   
  •      {   
  •          var varItem = new Option(objItemText,objItemValue);   
  • //       objSelect.options[objSelect.options.length] = varItem;   
  •          objSelect.options.add(varItem, objItemPos);   
  •          alert( "成功加入" );   
  •      }      
  • }   
  •   
  • //3.從select選項(xiàng)中 刪除一個(gè)Item   
  • function jsRemoveItemFromSelect(objSelect,objItemValue)   
  • {   
  •      //判斷是否存在   
  •      if (jsSelectIsExitItem(objSelect,objItemValue))   
  •      {   
  •          for ( var i=0;i;I++)   
  •          {   
  •              if (objSelect.options[i].value == objItemValue)   
  •              {   
  •                  objSelect.options.remove(i);   
  •                  break ;   
  •              }   
  •          }          
  •          alert( "成功刪除" );              
  •      }   
  •      else   
  •      {   
  •          alert( "該 select中 不存在該項(xiàng)" );   
  •      }      
  • }   
  •   
  • //4.修改select選項(xiàng)中 value="paraValue"的text為"paraText"   
  • function jsUpdateItemToSelect(objSelect,objItemText,objItemValue)   
  • {   
  •      //判斷是否存在   
  •      if (jsSelectIsExitItem(objSelect,objItemValue))   
  •      {   
  •          for ( var i=0;i;I++)   
  •          {   
  •              if (objSelect.options[i].value == objItemValue)   
  •              {   
  •                  objSelect.options[i].text = objItemText;   
  •                  break ;   
  •              }   
  •          }          
  •          alert( "成功修改" );              
  •      }   
  •      else   
  •      {   
  •          alert( "該 select中 不存在該項(xiàng)" );   
  •      }      
  • }   
  •           
  • //5.設(shè)置select中text="paraText"的第一個(gè) Item為選中   
  • function jsSelectItemByValue(objSelect,objItemText)   
  • {      
  •      //判斷是否存在   
  •      var isExit = false ;   
  •      for ( var i=0;i;I++)   
  •      {   
  •          if (objSelect.options[i].text == objItemText)   
  •          {   
  •              objSelect.options[i].selected = true ;   
  •              isExit = true ;   
  •              break ;   
  •          }   
  •      }        
  •      //Show出結(jié)果   
  •      if (isExit)   
  •      {   
  •          alert( "成功選中" );              
  •      }   
  •      else   
  •      {   
  •          alert( "該 select中 不存在該項(xiàng)" );   
  •      }      
  • }   
  •   
  • //6.設(shè)置select中value="paraValue"的Item 為選中   
  • document.all.objSelect.value = objItemValue;   
  •   
  • //7.得到select的當(dāng)前選中項(xiàng)的value   
  • var currSelectValue = document.all.objSelect.value;   
  •   
  • //8.得到select的當(dāng)前選中項(xiàng)的text   
  • var currSelectText = document.all.objSelect.options[document.all.objSelect.selectedIndex].text;   
  •   
  • //9.得到select的當(dāng)前選中項(xiàng)的Index   
  • var currSelectIndex = document.all.objSelect.selectedIndex;   
  •   
  • //10.清空select的項(xiàng)   
  • document.all.objSelect.options.length = 0;  
  • posted @ 2012-11-26 12:46 哈希 閱讀(232) | 評(píng)論 (0)編輯 收藏

    封裝 繼承 多態(tài)

    面向?qū)ο蟮娜齻€(gè)基本特征是:封裝、繼承、多態(tài)。

     

    封裝

    封裝最好理解了。封裝是面向?qū)ο蟮奶卣髦唬菍?duì)象和類概念的主要特性。

    封裝,也就是把客觀事物封裝成抽象的類,并且類可以把自己的數(shù)據(jù)和方法只讓可信的類或者對(duì)象操作,對(duì)不可信的進(jìn)行信息隱藏。

    繼承

    面向?qū)ο缶幊?(OOP) 語(yǔ)言的一個(gè)主要功能就是“繼承”。繼承是指這樣一種能力:它可以使用現(xiàn)有類的所有功能,并在無(wú)需重新編寫原來(lái)的類的情況下對(duì)這些功能進(jìn)行擴(kuò)展。

    通過(guò)繼承創(chuàng)建的新類稱為“子類”或“派生類”。

    被繼承的類稱為“基類”、“父類”或“超類”。

    繼承的過(guò)程,就是從一般到特殊的過(guò)程。

    要實(shí)現(xiàn)繼承,可以通過(guò)“繼承”(Inheritance)和“組合”(Composition)來(lái)實(shí)現(xiàn)。

    在某些 OOP 語(yǔ)言中,一個(gè)子類可以繼承多個(gè)基類。但是一般情況下,一個(gè)子類只能有一個(gè)基類,要實(shí)現(xiàn)多重繼承,可以通過(guò)多級(jí)繼承來(lái)實(shí)現(xiàn)。

    繼承概念的實(shí)現(xiàn)方式有三類:實(shí)現(xiàn)繼承、接口繼承和可視繼承。

    Ø 實(shí)現(xiàn)繼承是指使用基類的屬性和方法而無(wú)需額外編碼的能力;

    Ø 接口繼承是指僅使用屬性和方法的名稱、但是子類必須提供實(shí)現(xiàn)的能力;

    Ø 可視繼承是指子窗體(類)使用基窗體(類)的外觀和實(shí)現(xiàn)代碼的能力。

    在考慮使用繼承時(shí),有一點(diǎn)需要注意,那就是兩個(gè)類之間的關(guān)系應(yīng)該是“屬于”關(guān)系。例如,Employee 是一個(gè)人,Manager 也是一個(gè)人,因此這兩個(gè)類都可以繼承 Person 類。但是 Leg 類卻不能繼承 Person 類,因?yàn)橥炔⒉皇且粋€(gè)人。

    抽象類僅定義將由子類創(chuàng)建的一般屬性和方法,創(chuàng)建抽象類時(shí),請(qǐng)使用關(guān)鍵字 Interface 而不是 Class。

    OO開(kāi)發(fā)范式大致為:劃分對(duì)象→抽象類→將類組織成為層次化結(jié)構(gòu)(繼承和合成) →用類與實(shí)例進(jìn)行設(shè)計(jì)和實(shí)現(xiàn)幾個(gè)階段。

    多態(tài)

    多態(tài)性(polymorphisn)是允許你將父對(duì)象設(shè)置成為和一個(gè)或更多的他的子對(duì)象相等的技術(shù),賦值之后,父對(duì)象就可以根據(jù)當(dāng)前賦值給它的子對(duì)象的特性以不同的方式運(yùn)作。簡(jiǎn)單的說(shuō),就是一句話:允許將子類類型的指針賦值給父類類型的指針。

    實(shí)現(xiàn)多態(tài),有二種方式,覆蓋,重載。

    覆蓋,是指子類重新定義父類的虛函數(shù)的做法。

    重載,是指允許存在多個(gè)同名函數(shù),而這些函數(shù)的參數(shù)表不同(或許參數(shù)個(gè)數(shù)不同,或許參數(shù)類型不同,或許兩者都不同)。

    其實(shí),重載的概念并不屬于“面向?qū)ο缶幊?#8221;,重載的實(shí)現(xiàn)是:編譯器根據(jù)函數(shù)不同的參數(shù)表,對(duì)同名函數(shù)的名稱做修飾,然后這些同名函數(shù)就成了不同的函數(shù)(至少對(duì)于編譯器來(lái)說(shuō)是這樣的)。如,有兩個(gè)同名函數(shù):function func(p:integer):integer;和function func(p:string):integer;。那么編譯器做過(guò)修飾后的函數(shù)名稱可能是這樣的:int_func、str_func。對(duì)于這兩個(gè)函數(shù)的調(diào)用,在編譯器間就已經(jīng)確定了,是靜態(tài)的(記住:是靜態(tài))。也就是說(shuō),它們的地址在編譯期就綁定了(早綁定),因此,重載和多態(tài)無(wú)關(guān)!真正和多態(tài)相關(guān)的是 “覆蓋”。當(dāng)子類重新定義了父類的虛函數(shù)后,父類指針根據(jù)賦給它的不同的子類指針,動(dòng)態(tài)(記住:是動(dòng)態(tài)!)的調(diào)用屬于子類的該函數(shù),這樣的函數(shù)調(diào)用在編譯期間是無(wú)法確定的(調(diào)用的子類的虛函數(shù)的地址無(wú)法給出)。因此,這樣的函數(shù)地址是在運(yùn)行期綁定的(晚邦定)。結(jié)論就是:重載只是一種語(yǔ)言特性,與多態(tài)無(wú)關(guān),與面向?qū)ο笠矡o(wú)關(guān)!引用一句Bruce Eckel的話:“不要犯傻,如果它不是晚邦定,它就不是多態(tài)。”

    那么,多態(tài)的作用是什么呢?我們知道,封裝可以隱藏實(shí)現(xiàn)細(xì)節(jié),使得代碼模塊化;繼承可以擴(kuò)展已存在的代碼模塊(類);它們的目的都是為了——代碼重用。而多態(tài)則是為了實(shí)現(xiàn)另一個(gè)目的——接口重用!多態(tài)的作用,就是為了類在繼承和派生的時(shí)候,保證使用“家譜”中任一類的實(shí)例的某一屬性時(shí)的正確調(diào)用。

    泛化(Generalization)

     

    在上圖中,空心的三角表示繼承關(guān)系(類繼承),在UML的術(shù)語(yǔ)中,這種關(guān)系被稱為泛化(Generalization)。Person(人)是基類,Teacher(教師)、Student(學(xué)生)、Guest(來(lái)賓)是子類。

    若在邏輯上B是A的“一種”,并且A的所有功能和屬性對(duì)B而言都有意義,則允許B繼承A的功能和屬性。

    例如,教師是人,Teacher 是Person的“一種”(a kind of )。那么類Teacher可以從類Person派生(繼承)。

    如果A是基類,B是A的派生類,那么B將繼承A的數(shù)據(jù)和函數(shù)。

    如果類A和類B毫不相關(guān),不可以為了使B的功能更多些而讓B繼承A的功能和屬性。

    若在邏輯上B是A的“一種”(a kind of ),則允許B繼承A的功能和屬性。

    聚合(組合)

     

    若在邏輯上A是B的“一部分”(a part of),則不允許B從A派生,而是要用A和其它東西組合出B。

    例如,眼(Eye)、鼻(Nose)、口(Mouth)、耳(Ear)是頭(Head)的一部分,所以類Head應(yīng)該由類Eye、Nose、Mouth、Ear組合而成,不是派生(繼承)而成。

    聚合的類型分為無(wú)、共享(聚合)、復(fù)合(組合)三類。

    聚合(aggregation)

     

    上面圖中,有一個(gè)菱形(空心)表示聚合(aggregation)(聚合類型為共享),聚合的意義表示has-a關(guān)系。聚合是一種相對(duì)松散的關(guān)系,聚合類B不需要對(duì)被聚合的類A負(fù)責(zé)。

    組合(composition)

     

    這幅圖與上面的唯一區(qū)別是菱形為實(shí)心的,它代表了一種更為堅(jiān)固的關(guān)系——組合(composition)(聚合類型為復(fù)合)。組合表示的關(guān)系也是has-a,不過(guò)在這里,A的生命期受B控制。即A會(huì)隨著B(niǎo)的創(chuàng)建而創(chuàng)建,隨B的消亡而消亡。

    依賴(Dependency)

     

    這里B與A的關(guān)系只是一種依賴(Dependency)關(guān)系,這種關(guān)系表明,如果類A被修改,那么類B會(huì)受到影響

    posted @ 2012-11-21 09:32 哈希 閱讀(217) | 評(píng)論 (0)編輯 收藏

    主站蜘蛛池模板: 人人狠狠综合久久亚洲88| 久久久久av无码免费网| 人成电影网在线观看免费| 国产精品亚洲专区无码牛牛| 亚洲精品亚洲人成在线| 亚洲人成网站18禁止| 亚洲欧好州第一的日产suv| 亚洲熟妇丰满xxxxx| 亚洲色偷偷综合亚洲AV伊人蜜桃| 亚洲中文字幕精品久久| 亚洲国产精品美女久久久久| 国产成人久久精品亚洲小说| 男女作爱免费网站| 精品国产污污免费网站入口| 大地资源在线资源免费观看| 91av免费观看| 一二三四影视在线看片免费| 国产在线观看www鲁啊鲁免费| 免费一级毛片在线播放不收费| 国产亚洲美日韩AV中文字幕无码成人| 亚洲精品乱码久久久久久中文字幕| 亚洲av最新在线网址| 亚洲美女精品视频| 亚洲日韩精品无码专区加勒比☆| 亚洲A∨精品一区二区三区下载| 三级片免费观看久久| 好紧我太爽了视频免费国产 | 亚洲精品无码久久久久久久| 久久精品国产亚洲AV忘忧草18| 亚洲AV成人无码久久WWW| 一级A毛片免费观看久久精品 | 成人午夜免费福利视频| 日韩免费视频观看| 日韩亚洲变态另类中文| 亚洲视频在线观看地址| 亚洲成a人无码亚洲成www牛牛 | 黄网站色成年片大免费高清| 野花香高清在线观看视频播放免费 | 亚洲jjzzjjzz在线播放| 免费国产va在线观看| 青青草原1769久久免费播放 |