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

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

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

    Duran's technical life
    踏踏實(shí)實(shí)學(xué)技術(shù),認(rèn)認(rèn)真真做研究。

    2006年7月14日

    從MySql5中運(yùn)行本地腳本創(chuàng)建數(shù)據(jù)庫,當(dāng)插入中文字段時(shí)發(fā)生“data too long for column”錯(cuò)誤。上網(wǎng)一查,發(fā)現(xiàn)多字節(jié)用戶大都碰到了這種情況。google搜索網(wǎng)上的解決方法大都是要將數(shù)據(jù)庫的編碼方式為GBK或UTF8,可我在安裝MySql時(shí)就選擇了UTF8格式。原來錯(cuò)誤原因是本地的腳本文件不是UTF8編碼的,用記事本或UltraEdit將編碼轉(zhuǎn)為UTF8后問題解決。再次強(qiáng)調(diào),JSP頁面,數(shù)據(jù)庫聯(lián)接接方式,數(shù)據(jù)庫創(chuàng)建,…,都須一致使用UTF8編碼!

    BTW,MySql最近借著Web2.0的浪潮風(fēng)頭很勁啊,techn orati(好像這幾天被GFW filter了),flickr,del.icio.us等一批網(wǎng)站都是用了MySql。MySql還專門在首頁開了一大塊來炫耀。
    posted @ 2006-07-14 19:12 Duran's technical life 閱讀(9184) | 評(píng)論 (4)編輯 收藏

    2006年7月13日

    Installed JDK6 (Mustang) beta and Eclipse3.2 . As Sun promised , Swing library, especially the?WindowsLookAndFeel feels much better. It’s hard to tell the difference between a Swing drawn window and a WINXP native window. Developing Java desktop applications is worth considering. Mattise, a free easy-to-use WYSIWYG Swing UI designer, is the only reason for many to use the tedious NetBeans. Recently, Genuitec provided Matisse4Eclipse, which is?an implementation of Matisse that integrates its functionality into MyEclipse Workbench to enable the easy creation of Swing applications with Eclipse. So the only reason to use NetBeans has gone.
    posted @ 2006-07-13 22:17 Duran's technical life 閱讀(1037) | 評(píng)論 (0)編輯 收藏
     
    去年7月決定考研后暫停了對(duì)Java技術(shù)的學(xué)習(xí)。錄研上后專心開發(fā)導(dǎo)師負(fù)責(zé)的項(xiàng)目,到4月份從深圳出差回來后又忙著做畢設(shè)。快一年的時(shí)間沒跟新這,幾乎都要abandon了。百度剛開放了百度空間的注冊(cè),不過看起來不咋的。選國外的BSP會(huì)面臨隨時(shí)偉大的GFW過濾掉的后果。總的來說,BlogJava還是很適合post技術(shù)方面的東西,優(yōu)點(diǎn)是流量大,被google收錄快;缺點(diǎn)就是沒有trackback。前幾天下午跑到圖書館看了看上半年的程序員,新鮮玩意并不多。SOA,這個(gè)被預(yù)測(cè)為06年最熱點(diǎn)的技術(shù),并沒有什么有趣的文章,或許這個(gè)名詞還是沒有個(gè)明確的含義和應(yīng)用。在學(xué)校里,IBM的SOA大賽倒是舉辦的風(fēng)風(fēng)火火。JavaEE5,JDK 6的發(fā)布還是給Java界帶來不少有趣又實(shí)用的新東東,比如annotation,persistence API和script supporting。得跟上技術(shù)前進(jìn)的步伐了,以后技術(shù)的筆記還是發(fā)這里,平日的雜想就寫在我的MSN space上。
    posted @ 2006-07-13 22:14 Duran's technical life 閱讀(329) | 評(píng)論 (0)編輯 收藏

    2005年9月9日

    @title [筆記]事務(wù)處理

    #1 Transaction Propagation Behavior
    Required:Excute within a current tx, create a new one if none exists.
    Supports: Excute within a current tx, execute without a tx if none exsits.
    Mandatory: Excute within a current tx, throw an exception if none exists.
    Requires New: Create a new tx and excute within the tx, suspend the current tx if one exists.
    Not Supported: Excute without a tx, suspend the current tx if none exsits.
    Never: Excute without a tx, throw an exception if a tx exsits.

    #2 Transaction Isolation Level[1]
    #2.1 Concurrent Problem
    Dirty Reads: 臟讀(臟數(shù)據(jù)指已更新,還沒提交的數(shù)據(jù))。事務(wù)T1讀取到事務(wù)T2中的臟數(shù)據(jù)。

    Unrepeatable Reads: 不可重復(fù)讀。事務(wù)T1檢索到某行后,事務(wù)T2更新并提交了該行,若事務(wù)T2再次檢索該行,則會(huì)看到不一樣的結(jié)果。

    Phantom Reads: 虛讀。事務(wù)T1檢索到符合某條件的行集后,事務(wù)T2插入并提交了滿足該條件的新行,若事務(wù)T2再次按該條件檢索,則會(huì)看到以前不存在的行“Phantom”。

    #2.2 Isolation Level
    +---------------+-------+------------------+-----------+
    |Isolation Level|Phantom|Unrepeatable Reads|Dirty Reads|
    +---------------+-------+------------------+-----------+
    |Read Uncommited|   Y   |         Y        |     Y     |
    +---------------+-------+------------------+-----------+
    |Read Commited  |   Y   |         Y        |     N     |
    +---------------+-------+------------------+-----------+
    |Repeatable Read|   Y   |         N        |     N     |
    +---------------+-------+------------------+-----------+
    |Serializable   |   N   |         N        |     N     |
    +---------------+-------+------------------+-----------+

    #3 Timeout

    #4 ReadOnly Transaction
    只讀事務(wù)保證了多條查詢SQL的在事務(wù)級(jí)別的讀一致性。JDBC和數(shù)據(jù)庫會(huì)對(duì)只讀事務(wù)做一些優(yōu)化。

    [1] C.J.Date, An Introduction to Database Systems 7th.

    posted @ 2005-09-09 13:09 Duran's technical life 閱讀(715) | 評(píng)論 (1)編輯 收藏

    2005年9月7日

    iteration::two Cairngorm 0.99 開發(fā)指南
    @author sakis
    @version 0.1

    #0
    MXML優(yōu)點(diǎn):使用方便,XML代碼簡潔易懂
    缺點(diǎn):事件、函數(shù)、界面描混在一起。程序規(guī)模大了難于開發(fā)維護(hù)。

    #1
    Cairngorm框架是iterationtwo推出的號(hào)稱基于JEE Best Practice的Flex程序開發(fā)的light-weight framework。(恩,light-weight這個(gè)詞還真是流行呢)。目前最新版本為0.99。

    Cairngorm的結(jié)構(gòu)如下:
    org
    └─nevis
        └─cairngorm
            ├─application
            │      CairngormApplication.as
            │
            ├─business
            │      Responder.as
            │      ServiceLocator.as
            │
            ├─commands
            │      Command.as
            │      SequenceCommand.as
            │
            ├─control
            │      Event.as
            │      EventBroadcaster.as
            │      FrontController.as
            │
            ├─model
            │      ModelLocator.as
            │
            ├─view
            │      ViewHelper.as
            │      ViewLocator.as
            │
            └─vo
                    ValueObject.as


    #2
    下面給大家簡單介紹Cairngorm的實(shí)現(xiàn)思路。

    #2.1
    Command/FrontController將Event與Viwe分離。
    FrontController實(shí)現(xiàn)Singleton模式(以下簡寫為SP)。所有自定義的Command在要在FrontController構(gòu)造函數(shù)中實(shí)例化并以關(guān)聯(lián)數(shù)組的方式注冊(cè)FrontController#addCommand(eventType:String, commandInstance:Command)。EventBroadcaster實(shí)現(xiàn)SP。Event類的結(jié)構(gòu)為{type:eventType, data:eventData}。我們通過EventBroadcaster#broadcastEvent(eventType:String, eventData:Object)發(fā)布Event。Event發(fā)布后,與eventType對(duì)應(yīng)的command instance執(zhí)行Command#execute(event:Event)。

    BTW:在Cairngorm的源碼中,eventType、commandName、eventName混用,我統(tǒng)一用eventType。

    #2.2
    ServiceLocator將Remote Service聲明與View分離。
    ServiceLocator實(shí)現(xiàn)SP。在Cairngorm的demo中,又通過Delegate對(duì)象解除Command/Responder和ServiceLocator之間的依賴。這個(gè)Delegate做的事情其實(shí)意義不大,就是調(diào)用ServiceLocator中的Method,設(shè)置莫個(gè)Responder為相應(yīng)遠(yuǎn)程方法的handler。個(gè)人覺得無謂地增加了代碼量,而且Delegate對(duì)象也沒實(shí)現(xiàn)SP,也就是說我們每次調(diào)用一次Remote Service中的Method,都要new一個(gè)Delegate對(duì)象,實(shí)在浪費(fèi)。

    #2.3
    ViewLocator/ViewHelper將View(MXML)中夾雜的function與View分離。
    ViewHelper有點(diǎn)意思,當(dāng)一個(gè)ViewHelper在某個(gè)MXML頁面中聲明時(shí),如<view:LoginViewHelper id="loginViewHelper" />。ViewHelper能自動(dòng)取得所在MXML對(duì)象的引用,并通過ViewLocator#register(id, this:ViewHelper)將自身注冊(cè)到ViewLocator中。ViewLocator實(shí)現(xiàn)SP。借助ViewLocator/ViewHelper,我們就可以方便的調(diào)用不同MXML頁面中的方法。

    #2.4
    ModelLocator是一個(gè)marker interface,程序中Model可以放在某個(gè)ModelLocator方便調(diào)用。

    #2.5
    ValueObject也是一個(gè)marker interface, 基本不需要。

    #3
    Cairngorm.99給我們開發(fā)Flex程序提供了很不錯(cuò)的架構(gòu)模式,M/V/C/Remote之間可以做到完全解構(gòu)。但在實(shí)際開發(fā)時(shí)沒有必要死扣,代碼結(jié)構(gòu)清晰有活力就好。

    posted @ 2005-09-07 21:49 Duran's technical life 閱讀(883) | 評(píng)論 (0)編輯 收藏

    2005年9月6日

    Hibernate一對(duì)一關(guān)聯(lián)實(shí)用介紹

    #0
    書和文檔上寫的都不是特清楚的。自己記下來。

    #1 Using a PK association

    #1.1 POJO with XDolclet annotation
    public class Customer {
     /**
      * @return Returns the shoppingCart.
      * @hibernate.many-to-one cascade="delete" column="shopping_cart_id"
      *  unique="true" foreign-key="FK_SHOPPING_CART__CUSTOMER"
      */
     public ShoppingCart getShoppingCart() {
      return shoppingCart;
     }
    }

    public class ShoppingCart {
     /**
      * @return Returns the customer.
      * @hibernate.one-to-one property-ref="shoppingCart"
      */
     public Customer getCustomer() {
      return customer;
     }
    }

    property-ref="shoppingCart" 告訴Hibernate ShoppingCart#customer和Customer#shoppingCart是反向的關(guān)系。所以Hibernate知道如何從ShoppingCart#getCustomer中檢索到相應(yīng)的customer對(duì)象。取出某個(gè)Customer對(duì)象時(shí),Hibernate會(huì)生成DEBUG SQL:324 - 3中的SQL語句。

    #1.2 HBM
    Customer.hbm.xml
    <many-to-one
        name="shoppingCart"
        class="ShoppingCart"
        cascade="delete"
        outer-join="auto"
        foreign-key="FK_SHOPPING_CART__CUSTOMER"
        column="shopping_cart_id"
    />

    ShoppingCart.hbm.xml
    <one-to-one
        name="customer"
        class="Customer"
        cascade="none"
        outer-join="auto"
        constrained="false"
        property-ref="shoppingCart"
    />

    #1.3 SCHEMA SQL
    create table CUSTOMER (
        ID bigint generated by default as identity (start with 1),
        SHOPPING_CART_ID bigint,
        primary key (ID)
    )

    create table SHOPPING_CART (
        ID bigint generated by default as identity (start with 1)
        primary key (ID)
    )

    alter table CUSTOMER
        add constraint FK_SHOPPING_CART__CUSTOMER
        foreign key (SHOPPING_CART_ID)
        references SHOPPING_CART

    #1.4 Query SQL
    DEBUG SQL:324 - 1
    select customer0_.ID as ID, customer0_.SHOPPING_CART_ID as SHOPPING2_3_, customer0_.USERNAME as USERNAME3_, customer0_.PWD as PWD3_
    from CUSTOMER customer0_
    where customer0_.USERNAME=? and customer0_.PWD=?

    DEBUG SQL:324 - 2
    select shoppingca0_.ID as ID0_, shoppingca0_.TOTAL as TOTAL8_0_
    from SHOPPING_CART shoppingca0_
    where shoppingca0_.ID=?

    DEBUG SQL:324 - 3
    select customer0_.ID as ID1_, customer0_.SHOPPING_CART_ID as SHOPPING2_3_1_, customer0_.USERNAME as USERNAME3_1_, customer0_.PWD as PWD3_1_, shoppingca1_.ID as ID0_, shoppingca1_.TOTAL as TOTAL8_0_
    from
     CUSTOMER customer0_
     left outer join
     SHOPPING_CART shoppingca1_
     on customer0_.SHOPPING_CART_ID=shoppingca1_.ID
    where customer0_.SHOPPING_CART_ID=?


    #2 Using a FK association

    #2.1 POJO with XDolclet annotation
    public class Customer {
     /**
      * @return Returns the shoppingCart.
      * @hibernate.one-to-one cascade="delete"
      */
     public ShoppingCart getShoppingCart() {
      return shoppingCart;
     }
    }

    public class ShoppingCart {
     /**
      * @return Returns the id.
      * @hibernate.id generator-class="foreign"
      * @hibernate.generator-param name="property" value="customer"
      */
     public Long getId() {
      return id();
     }

     /**
      * @return Returns the customer.
      * @hibernate.one-to-one constrained="true" foreign-key="FK_CUSTOMER__SHOPPING_CART"
      */
     public Customer getCustomer() {
      return customer;
     }
    }

    constrained="true" 告訴Hibernate ShoppingCart的PK還應(yīng)該是一個(gè)FK,這個(gè)FK引用Customer的PK。還需要多做一點(diǎn)工作,聲明ShoppingCart的PK生成策略是foreign,對(duì)應(yīng)ShoppingCart#customer。這和上面一句話不是一個(gè)意思嘛,F(xiàn)T~~

    #2.2 HBM
    Customer.hbm.xml
    <one-to-one
        name="shoppingCart"
        class="ShoppingCart"
        cascade="delete"
        outer-join="auto"
        constrained="false"
    />

    ShoppingCart.hbm.xml
    <id
        name="id"
        column="id"
        type="java.lang.Long"
    >
        <generator class="foreign">
     <param name="property">customer</param>
        </generator>
    </id>

    <one-to-one
        name="customer"
        class="Customer"
        cascade="none"
        outer-join="auto"
        constrained="true"
    />

    #2.3 SCHEMA SQL
    create table CUSTOMER (
        ID bigint generated by default as identity (start with 1),
        primary key (ID)
    )

    create table SHOPPING_CART (
        ID bigint not null,
        TOTAL integer,
        primary key (ID)
    )

    alter table SHOPPING_CART
        add constraint FK_CUSTOMER__SHOPPING_CART
        foreign key (ID)
        references CUSTOMER

    #2.4 Query SQL
    DEBUG SQL:324 -
    select customer0_.ID as ID, customer0_.USERNAME as USERNAME3_, customer0_.PWD as PWD3_
    from CUSTOMER customer0_
    where customer0_.USERNAME=? and customer0_.PWD=?

    DEBUG SQL:324 -
    select shoppingca0_.ID as ID0_, shoppingca0_.TOTAL as TOTAL8_0_
    from SHOPPING_CART shoppingca0_
    where shoppingca0_.ID=?

    這個(gè)“真正”的one-to-one的好處是少條關(guān)聯(lián)SQL語句,看到了嗎?

    posted @ 2005-09-06 13:16 Duran's technical life 閱讀(4193) | 評(píng)論 (2)編輯 收藏

    2005年8月12日

    1  Open the Apache Tomcat configuration app in sys tray, and on the "Java" tab, bump up the initial memory pool size and the maximum memory pool size to 512 Initial and 768 Max, click Ok.
    2  In \Program Files\Apache software Foundation\Tomcat 5.0\bin\catalina.bat, in the last section immediately after "rem Execute Java with the applicable properties", insert this line, set CATALINA_OPTS=-mx1024m. Save the file.
    posted @ 2005-08-12 17:38 Duran's technical life 閱讀(1597) | 評(píng)論 (0)編輯 收藏

    2005年8月9日

    在google里敲了“HelloWolrd”,再點(diǎn)“手氣不錯(cuò)”,出來了這樣一個(gè)頁面:http://www2.latech.edu/~acm/HelloWorld.shtml

    Hello World!

    Welcome to the ACM "Hello World" project. Everyone has seen the Hello World program used as a first exposure to a new language or environment. We are attempting to collect examples for as many languages and related programming environments (shells etc.) as possible.


    Aproximate number of examples:204     <----wow~~~
    This page has been accessed 33274 times.
    Last updated: January 20, 2005   


    看看C的,經(jīng)典HelloWorld
    #include <stdio.h>
    main()
    {
      for(;;)
          {
              printf ("Hello World!\n");
          }
    }


    這也是HelloWolrd?!
    a 1986 entry from Bruce Holloway:

    #include "stdio.h"
    #define e 3
    #define g (e/e)
    #define h ((g+e)/2)
    #define f (e-g-h)
    #define j (e*e-g)
    #define k (j-h)
    #define l(x) tab2[x]/h
    #define m(n,a) ((n&(a))==(a))

    long tab1[]={ 989L,5L,26L,0L,88319L,123L,0L,9367L };
    int tab2[]={ 4,6,10,14,22,26,34,38,46,58,62,74,82,86 };

    main(m1,s) char *s; {
        int a,b,c,d,o[k],n=(int)s;
        if(m1==1){ char b[2*j+f-g]; main(l(h+e)+h+e,b); printf(b); }
        else switch(m1-=h){
            case f:
                a=(b=(c=(d=g)<<g)<'<g)<<g;
                return(m(n,a|c)|m(n,b)|m(n,a|d)|m(n,c|d));
            case h:
                for(a=f;a=e)for(b=g<<g;b<n;++b)o[b]=o[b-h]+o[b-g]+c;
                return(o[b-g]%n+k-h);
            default:
                if(m1-=e) main(m1-g+e+h,s+g); else *(s+g)=f;
                for(*s=a=f;a<e;) *s=(*s<<e)|main(h+a++,(char *)m1);
            }
    }

    曾經(jīng)最短的HelloWorld(Jari.Arkko@lmf.eua.ericsson.se
    jar.1.c
    char*_="Hello world.\n";

    ln -s /dev/tty jar.1.o
    cc -c jar.1.c



    現(xiàn)在最短的HelloWorld (Jyrki Holopainen)
    ";main(){puts("Hello World!");}char*C=".c  
    char*_=__FILE__;

    posted @ 2005-08-09 09:38 Duran's technical life 閱讀(625) | 評(píng)論 (0)編輯 收藏

    2005年7月14日

    抵達(dá)深圳

    在中國改革開放的貞操牌坊,更加強(qiáng)烈感受了GCD領(lǐng)導(dǎo)下的中國特色的社會(huì)主義和諧社會(huì)。羅湖區(qū)1w的小套間,隨處可見benz和BMW。晚上去吃海鮮,一盤盤的叫不上名來,味道倒是鮮美:-)

    實(shí)習(xí)第一天

    XX信息公司研發(fā)部實(shí)習(xí)員工登記,領(lǐng)工卡,認(rèn)識(shí)組員,了解項(xiàng)目情況,做了一天需求分析,easy。在公司里寫程序的感覺和學(xué)校不大一樣,一邊寫一邊就能聽到boss在隔壁辦公室訓(xùn)斥某人。小小的不滿:液晶顯示器不多,自然輪不到我。小小小的不滿:QQ不能用就算了,msn好像都不能用。

    posted @ 2005-07-14 18:07 Duran's technical life 閱讀(627) | 評(píng)論 (0)編輯 收藏

    2005年6月17日

    性能比較:Java全面超越C++?
    這樣的八卦炒作貼也能在java.csdn.net上置頂,真是無語了~我只想對(duì)csdn說:“你太差了!”
    《程序員》每期都會(huì)買,是因?yàn)槲覜]的選擇。作為一本技術(shù)刊物,《程序員》不是保持中立,而是摻雜了太多的商業(yè)立場(chǎng)和利益。高水平的文章也有,但遠(yuǎn)遠(yuǎn)不夠。該雜志一主編感嘆沒有對(duì)手,說《DDJ China》“幾乎是一個(gè)合格的對(duì)手了”。說的極端和刻薄一點(diǎn),《DDJ》是軟件開發(fā)的學(xué)術(shù)刊物,csdn、《程序員》只能算是程序員的娛樂新聞雜志。

    這是一個(gè)署名“周星星”的同學(xué)對(duì)原文的評(píng)論。
    周星星 發(fā)表于2005-06-16 5:01 PM 
    “很明顯,C++的編譯器不如java的JIT和HotSpot編譯器,因?yàn)镴IT和HotSpot編譯器能針對(duì)CPU指令集進(jìn)行人優(yōu)化、能在運(yùn)行時(shí)根據(jù)使用頻率對(duì)method進(jìn)行內(nèi)聯(lián)和優(yōu)化。而C++的靜態(tài)編譯器永遠(yuǎn)也做不到這些”
    --- 無知了吧,現(xiàn)存于世的C++編譯器,無論是VC++,還是Intel C++,還是g++,都能針對(duì)特定CPU進(jìn)行優(yōu)化;而Java的所謂動(dòng)態(tài)優(yōu)化只是做了部分(不是全部)C++靜態(tài)優(yōu)化的工作;事實(shí)上,真正的動(dòng)態(tài)優(yōu)化不是任何一個(gè)高級(jí)語言所能做到的,C++不能,C不能,Java更不能,必須內(nèi)嵌匯編才能做到這一點(diǎn)。

    “JDK1.0時(shí),java的速度是C++的20到40分之一。而到了jdk1.4時(shí),java的性能則是C++的三分之一到2倍(通常C++是java的1.2倍到1.5倍)。可惜這分報(bào)告沒有jdk1.4以后的數(shù)據(jù),而后面的報(bào)告我們將看到在jdk1.4.2時(shí),java性能全面超過C++。”
    --- 有個(gè)10歲的小孩子對(duì)她30母親說:“9年前我的年齡是妳的1/21,我現(xiàn)在的年齡是妳的1/3,隨著這種趨勢(shì)的發(fā)展,在未來我的年齡就可以超過妳。”
    Java的速度也許可以接近C++,但永遠(yuǎn)不可能達(dá)到C++一樣快,更不可能超過C++,因?yàn)榻忉尦绦虮仨氁笤绦騺斫忉寛?zhí)行,所以永遠(yuǎn)達(dá)不到一樣的速度。

    “Java寫的數(shù)據(jù)庫的性能是C++寫的數(shù)據(jù)庫性能的近600倍!”
    --- 天方夜譚,如果真的這樣,MS SQL為什么不用Java來編寫,Oracle為什么不用Java來編寫,MySQL為什么不用Java來編寫?

    “伯克利大學(xué)和Lawrence伯克利國家實(shí)驗(yàn)室的一份報(bào)告證明:IBM的JDK比GCC更快”
    --- 伯克利大學(xué)真的有這個(gè)報(bào)告嗎?真是玷污伯克利的威名,把JDK和GCC放在一起比,如同把“長度”和“重量”這兩種不同性質(zhì)的東西放在一起比。

    “用純java寫的JDK底層要比用C++寫JDK底層要快”
    --- 暈,“純java寫的JDK”,教你Java的老師被你氣跳樓了。

    posted @ 2005-06-17 12:31 Duran's technical life 閱讀(730) | 評(píng)論 (1)編輯 收藏
    僅列出標(biāo)題  下一頁
     
    主站蜘蛛池模板: 无码国产精品一区二区免费3p| 亚洲婷婷国产精品电影人久久| 亚洲va在线va天堂va888www| 亚洲免费无码在线| 亚洲色婷婷综合久久| 你懂得的在线观看免费视频| 亚洲成人动漫在线观看| 成全影视免费观看大全二| 特级aa**毛片免费观看| 亚洲国产精品无码久久久蜜芽 | 中文字幕人成无码免费视频 | 亚洲精品一级无码鲁丝片| 十八禁视频在线观看免费无码无遮挡骂过 | 亚洲一区二区三区高清在线观看 | 色偷偷女男人的天堂亚洲网| 亚洲福利精品一区二区三区| 黄色片免费在线观看| 亚洲91精品麻豆国产系列在线 | 免费国产在线视频| 亚洲欧美成人综合久久久 | 亚洲色少妇熟女11p| 二区久久国产乱子伦免费精品| 国产偷国产偷亚洲清高动态图| 久久精品国产免费| 自拍偷自拍亚洲精品偷一| 亚洲国产精品无码久久久不卡 | 亚洲一级特黄特黄的大片| 69影院毛片免费观看视频在线 | 国产亚洲精品AA片在线观看不加载| 无遮免费网站在线入口| 性xxxxx大片免费视频| jizz日本免费| 深夜福利在线视频免费| 亚洲AV无码AV男人的天堂不卡| 亚洲一区二区三区免费观看| 久久久久亚洲AV无码专区首JN| 亚洲人色婷婷成人网站在线观看| 免费国产精品视频| 久久精品国产亚洲7777| 国产成人精品久久亚洲高清不卡 | 在线jyzzjyzz免费视频|