日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

JAVA编程经验汇总 (载)

發布時間:2023/12/9 编程问答 58 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JAVA编程经验汇总 (载) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1. 關于動態加載機制??
學習Java比C++更容易理解OOP的思想,畢竟C++還混合了不少面向過程的成分。很多人都能背出來Java語言的特點,所謂的動態加載機制等等。當然概念往往是先記住而后消化的,可有多少人真正去體會過動態加載的機制,試圖去尋找過其中的細節呢?? 提供大家一個方法:
在命令行窗口運行Java程序的時候,加上這個很有用的參數:

java? -verbose? *.class

這樣會清晰的打印出被加載的類文件,大部分是jdk自身運行需要的,最后幾行會明顯的看到自己用到的那幾個類文件被加載進來的順序。即使你聲明了一個類對象,不實例化也不會加載,說明只有真正用到那個類的實例即對象的時候,才會執行加載。這樣是不是大家稍微能明白一點動態加載了呢?^_^

2. 關于尋找class文件原理??
建議大家在入門的時候在命令行窗口編譯和運行,不要借助JCreator或者Eclipse等IDE去幫助做那些事情。嘗試自己這樣做:
javac??? -classpath? yourpath? *.java
java??? -classpath? yourpath? *.class
也許很多人都能看懂,設置classpath的目的就是告訴編譯器去哪里尋找你的class文件.? 不過至少筆者今日才弄懂JVM去查詢類的原理,編譯器加載類要依靠classloader,? 而classloader有3個級別,從高到低分別是BootClassLoader(名字可能不準確)? ,? ExtClassLoader,? AppClassLoader.

這3個加載器分別對應著編譯器去尋找類文件的優先級別和不同的路徑:BootClassLoader對應jre/classes路徑,是編譯器最優先尋找class的地方
ExtClassLoader對應jre/lib/ext路徑,是編譯器次優先尋找class的地方
AppClassLoader對應當前路徑,所以也是編譯器默認找class的地方

其實大家可以自己寫個程序簡單的測試,對任何class,例如A,?
調用new? A().getClass().getClassLoader().toString()? 打印出來就可以看到,把class文件放在不同的路徑下再次執行,就會看到區別。特別注意的是如果打印出來是null就表示到了最高級 BootClassLoader,? 因為它是C++編寫的,不存在Java對應的類加載器的名字。

尋找的順序是一種向上迂回的思想,即如果本級別找不到,就只能去本級別之上的找,不會向下尋找。不過似乎從Jdk1.4到Jdk1.6這一特點又有改變,沒有找到詳細資料。所以就不舉例子了。告訴大家設計這種體系的是Sun公司曾經的技術核心宮力先生,一個純種華人哦!^_^

這樣希望大家不至于迷惑為什么總報錯找不到類文件,不管是自己寫的還是導入的第三方的jar文件(J2ee中經常需要導入的)。

3. 關于jdk和jre??
大家肯定在安裝JDK的時候會有選擇是否安裝單獨的jre,一般都會一起安裝,我也建議大家這樣做。因為這樣更能幫助大家弄清楚它們的區別:

Jre? 是java? runtime? environment,? 是java程序的運行環境。既然是運行,當然要包含jvm,也就是大家熟悉的虛擬機啦,? 還有所有java類庫的class文件,都在lib目錄下打包成了jar。大家可以自己驗證。至于在windows上的虛擬機是哪個文件呢?? 學過MFC的都知道什么是dll文件吧,那么大家看看jre/bin/client里面是不是有一個jvm.dll呢?那就是虛擬機。

Jdk? 是java? development? kit,是java的開發工具包,里面包含了各種類庫和工具。當然也包括了另外一個Jre.??? 那么為什么要包括另外一個Jre呢?而且jdk/jre/bin同時有client和server兩個文件夾下都包含一個jvm.dll。? 說明是有兩個虛擬機的。這一點不知道大家是否注意到了呢?

相信大家都知道jdk的bin下有各種java程序需要用到的命令,與jre的bin目錄最明顯的區別就是jdk下才有javac,這一點很好理解,因為 jre只是一個運行環境而已。與開發無關,正因為如此,具備開發功能的jdk自己的jre下才會同時有client性質的jvm和server性質的 jvm,? 而僅僅作為運行環境的jre下只需要client性質的jvm.dll就夠了。

記得在環境變量path中設置jdk/bin路徑麼?這應該是大家學習Java的第一步吧,? 老師會告訴大家不設置的話javac和java是用不了的。確實jdk/bin目錄下包含了所有的命令。可是有沒有人想過我們用的java命令并不是 jdk/bin目錄下的而是jre/bin目錄下的呢?不信可以做一個實驗,大家可以把jdk/bin目錄下的java.exe剪切到別的地方再運行 java程序,發現了什么?一切OK!

那么有人會問了?我明明沒有設置jre/bin目錄到環境變量中啊?

試想一下如果java為了提供給大多數人使用,他們是不需要jdk做開發的,只需要jre能讓java程序跑起來就可以了,那么每個客戶還需要手動去設置環境變量多麻煩啊?所以安裝jre的時候安裝程序自動幫你把jre的java.exe添加到了系統變量中,驗證的方法很簡單,大家看到了系統環境變量的 path最前面有“%SystemRoot%\system32;%SystemRoot%;”這樣的配置,那么再去Windows/system32下面去看看吧,發現了什么?有一個java.exe。

如果強行能夠把jdk/bin挪到system32變量前面,當然也可以迫使使用jdk/jre里面的java,不過除非有必要,我不建議大家這么做。使用單獨的jre跑java程序也算是客戶環境下的一種測試。

這下大家應該更清楚jdk和jre內部的一些聯系和區別了吧?


1.? 關于集合框架類
相信學過Java的各位對這個名詞并不陌生,對? java.util.*這個package肯定也不陌生。不知道大家查詢API的時候怎么去審視或者分析其中的一個package,每個包最重要的兩個部分就是interfaces和classes,接口代表了它能做什么,實現類則代表了它如何去做。關注實現類之前,我們應該先理解清楚它的來源接口,不管在j2se還是j2ee中,都應該是這樣。那么我們先看這三個接口:List、Set、Map。
也許有些人不太熟悉這三個名字,但相信大部分人都熟悉ArrayList,LinkedList,TreeSet,HashSet,HashMap,??? Hashtable等實現類的名字。它們的區別也是滿容易理解的,List放可以重復的對象集合,Set放不可重復的對象組合,而Map則放? <Key,Value? > 這樣的名值對,? Key不可重復,Value可以。這里有幾個容易混淆的問題:

到底Vector和ArrayList,Hashtable和HashMap有什么區別?
很多面試官喜歡問這個問題,其實更專業一點應該這樣問:新集合框架和舊集合框架有哪些區別?新集合框架大家可以在這些包中找since? jdk1.2的,之前的如vector和Hashtable都是舊的集合框架包括的類。那么區別是?
a.? 新集合框架的命名更加科學合理。例如List下的ArrayList和LinkedList
b.? 新集合框架下全部都是非線程安全的。建議去jdk里面包含的源代碼里面自己去親自看看vector和ArrayList的區別吧。當然如果是jdk5.0之后的會比較難看一點,因為又加入了泛型的語法,類似c++的template語法。

那么大家是否想過為什么要從舊集合框架默認全部加鎖防止多線程訪問更新到新集合框架全部取消鎖,默認方式支持多線程?(當然需要的時候可以使用collections的靜態方法加鎖達到線程安全)
筆者的觀點是任何技術的發展都未必是遵循它們的初衷的,很多重大改變是受到客觀環境的影響的。大家知道Java的初衷是為什么而開發的麼?是為嵌入式程序開發的。記得上一篇講到classLoader機制麼?那正是為了節約嵌入式開發環境下內存而設計的。而走到今天,Java成了人們心中為互聯網誕生的語言。互聯網意味著什么?多線程是必然的趨勢。客觀環境在變,Java技術也隨著飛速發展,導致越來越脫離它的初衷。據說Sun公司其實主打的是J2se,結果又是由于客觀環境影響,J2se幾乎遺忘,留在大家談論焦點的一直是j2ee。

技術的細節這里就不多說了,只有用了才能真正理解。解釋這些正是為了幫助大家理解正在學的和將要學的任何技術。之后講j2ee的時候還會再討論。
多扯句題外話:幾十年前的IT巨人是IBM,Mainframe市場無人可比。微軟如何打敗IBM?正是由于硬件飛速發展,對個人PC的需求這個客觀環境,讓微軟通過OS稱為了第二個巨人。下一個打敗微軟的呢?Google。如何做到的?如果微軟并不和IBM爭大型機,Google借著互聯網飛速發展這個客觀環境作為決定性因素,避開跟微軟爭OS,而是走搜索引擎這條路,稱為第3個巨人。那么第4個巨人是誰呢?很多專家預言將在亞洲或者中國出現,? Whatever,客觀環境變化趨勢才是決定大方向的關鍵。當然筆者也希望會出現在中國,^_^~~

2.? 關于Java設計模式
身邊的很多在看GOF的23種設計模式,似乎學習它無論在學校還是在職場,都成了一種流行風氣。我不想列舉解釋這23種Design? Pattern,? 我寫這些的初衷一直都是談自己的經歷和看法,希望能幫助大家理解。
首先我覺得設計模式只是對一類問題的一種通用解決辦法,只要是面向對象的編程預言都可以用得上這23種。理解它們最好的方法就是親自去寫每一種,哪怕是一個簡單的應用就足夠了。如果代碼實現也記不住的話,記憶它們對應的UML圖會是一個比較好的辦法,當然前提是必須了解UML。
同時最好能利用Java自身的類庫幫助記憶,例如比較常用的觀察者模式,在java.util.*有現成的Observer接口和Observable這個實現類,看看源代碼相信就足夠理解觀察者模式了。再比如裝飾器模式,大家只要寫幾個關于java.io.*的程序就可以完全理解什么是裝飾器模式了。有很多人覺得剛入門的時候不該接觸設計模式,比如圖靈設計叢書系列很出名的那本《Java設計模式》,作者:? Steven? John? Metsker,大部分例子老實說令現在的我也很迷惑。但我仍然不同意入門跟學習設計模式有任何沖突,只是我們需要知道每種模式的概念的和典型的應用,這樣我們在第一次編寫? FileOutputStream、BufferedReader、PrintWriter的時候就能感覺到原來設計模式離我們如此之近,而且并不是多么神秘的東西。

另外,在學習某些模式的同時,反而更能幫助我們理解java類庫的某些特點。例如當你編寫原型(Prototype)模式的時候,你必須了解的是? java.lang.Cloneable這個接口和所有類的基類Object的clone()這個方法。即深copy和淺copy的區別:
Object.clone()默認實現的是淺copy,也就是復制一份對象拷貝,但如果對象包含其他對象的引用,不會復制引用,所以原對象和拷貝共用那個引用的對象。
深copy當然就是包括對象的引用都一起復制啦。這樣原對象和拷貝對象,都分別擁有一份引用對象。如果要實現深copy就必須首先實現? java.lang.Cloneable接口,然后重寫clone()方法。因為在Object中的clone()方法是protected簽名的,而? Cloneable接口的作用就是把protected放大到public,這樣clone()才能被重寫。

那么又有個問題了?如果引用的對象又引用了其他對象呢?這樣一直判斷并復制下去,是不是顯得很麻煩?曾經有位前輩告訴我的方法是重寫clone方法的時候直接把原對象序列化到磁盤上再反序列化回來,這樣不用判斷就可以得到一個深copy的結果。如果大家不了解序列化的作法建議看一看? ObjectOutputStream和ObjectInputStream

歸根結底,模式只是思想上的東西,把它當成前人總結的經驗其實一點都不為過。鼓勵大家動手自己去寫,例如代理模式,可以簡單的寫一個Child類,? Adult類。Child要買任何東西由Adult來代理實現。簡單來說就是Adult里的buy()內部實際調用的是Child的buy(),可是暴露在main函數的卻是Adult.buy()。這樣一個簡單的程序就足夠理解代理模式的基本含義了。


1.? 關于Object類理解
??????? 大家都知道Object是所有Java類的基類,? 意味著所有的Java類都會繼承了Object的11個方法。建議大家去看看Object的? 11個成員函數的源代碼,就會知道默認的實現方式。比如equals方法,默認實現就是用"=="來比較,即直接比較內存地址,返回true? 或者? false。而toString()方法,返回的串組成方式是??
??????? "getClass().getName()? +? "@"? +? Integer.toHexString(hashCode())"
??????? 其實不用我過多的解釋,大家都能看懂這個串的組成。接下來再看看hashCode():
??????? public? native? int? hashCode();
?????
??????? 由于是native方法,跟OS的處理方式相關,源代碼里僅僅有一個聲明罷了。我們有興趣的話完全可以去深究它的hashCode到底是由OS怎么樣產生的呢?但筆者建議最重要的還是先記住使用它的幾條原則吧!首先如果equals()方法相同的對象具有相通的hashCode,但equals? ()對象不相通的時候并不保證hashCode()方法返回不同的整數。而且下一次運行同一個程序,同一個對象未必還是當初的那個hashCode()? 哦。
??????? 其余的方法呢?nofigy()、notifyAll()、clone()、wait()都是native方法的,說明依賴于操作系統的實現。最后一個有趣的方法是finalize(),類似C++的析構函數,簽名是protected,證明只有繼承擴展了才能使用,方法體是空的,默示什么也不做。它的作用據筆者的了解僅僅是通知JVM此對象不再使用,隨時可以被銷毀,而實際的銷毀權還是在于虛擬機手上。那么它真的什么也不做麼?未必,實際上如果是線程對象它會導致在一定范圍內該線程的優先級別提高,導致更快的被銷毀來節約內存提高性能。其實從常理來說,我們也可以大概這樣猜測出jvm做法的目的。

??????? 2.? 關于重載hashCode()與Collection框架的關系
筆者曾經聽一位搞Java培訓多年的前輩說在他看來hashCode方法沒有任何意義,僅僅是為了配合證明具有同樣的hashCode會導致equals? 方法相等而存在的。連有的前輩都犯這樣的錯誤,其實說明它還是滿容易被忽略的。那么hashCode()方法到底做什么用?
?????
??????? 學過數據結構的課程大家都會知道有一種結構叫hash? table,目的是通過給每個對象分配一個唯一的索引來提高查詢的效率。那么Java也不會肆意扭曲改變這個概念,所以hashCode唯一的作用就是為支持數據結構中的哈希表結構而存在的,換句話說,也就是只有用到集合框架的? Hashtable、HashMap、HashSet的時候,才需要重載hashCode()方法,
這樣才能使得我們能人為的去控制在哈希結構中索引是否相等。筆者舉一個例子:
??????? 曾經為了寫一個求解類程序,需要隨機列出1,2,3,4組成的不同排列組合,所以筆者寫了一個數組類用int[]來存組合結果,然后把隨機產生的組合加入一個HashSet中,就是想利用HashSet不包括重復元素的特點。可是HashSet怎么判斷是不是重復的元素呢?當然是通過? hashCode()返回的結果是否相等來判斷啦,可做一下這個實驗:
??????? int[]? A? =? {1,2,3,4};
??????? int[]? B? =? {1,2,3,4};
??????? System.out.println(A.hashCode());
??????? System.out.println(B.hashCode());

??????? 這明明是同一種組合,卻是不同的hashCode,加入Set的時候會被當成不同的對象。這個時候我們就需要自己來重寫hashCode()方法了,如何寫呢?其實也是基于原始的hashCode(),畢竟那是操作系統的實現,? 找到相通對象唯一的標識,實現方式很多,筆者的實現方式是:
??????? 首先重寫了toString()方法:
??????? return??? A[0]“+”? A[1]“+”? A[2]“+”? A[3];? //顯示上比較直觀
??????? 然后利用toString()來計算hashCode():
??????? return??? this.toString().hashCode();
??????? 這樣上述A和B返回的就都是”1234”,在測試toString().hashCode(),由于String在內存中的副本是一樣的,”1234”.hashCode()返回的一定是相同的結果。

??????? 說到這,相信大家能理解得比我更好,今后千萬不要再誤解hashCode()方法的作用。

??????? 3.? 關于Class類的成員函數與Java反射機制
??????? 很早剛接觸Java就聽很多老師說過Java的動態運行時機制、反射機制等。確實它們都是Java的顯著特點,運行時加載筆者在第一篇介紹過了,現在想講講反射機制。在Java中,主要是通過java.lang包中的Class類和Method類來實現內存反射機制的。
??????? 熟悉C++的人一定知道下面這樣在C++中是做不到的:? 運行時以字符串參數傳遞一個類名,就可以得到這個類的所有信息,包括它所有的方法,和方法的詳細信息。還可以實例化一個對象,并通過查到的方法名來調用該對象的任何方法。這是因為Java的類在內存中除了C++中也有的靜態動態數據區之外,還包括一份對類自身的描述,也正是通過這描述中的信息,才能幫助我們才運行時讀取里面的內容,得到需要加載目標類的所有信息,從而實現反射機制。大家有沒有想過當我們需要得到一個JavaBean的實例的時候,怎么知道它有哪些屬性呢?再明顯簡單不過的例子就是自己寫一個JavaBean的解析器:

??????? a.? 通過Class.forName(“Bean的類名”)得到Class對象,例如叫ABeanClass
??????? b.? 通過ABeanClass的getMethods()方法,得到Method[]對象
??????? c.? 按照規范所有get方法名后的單詞就代表著該Bean的一個屬性
??????? d.? 當已經知道一個方法名,可以調用newInstance()得到一個實例,然后通過invoke()方法將方法的名字和方法需要用的參數傳遞進去,就可以動態調用此方法。

??????? 當然還有更復雜的應用,這里就不贅述,大家可以參考Class類和Method類的方法。

??????? 4.? 坦言Synchronize的本質
??????? Synchronize大家都知道是同步、加鎖的意思,其實它的本質遠沒有大家想得那么復雜。聲明Synchronize的方法被調用的時候,鎖其實是加載對象上,當然如果是靜態類則是加在類上的鎖,調用結束鎖被解除。它的實現原理很簡單,僅僅是不讓第二把鎖再次被加在同一個對象或類上,僅此而已。一個簡單的例子足以說明問題:
??????? class? A{
synchronized? void? f(){}
void? g(){}
??????? }

??????? 當A的一個對象a被第一個線程調用其f()方法的時候,第二個線程不能調用a的synchronized方法例如f(),因為那是在試圖在對象上加第二把鎖。但調用g()卻是可以的,因為并沒有在同一對象上加兩把鎖的行為產生。


1.關于序列化和反序列化
??????? 應該大家都大概知道Java中序列化和反序列化的意思,序列化就是把一個Java對象轉換成二進制進行磁盤上傳輸或者網絡流的傳輸,反序列化的意思就是把這個接受到的二進制流重新組裝成原來的對象逆過程。它們在Java中分別是通過ObjectInputStream和? ObjectOutStream這兩個類來實現的(以下分別用ois和oos來簡稱)。
?????
??????? oos的writeObject()方法用來執行序列化的過程,ois的readObject()用來執行反序列化的過程,在傳輸二進制流之前,需要講這兩個高層流對象連接到同一個Channel上,這個Channel可以是磁盤文件,也可以是socket底層流。所以無論用哪種方式,底層流對象都是以構造函數參數的形式傳遞進oos和ois這兩個高層流,連接完畢了才可以進行二進制數據傳輸的。例子:
??????? 可以是文件流通道
??????? file? =? new? File(“C:/data.dat”);
??????? oos? =? new? ObjectOutputStream(new? FileOutputStream(file));
??????? ois? =? new? ObjectInputStream(new? FileInputStream(file));
?????
??????? 或者網絡流通道
??????? oos? =? new? ObjectOutputStream(socket.getOutputStream());
??????? ois? =? new? ObjectInputStream(socket.getInputStream());?

??????? 不知道大家是否注意到oos總是在ois之前定義,這里不希望大家誤解這個順序是固定的么?回答是否定的,那么有順序要求么?回答是肯定的。原則是什么呢?
原則是互相對接的輸入/輸出流之間必須是output流先初始化然后再input流初始化,否則就會拋異常。大家肯定會問為什么?只要稍微看一看這兩個類的源代碼文件就大概知道了,output流的任務很簡單,只要把對象轉換成二進制往通道中寫就可以了,但input流需要做很多準備工作來接受并最終重組這個Object,所以ObjectInputStream的構造函數中就需要用到output初始化發送過來的header信息,這個方法叫做? readStreamHeader(),它將會去讀兩個Short值用于決定用多大的緩存來存放通道發送過來的二進制流,這個緩存的size因jre的版本不同是不一樣的。所以output如果不先初始化,input的構造函數首先就無法正確運行。
?????
??????? 對于上面兩個例子,第一個順序是嚴格的,第二個因為oos和ois連接的已經不是對方了,而是socket另外一端的流,需要嚴格按照另外一方對接的output流先于對接的input流打開才能順利運行。
?????
??????? 這個writeObject和readObject本身就是線程安全的,傳輸過程中是不允許被并發訪問的。所以對象能一個一個接連不斷的傳過來,有很多人在運行的時候會碰到EOFException,? 然后百思不得其解,去各種論壇問解決方案。其實筆者這里想說,這個異常不是必須聲明的,也就是說它雖然是異常,但其實是正常運行結束的標志。EOF表示讀到了文件尾,發送結束自然連接也就斷開了。如果這影響到了你程序的正確性的話,請各位靜下心來看看自己程序的業務邏輯,而不要把注意力狹隘的聚集在發送和接受的方法上。因為筆者也被這樣的bug困擾了1整天,被很多論壇的帖子誤解了很多次最后得出的教訓。如果在while循環中去readObject,本質上是沒有問題的,有對象數據來就會讀,沒有就自動阻塞。那么拋出EOFException一定是因為連接斷了還在繼續read,什么原因導致連接斷了呢?一定是業務邏輯哪里存在錯誤,比如NullPoint、? ClassCaseException、ArrayOutofBound,即使程序較大也沒關系,最多只要單步調適一次就能很快發現bug并且解決它。
?????
??????? 難怪一位程序大師說過:解決問題90%靠經驗,5%靠技術,剩下5%靠運氣!真是金玉良言,筆者大概查閱過不下30篇討論在while循環中使用? readObject拋出EOFExceptionde? 的帖子,大家都盲目的去關注解釋這個名詞、反序列化的行為或反對這樣寫而沒有一個人認為EOF是正確的行為,它其實很老實的在做它的事情。為什么大家都忽略了真正出錯誤的地方呢?兩個字,經驗!

??????? 2.關于Java的多線程編程
??????? 關于Java的線程,初學或者接觸不深的大概也能知道一些基本概念,同時又會很迷惑線程到底是怎么回事?如果有人認為自己已經懂了不妨來回答下面的問題:
??????? a.? A對象實現Runnable接口,A.start()運行后所謂的線程對象是誰?是A么?
??????? b.? 線程的wait()、notify()方法到底是做什么時候用的,什么時候用?
??????? c.? 為什么線程的suspend方法會被標注過時,不推薦再使用,線程還能掛起么?
??????? d.? 為了同步我們會對線程方法聲明Synchronized來加鎖在對象上,那么如果父類的f()方法加了Synchronized,子類重寫f()方法必須也加Synchronized么?如果子類的f()方法重寫時聲明Synchronized并調用super.f(),那么子類對象上到底有幾把鎖呢?會因為競爭產生死鎖么?

??????? 呵呵,各位能回答上來幾道呢?如果這些都能答上來,說明對線程的概念還是滿清晰的,雖說還遠遠不能算精通。筆者這里一一做回答,礙于篇幅的原因,筆者盡量說得簡介一點,如果大家有疑惑的歡迎一起討論。
?????
??????? 首先第一點,線程跟對象完全是兩回事,雖然我們也常說線程對象。但當你用run()和start()來啟動一個線程之后,線程其實跟這個繼承了? Thread或實現了Runnable的對象已經沒有關系了,對象只能算內存中可用資源而對象的方法只能算內存正文區可以執行的代碼段而已。既然是資源和代碼段,另外一個線程當然也可以去訪問,main函數執行就至少會啟動兩個線程,一個我們稱之為主線程,還一個是垃圾收集器的線程,主線程結束就意味著程序結束,可垃圾收集器線程很可能正在工作。
?????
??????? 第二點,wait()和sleep()類似,都是讓線程處于阻塞狀態暫停一段時間,不同之處在于wait會釋放當前線程占有的所有的鎖,而? sleep不會。我們知道獲得鎖的唯一方法是進入了Synchronized保護代碼段,所以大家會發現只有Synchronized方法中才會出現? wait,直接寫會給警告沒有獲得當前對象的鎖。所以notify跟wait配合使用,notify會重新把鎖還給阻塞的線程重而使其繼續執行,當有多個對象wait了,notify不能確定喚醒哪一個,必經鎖只有一把,所以一般用notifyAll()來讓它們自己根據優先級等競爭那唯一的一把鎖,競爭到的線程執行,其他線程只要繼續wait。

??????? 從前Java允許在一個線程之外把線程掛起,即調用suspend方法,這樣的操作是極不安全的。根據面向對象的思想每個對象必須對自己的行為負責,而對自己的權力進行封裝。如果任何外步對象都能使線程被掛起而阻塞的話,程序往往會出現混亂導致崩潰,所以這樣的方法自然是被斃掉了啦。
?????
??????? 最后一個問題比較有意思,首先回答的是子類重寫f()方法可以加Synchronized也可以不加,如果加了而且還內部調用了super.f? ()的話理論上是應該對同一對象加兩把鎖的,因為每次調用Synchronized方法都要加一把,調用子類的f首先就加了一把,進入方法內部調用父類的? f又要加一把,加兩把不是互斥的么?那么調父類f加鎖不就必須永遠等待已經加的鎖釋放而造成死鎖么?實際上是不會的,這個機制叫重進入,當父類的f方法試圖在本對象上再加一把鎖的時候,因為當前線程擁有這個對象的鎖,也可以理解為開啟它的鑰匙,所以同一個線程在同一對象上還沒釋放之前加第二次鎖是不會出問題的,這個鎖其實根本就沒有加,它有了鑰匙,不管加幾把還是可以進入鎖保護的代碼段,暢通無阻,所以叫重進入,我們可以簡單認為第二把鎖沒有加上去。
?????
??????? 總而言之,Synchronized的本質是不讓其他線程在同一對象上再加一把鎖。


1.? Java關于XML的解析???
??????? 相信大家對XML都不陌生,含義是可擴展標記語言。本身它也就是一個數據的載體以樹狀表現形式出現。后來慢慢的數據變成了信息,區別是信息可以包括可變的狀態從而針對程序硬編碼的做法變革為針對統一接口硬編碼而可變狀態作為信息進入了XML中存儲。這樣改變狀態實現擴展的唯一工作是在XML中添加一段文本信息就可以了,代碼不需要改動也不需要重新編譯。這個靈活性是XML誕生時候誰也沒想到的。?

??????? 當然,如果接口要能提取XML中配置的信息就需要程序能解析規范的XML文件,Java中當然要提高包對這個行為進行有利支持。筆者打算講到的兩個包是 org.w3c.dom和javax.xml.parsers和。(大家可以瀏覽一下這些包中間的接口和類定義)?
???????
??????? Javax.xml.parsers包很簡單,沒有接口,兩個工廠配兩個解析器。顯然解析XML是有兩種方式的:DOM解析和SAX解析。本質上并沒有誰好誰不好,只是實現的思想不一樣罷了。給一個XML文件的例子:?
????????? <?xml? version=”1.0”? encoding=”UTF-8”? >?
????????? <root? >?
<child??? name=”Kitty”? >???
????????????????? A? Cat???
????????????????? </child? >?
????????? </root? >?
???????
??????? 所謂DOM解析的思路是把整個樹狀圖存入內存中,需要那個節點只需要在樹上搜索就可以讀到節點的屬性,內容等,這樣的好處是所有節點皆在內存可以反復搜索重復使用,缺點是需要消耗相應的內存空間。?
???????
??????? 自然SAX解析的思路就是為了克服DOM的缺點,以事件觸發為基本思路,順序的搜索下來,碰到了Element之前觸發什么事件,碰到之后做什么動作。由于需要自己來寫觸發事件的處理方案,所以需要借助另外一個自定義的Handler,處于org.xml.sax.helpers包中。它的優點當然是不用整個包都讀入內存,缺點也是只能順序搜索,走完一遍就得重來。?
???????
??????? 大家很容易就能猜到,接觸到的J2ee框架用的是哪一種,顯然是DOM。因為類似Struts,Hibernate框架配置文件畢竟是很小的一部分配置信息,而且需要頻繁搜索來讀取,當然會采用DOM方式(其實SAX內部也是用DOM采用的結構來存儲節點信息的)。現在無論用什么框架,還真難發現使用 SAX來解析XML的技術了,如果哪位仁兄知道,請讓筆者也學習學習。?

??????? 既然解析方式有了,那么就需要有解析的存儲位置。不知道大家是否發現org.w3c.dom這個包是沒有實現類全部都是接口的。這里筆者想說一下Java 如何對XML解析是Jdk應該考慮的事,是它的責任。而w3c組織是維護定義XML標準的組織,所以一個XML結構是怎么樣的由w3c說了算,它不關心 Java如何去實現,于是乎規定了所有XML存儲的結構應該遵循的規則,這就是org.w3c.dom里全部的接口目的所在。在筆者看來,簡單理解接口的概念就是實現者必須遵守的原則。?

??????? 整個XML對應的結構叫Document、子元素對應的叫做Element、還有節點相關的Node、NodeList、Text、Entity、 CharacterData、CDATASection等接口,它們都可以在XML的語法中間找到相對應的含義。由于這里不是講解XML基本語法,就不多介紹了。如果大家感興趣,筆者也可以專門寫一篇關于XML的語法規則帖與大家分享一下。?

??????? 2.? Java? Swing?
??????? Swing是一個讓人又愛又恨的東西,可愛之處在于上手很容易,較AWT比起來Swing提供的界面功能更加強大,可恨之處在于編復雜的界面工作量實在是巨大。筆者寫過超過3000行的Swing界面,感覺用戶體驗還不是那么優秀。最近又寫過超過6000行的,由于功能模塊多了,整體效果還只是一般般。體會最深的就一個字:累!? 所以大家現在都陸續不怎么用Swing在真正開發的項目上了,太多界面技術可以取代它了。筆者去寫也是迫于無奈組里面大家都沒寫過,我不入地域誰入??
???????
??????? 盡管Swing慢慢的在被人忽略,特別是隨著B/S慢慢的在淹沒C/S,筆者倒是很愿意站出來為Swing正身。每一項技術的掌握絕不是為了流行時尚跟風。真正喜歡Java的朋友們還是應該好好體會一下Swing,相信在校的很多學生也很多在學習它。很可能從Jdk? 1.1、1.2走過來的很多大學老師可能是最不熟悉它的。?
Swing提供了一組輕組件統稱為JComponent,它們與AWT組件的最大區別是JComponent全部都是Container,而 Container的特點是里面可以裝載別的組件。在Swing組件中無論是JButton、JLabel、JPanel、JList等都可以再裝入任何其他組件。好處是程序員可以對Swing組件實現“再開發”,針對特定需求構建自己的按鈕、標簽、畫板、列表之類的特定組件。?

??????? 有輕自然就有重,那么輕組件和重組件區別是?重組件表現出來的形態因操作系統不同而異,輕組件是Swing自己提供GUI,在跨平臺的時候最大程度的保持一致。?
那么在編程的時候要注意一些什么呢?筆者談談自己的幾點經驗:?

??????? a.? 明確一個概念,只有Frame組件才可以單獨顯示的,也許有人會說JOptionPane里面的靜態方法就實現了單獨窗口出現,但追尋源代碼會發現其實現實出來的Dialog也需要依托一個Frame窗體,如果沒有指定就會默認產生一個然后裝載這個Dialog顯示出來。?

??????? b.? JFrame是由這么幾部分組成:?
??????????????? 最底下一層JRootPane,上面是glassPane? (一個JPanel)和layeredPane? (一個JLayeredPane),而layeredPane又由contentPane(一個JPanel)和menuBar構成。我們的組件都是加在 contentPane上,而背景圖片只能加在layeredPane上面。? 至于glassPane是一個透明的覆蓋了contentPane的一層,在特定效果中將被利用到來記錄鼠標坐標或掩飾組件。?

??????? c.? 為了增強用戶體驗,我們會在一些按鈕上添加快捷鍵,但Swing里面通常只能識別鍵盤的Alt鍵,要加入其他的快捷鍵,必須自己實現一個ActionListener。?

??????? d.? 通過setLayout(null)可以使得所有組件以setBounds()的四個參數來精確定位各自的大小、位置,但不推薦使用,因為好的編程風格不應該在Swing代碼中硬編碼具體數字,所有的數字應該以常數的形式統一存在一個靜態無實例資源類文件中。這個靜態無實例類統一負責Swing界面的風格,包括字體和顏色都應該包括進去。?

??????? e.? 好的界面設計有一條Golden? Rule:? 用戶不用任何手冊通過少數嘗試就能學會使用軟件。所以盡量把按鈕以菜單的形式(不管是右鍵菜單還是窗體自帶頂部菜單)呈現給顧客,除非是頻繁點擊的按鈕才有必要直接呈現在界面中。


本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/lyc675154145/archive/2009/12/22/5051635.aspx

轉載于:https://www.cnblogs.com/blackcore/archive/2010/01/08/1642051.html

總結

以上是生活随笔為你收集整理的JAVA编程经验汇总 (载)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

亚洲一级片免费观看 | 亚洲精品自拍视频在线观看 | www.色爱| www.97色.com| 欧美 亚洲 另类 激情 另类 | 国产精品普通话 | 日韩精品中文字幕在线播放 | 亚洲人av免费网站 | 欧美另类人妖 | 亚洲精品美女久久17c | 久久免费国产精品 | 久久天天躁| 婷婷伊人五月天 | 亚洲精品美女在线观看播放 | 久久人人爽人人人人片 | 色婷婷精品大在线视频 | 91精品国产91久久久久福利 | 中文字幕在线播放第一页 | 久草在线视频在线观看 | 色综合久久久 | 婷婷精品在线 | 不卡的av在线播放 | 久久99久久99精品免费看小说 | 欧美一区二区伦理片 | 手机av看片| 亚洲精品国偷拍自产在线观看 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 久久成人国产精品免费软件 | 久草综合在线观看 | 欧美大片www | av在线永久免费观看 | 国产精品理论视频 | 久久看毛片 | 亚洲自拍偷拍色图 | 超碰人人射 | 久久久久久久国产精品视频 | 亚洲一二视频 | 国产一区二区三区高清播放 | 国产高清免费在线播放 | 在线观看aa | 黄色小说网站在线 | 国产在线传媒 | 免费观看成人网 | 91精彩视频在线观看 | 亚洲综合成人在线 | 日本少妇久久久 | 中文字幕av播放 | 欧美一区二区在线免费看 | 亚州精品天堂中文字幕 | 99精品免费在线 | 日本狠狠色 | 日日狠狠 | 中文字幕91在线 | 99久久日韩精品免费热麻豆美女 | 毛片a级片| 草久久久久 | 天堂在线免费视频 | 成人av视屏 | 免费av高清 | 91在线文字幕 | 日韩av中文在线观看 | 日韩高清不卡在线 | 成人h视频在线 | 91久久久久久国产精品 | 国产精品一区二区免费 | 高清精品视频 | 日韩欧美xx | 精品国产大片 | 国产99视频在线观看 | 国产色一区| 五月婷婷视频在线观看 | 中文视频在线 | 精品国产一区二区三区四区vr | 欧美国产日韩一区二区三区 | 日韩免费播放 | 在线三级播放 | 人人爱爱人人 | 黄色在线观看免费 | 亚洲免费av片 | 久久电影国产免费久久电影 | 日日爽视频 | 欧美淫aaa免费观看 日韩激情免费视频 | 欧美a√在线 | 久久久久久久久久久久久影院 | 国产黑丝一区二区三区 | 免费日韩一区二区三区 | 91色综合 | av在线免费播放网站 | 精品一区二区6 | www.操.com| 国产视频精品在线 | 日本bbbb摸bbbb | 久久久久久久久网站 | 色停停五月天 | 日韩中文字幕免费在线观看 | 在线国产日韩 | 日韩深夜在线观看 | 一区二区三区精品在线视频 | 免费久久99精品国产婷婷六月 | 中文字幕在线视频免费播放 | 国产白浆在线观看 | 国产精品无av码在线观看 | 91亚洲激情 | 91成品人影院 | 97视频资源| 91精品国自产在线观看欧美 | 在线观看视频你懂得 | 97精品超碰一区二区三区 | 亚洲国产精品久久久久久 | 欧美日韩aaaa| 久久视频中文字幕 | 天天干天天草天天爽 | 亚洲四虎| 久久精品人人做人人综合老师 | 久久久18 | 超碰免费97 | 四虎永久精品在线 | 日韩有色 | 五月婷丁香网 | 国产你懂的在线 | 国产视频综合在线 | 99视频这里只有 | 男女啪啪网站 | 国产a国产a国产a | 国产亚洲精品女人久久久久久 | 国产精品久99 | 国产1区在线观看 | 国产在线观看av | 欧美性久久久久久 | 成人a免费视频 | 91探花国产综合在线精品 | 黄影院| 国产区精品在线 | 最新一区二区三区 | 中文乱幕日产无线码1区 | 2021国产在线 | 美女黄视频免费 | 日韩特级毛片 | 在线视频日韩一区 | 亚洲精品视频二区 | 国产一区免费在线观看 | 国产精品一区二区av影院萌芽 | 国产三级香港三韩国三级 | 手机在线看片日韩 | 一级一片免费观看 | 色婷婷88av视频一二三区 | 91亚洲精品乱码久久久久久蜜桃 | 午夜国产福利在线观看 | 国产精品淫 | 美女视频一区二区 | 在线观看中文 | 99精品视频网| 99av国产精品欲麻豆 | 午夜国产一区 | 日韩一区二区在线免费观看 | 91亚洲成人| 久久久五月天 | 色狠狠婷婷 | 久久久久久蜜桃一区二区 | 欧美成天堂网地址 | 国语精品免费视频 | 精品字幕在线 | 亚洲精品一区二区久 | 日韩av资源在线观看 | 国产二区视频在线观看 | 夜夜躁日日躁狠狠久久88av | 在线综合 亚洲 欧美在线视频 | 色婷婷狠狠五月综合天色拍 | 国产视频日本 | 国产又粗又猛又爽又黄的视频先 | 久久国产精品色婷婷 | 免费日韩三级 | 国产一区欧美二区 | 国产99久久99热这里精品5 | 久草精品资源 | 亚洲精品小视频在线观看 | 天天夜夜狠狠操 | a级片在线播放 | 日韩精品网址 | 欧美黑人xxxx猛性大交 | 操操综合网 | 日本黄色免费在线 | 808电影 | 五月天色综合 | 摸bbb搡bbb搡bbbb | 婷婷免费在线视频 | 中文字幕成人av | avv天堂| 亚洲影视九九影院在线观看 | 91av久久| 丁香六月色 | 日日干 天天干 | 国产一级电影免费观看 | 国产成人一区二区在线观看 | 欧美性粗大hdvideo | 亚洲欧美视频网站 | 99热99热| 久久一本综合 | 国产123区在线观看 国产精品麻豆91 | 一二三四精品 | 最近免费中文字幕大全高清10 | 亚洲无在线 | 日韩av片免费在线观看 | 久久激情婷婷 | 丁香激情网 | 一二区av | 国产精彩视频一区 | 亚洲视频在线播放 | 日韩欧美国产视频 | 免费看国产精品 | 日韩电影一区二区三区在线观看 | 五月婷婷视频在线观看 | 最近中文字幕完整视频高清1 | 五月婷香蕉久色在线看 | 中文字幕第一页在线 | 欧美做受高潮电影o | 人人精久| 男女全黄一级一级高潮免费看 | 人人澡人人添人人爽一区二区 | 91看片在线看片 | 欧美五月婷婷 | 97免费视频在线播放 | 精品国内自产拍在线观看视频 | av高清不卡 | 久久99欧美 | 国内精品久久久久久中文字幕 | 日日夜夜天天 | 91精品国产一区二区在线观看 | 亚洲精品国产区 | 亚洲天堂激情 | 婷婷综合在线 | 香蕉在线观看视频 | 免费观看性生交 | 综合精品久久久 | 不卡av电影在线观看 | 成年美女黄网站色大片免费看 | 91精品爽啪蜜夜国产在线播放 | 毛片在线播放网址 | 在线观看成人福利 | 一区二区三区在线观看 | 久草a视频| 国产精品一区二区免费 | 亚洲国产av精品毛片鲁大师 | 亚洲欧美婷婷六月色综合 | 日韩中字在线观看 | 天堂在线一区 | 久久免费在线 | 天天天干夜夜夜操 | 国产精品中文字幕在线观看 | 久久99精品一区二区三区三区 | 国产精品一区二区在线观看免费 | 中文字幕在线字幕中文 | 国产精品久久久久久久久久99 | 91在线免费播放视频 | 亚洲国产精品500在线观看 | 中文字幕在线一区二区三区 | 欧美激情综合五月色丁香 | 99久久99久久免费精品蜜臀 | 久草在线视频看看 | 91大神精品视频在线观看 | 久久久在线免费观看 | 色吧久久 | 永久免费毛片在线观看 | 91精品国产乱码久久 | 国产精品综合久久久久 | 久久草在线视频国产 | 欧美精品久久久久久 | 丁香色婷婷 | 91精品国产欧美一区二区成人 | 精品亚洲成人 | 国产精品视频app | 99精品视频免费全部在线 | 日韩欧美视频一区二区 | 欧美大片在线观看一区 | 婷婷六月天天 | 日日操日日 | 天天操天天色综合 | 精品久久久久久亚洲综合网站 | 天堂入口网站 | 日韩电影中文,亚洲精品乱码 | 美女黄频在线观看 | 欧美日韩精品免费观看 | 亚洲午夜av电影 | 中文字幕一区二区三区精华液 | 国产原创在线观看 | 色妞色视频一区二区三区四区 | 国产精品系列在线观看 | 91视频这里只有精品 | 日本少妇久久久 | 中文字幕在线观看视频网站 | 麻豆视频91 | 激情在线免费视频 | 亚洲专区路线二 | 国产91九色蝌蚪 | 国产亚洲精品福利 | 91精品国产麻豆国产自产影视 | 日本久久久久久久久久 | 久久9999久久| 国产精品免费久久久久影院仙踪林 | 日韩不卡高清 | 日韩在线视频观看免费 | 中文字幕在线观看完整版电影 | 天天爱天天操天天射 | 91色偷偷 | 日韩小视频 | 国产精品a久久久久 | 人人超在线公开视频 | 免费亚洲黄色 | 国产精品99久久久久久有的能看 | 亚洲国产精品视频在线观看 | 国产精品99久久久久久久久久久久 | 天天激情| 日本护士撒尿xxxx18 | 在线网址你懂得 | 亚洲另类交 | 一区二区精品视频 | 国产不卡高清 | 97碰视频| 狠狠色丁香久久婷婷综合_中 | 天天色棕合合合合合合 | 99精品电影 | 国产精品免费不卡 | 热久久精品在线 | 黄网站色视频 | 国产91精品久久久久久 | 日韩首页 | 国产免费一区二区三区最新6 | 91av视频在线免费观看 | 美女精品 | 成年人视频在线 | 99免费在线观看视频 | 免费人成在线观看 | 伊人影院得得 | 成人国产综合 | 婷婷亚洲综合 | 超碰av在线免费观看 | 伊人五月 | 久久久久久黄 | 国产精品乱码高清在线看 | 天天想夜夜操 | 2021久久 | av解说在线 | 亚洲国产网站 | 国产日韩欧美自拍 | 999一区二区三区 | 中文字幕在线国产 | 国产精品一区久久久久 | 久久精品久久久久久久 | 中文字幕日韩电影 | 麻豆果冻剧传媒在线播放 | 国产亚洲精品久久久久久大师 | 月下香电影| 在线免费观看国产黄色 | av电影免费在线看 | 国产在线成人 | 女女av在线| 在线成人观看 | 久久99热精品 | 国产福利精品在线观看 | 天天干,天天射,天天操,天天摸 | 丁香六月天婷婷 | 一区二区三区视频在线 | 久久精品艹 | 国产一区二区精品久久 | 看片的网址| 国产日本高清 | 亚洲精品国产精品国产 | 国内亚洲精品 | 综合网天天 | 久久国产精品久久w女人spa | 亚洲国产成人av网 | 91超级碰碰 | 国产精品99久久久精品免费观看 | 激情av网址 | 亚洲国产成人在线观看 | 激情五月五月婷婷 | ,久久福利影视 | www.久久久 | 涩涩成人在线 | 久久久久久国产精品999 | 四虎永久免费网站 | 免费观看一区 | 国产精品9999久久久久仙踪林 | 狠狠色丁香婷婷综合久久片 | 久久久久久久综合色一本 | 91丨九色丨91啦蝌蚪老版 | 亚洲精品国产精品国自产 | 在线免费视频 你懂得 | 精品视频久久 | 精品电影一区 | 欧美成人h版在线观看 | 亚洲久草视频 | 天天干天天插伊人网 | 天堂av网在线 | 午夜精选视频 | 日韩两性视频 | 视频 天天草 | 一级全黄毛片 | 手机在线日韩视频 | 欧美视频18 | 国产精品免费在线播放 | 天天干天天拍 | 激情久久综合网 | 美女av在线免费 | 亚洲砖区区免费 | 高清av不卡 | 精品在线播放视频 | 在线观看久草 | 国产精品在线看 | 国产糖心vlog在线观看 | 国产精品久久人 | 激情五月亚洲 | 成人cosplay福利网站 | 最新国产福利 | 国产裸体视频网站 | 欧美午夜精品久久久久久孕妇 | 日韩视频一区二区三区在线播放免费观看 | 在线有码中文字幕 | 国产精品久久久久久久7电影 | 中文一区在线观看 | 麻豆影音先锋 | 久久精品视频在线观看免费 | 又大又硬又黄又爽视频在线观看 | 日本性视频 | 成年人免费电影在线观看 | 在线一二区 | 欧美在线视频第一页 | 91丨九色丨蝌蚪丨对白 | 亚洲精选在线观看 | 五月婷婷在线观看视频 | 色中色综合 | 午夜精品电影 | 成人超碰在线 | 国产成人不卡 | 中文字幕一区二区三区乱码在线 | 日韩av电影中文字幕 | 久久久久国产视频 | 欧美aa一级 | 免费视频99 | 不卡av电影在线观看 | 丁香花在线观看免费完整版视频 | 国产精品久久嫩一区二区免费 | 日韩精品无| 黄色软件在线观看 | 久久激情综合网 | 91pony九色丨交换 | 91亚洲精品久久久蜜桃网站 | 精品视频中文字幕 | 日本精品一 | 久草爱| 成人av在线直播 | 国产欧美日韩精品一区二区免费 | 人人精品久久 | 亚洲精品视频在线播放 | 久久久精品 一区二区三区 国产99视频在线观看 | 国产精品一区二区电影 | 欧美少妇的秘密 | 99久久99| 国产成人av在线影院 | 日韩在线观看视频中文字幕 | 97精品一区 | av成人在线播放 | 狠狠色噜噜狠狠狠狠2021天天 | 国产手机视频在线播放 | 一区二区三区 中文字幕 | 国产日韩精品在线观看 | 色香天天 | 亚洲国产成人久久综合 | 99久久999久久久精玫瑰 | 国产精品va视频 | 青草视频在线 | 国产中文a| 国产一区二区三区免费观看视频 | 国产精品九九九九九九 | 亚洲精品高清一区二区三区四区 | 欧美日本中文字幕 | 精精国产xxxx视频在线播放 | 在线黄色免费 | 日韩试看 | 久久综合亚洲鲁鲁五月久久 | 美国人与动物xxxx | 欧美日韩91 | 久久精品综合 | 91豆花在线观看 | 五月香婷| 日本中文在线 | 一区二区三区免费在线 | 99这里只有| 日韩在线看片 | 日b黄色片 | 欧美精品色 | 国产精品国产三级国产aⅴ无密码 | 99精品视频在线播放免费 | 一级成人免费 | 9797在线看片亚洲精品 | 婷婷六月丁 | 国产一区二区三区免费视频 | 97免费中文视频在线观看 | 亚洲精品乱码久久 | a久久久久久 | 亚洲视频免费 | 天天做天天射 | 久久久91精品国产 | 99久久99久久 | japanesexxxhd奶水 91在线精品一区二区 | 日日天天狠狠 | 97超碰资源网 | 日韩精品一区二区电影 | 97精品国产97久久久久久 | 美女露久久 | 狠狠网站| 国产日产精品一区二区三区四区 | 久久伊人精品一区二区三区 | 中文字幕一区二区三区久久蜜桃 | 九九国产精品视频 | 亚洲狠狠| 国内精自线一二区永久 | 国产精品黑丝在线观看 | 狠狠躁天天躁综合网 | 国产高清在线 | 激情 婷婷| 国产高清视频免费在线观看 | 美女网站视频免费都是黄 | av中文电影 | 夜夜爽88888免费视频4848 | 免费又黄又爽的视频 | 成年人免费在线观看 | 91免费视频网站在线观看 | 亚洲国产资源 | 久久精品精品电影网 | 国产爽妇网 | 日韩电影中文 | 韩国中文三级 | 久草新在线 | 午夜视频播放 | 超碰97国产精品人人cao | 中文字幕制服丝袜av久久 | 欧美一级黄色片 | 97狠狠干 | 一区 二区电影免费在线观看 | 美女久久一区 | 一区视频在线 | 日本最新一区二区三区 | 国产中文字幕大全 | 亚在线播放中文视频 | 国产精品乱看 | 婷婷丁香社区 | 久久国产精品久久国产精品 | 狠狠狠色丁香婷婷综合久久88 | 成人福利av| 久久婷婷色综合 | 欧美性免费 | 天堂av免费在线 | 午夜国产一区 | 国产高清亚洲 | 日本黄色片一区二区 | 激情婷婷综合网 | 久久久久久久久久久影视 | 久久久五月婷婷 | 日韩在线免费小视频 | 亚洲午夜精品久久久久久久久久久久 | 免费在线一区二区三区 | 亚洲午夜精品久久久久久久久久久久 | 国产在线一线 | 久久婷婷五月综合色丁香 | 久久精品视频18 | 久久久精华网 | 久久这里只有精品首页 | 在线观看av网站 | 久久视频在线免费观看 | 久久免费看 | 高清久久久久久 | 欧美特一级 | 天天综合网~永久入口 | 国产成人一区二区啪在线观看 | 国产成人免费高清 | 久久久久亚洲天堂 | 婷婷综合网| 久久呀 | 亚洲精品mv在线观看 | 蜜臀一区二区三区精品免费视频 | 久热这里有精品 | 日韩av在线免费看 | 国产视频美女 | 日本免费一二三区 | 成人在线一区二区三区 | www.亚洲精品在线 | 亚洲免费视频观看 | 97av.com | 亚洲一级电影在线观看 | 成人在线播放免费观看 | 久久久久国产精品视频 | 天堂在线一区二区 | 欧美激情在线网站 | 国产精品va在线播放 | 国产精品久久久久高潮 | 奇米网网址| 国产精品第一页在线 | 亚洲人av免费网站 | 久久综合射 | 日本中文字幕在线观看 | 狠狠色综合网站久久久久久久 | 91漂亮少妇露脸在线播放 | 国产精品久久久久一区二区三区共 | 在线成人高清电影 | 色.www| 亚洲成aⅴ人在线观看 | 国产中文字幕国产 | 色99导航| 色在线观看网站 | 日韩欧美视频在线免费观看 | 久久精品一区 | 久久专区 | 精品电影一区 | 超黄视频网站 | 国产精品mv | 91精品久久香蕉国产线看观看 | 91精品国| 麻豆一区在线观看 | 91精品1区2区| 青青看片| 日本高清免费中文字幕 | 五月天狠狠操 | 国产视频在线免费 | 91av在线看 | 久久久久激情电影 | 亚洲成av人片在线观看香蕉 | 欧美日韩国产高清视频 | 日韩精品一区二区在线观看 | 久草视频手机在线 | www日| 黄色网址在线播放 | 97电影在线 | 免费国产在线观看 | 日韩av电影免费在线观看 | 一区二区视频在线观看免费 | 亚洲最大激情中文字幕 | 天天色.com| 91麻豆精品91久久久久同性 | 激情五月在线 | 国产色就色 | 美女精品在线 | av 一区二区三区 | 日韩高清免费观看 | 国产在线更新 | 色综合久久久久综合体 | 成人午夜电影在线播放 | 天天色天天射天天综合网 | 国产精品video爽爽爽爽 | 四虎国产精品免费观看视频优播 | 在线探花| 欧美另类v | 麻豆视频观看 | 久章草在线观看 | 四虎www| 亚洲精品97 | 91cn国产在线| 久久久久久国产精品999 | mm1313亚洲精品国产 | 久草视频网| 黄色大全在线观看 | 超碰在线人人 | 国产精品刺激对白麻豆99 | 国产一区在线视频观看 | 中文字幕人成乱码在线观看 | 这里只有精品视频在线观看 | 热久久国产| 久久美女免费视频 | 免费看网站在线 | 色国产精品一区在线观看 | 69夜色精品国产69乱 | 亚洲黄色免费在线看 | 中文字幕中文中文字幕 | 亚洲免费小视频 | 91香蕉视频黄色 | 国产二区视频在线 | 日本久久中文 | 日韩av偷拍| 福利久久久 | 91av大全| 天天曰天天曰 | 天天干人人 | 91精品国产一区 | 久99久中文字幕在线 | 国产精品成人一区二区三区吃奶 | 亚洲婷婷在线视频 | 国产成人精品一区二区三区福利 | 丝袜网站在线观看 | 999免费视频 | 国产高清视频免费最新在线 | 日韩在线视频一区二区三区 | 国产精品岛国久久久久久久久红粉 | 日本久久成人 | 亚洲欧洲精品在线 | 91精彩视频 | 国产精品自产拍在线观看中文 | 午夜久久福利 | 国产精品久久久久久久久久久久久 | 午夜精品一区二区三区免费 | 91精品人成在线观看 | 99热这里只有精品免费 | av黄免费看 | 91视频三区| 国产系列在线观看 | 国产成人精品网站 | 色婷婷激情 | 国产精品资源在线观看 | 综合亚洲视频 | 色综合久久综合中文综合网 | 欧美一二区视频 | 国产在线无 | 二区三区av| 最近中文字幕在线播放 | 99精品国产成人一区二区 | 日韩在线观看视频免费 | 日韩高清 一区 | 亚洲乱码一区 | 狠狠色丁香久久婷婷综合丁香 | 久久免费视频一区 | 国内精品久久久久影院日本资源 | 99中文字幕在线观看 | 久久精品一区二区三区四区 | 久久精品电影院 | 超碰国产在线 | 久久久久在线视频 | 九九免费观看全部免费视频 | 国产又粗又长又硬免费视频 | 色中文字幕在线观看 | 高清一区二区三区av | 免费在线一区二区 | 91精品国产高清 | 久久永久免费视频 | 五月天激情视频 | 九色精品免费永久在线 | 中文字幕在线观看日本 | 欧美一区二区日韩一区二区 | 黄色毛片一级 | 精品一区二区在线免费观看 | 亚洲香蕉视频 | 五月婷婷黄色 | 日韩精品一区在线播放 | 五月天亚洲综合 | 日韩欧美电影在线观看 | 国产美女久久久 | 欧美aaa大片 | 天天激情综合 | 成人av av在线 | 亚洲精品在线观看中文字幕 | 香蕉视频国产在线观看 | 91丨九色丨国产女 | 午夜精品久久久久久久99婷婷 | 亚洲黄色免费网站 | 激情开心 | 在线视频日韩欧美 | 日韩试看 | 国产真实在线 | 精品国产伦一区二区三区 | 天天久久夜夜 | 国产成人精品三级 | 激情五月伊人 | 九九精品毛片 | 亚洲一区二区三区四区精品 | 91精品中文字幕 | 夜夜操狠狠干 | 国产三级在线播放 | 日韩欧美一区二区三区免费观看 | 黄色精品久久 | 国产美女网| 亚洲欧美一区二区三区孕妇写真 | 日韩午夜高清 | 激情五月婷婷丁香 | 蜜臀久久99精品久久久无需会员 | 国产精久久| 欧美色888 | 久久精品视频3 | av官网 | 国产精品永久免费视频 | 国产一级特黄毛片在线毛片 | 天天操天天干天天玩 | 欧美日韩后 | 波多野结衣精品视频 | 国产精品久久久久久久免费 | 黄色国产区 | 成人污视频在线观看 | 成人三级av| 久久人人爽人人爽人人片av软件 | 不卡的av片 | 视频一区二区在线观看 | 婷婷丁香色 | 综合亚洲视频 | 91亚州 | 欧美 日韩 性 | 五月天久久精品 | 亚洲三级网 | 国产精品久久久久毛片大屁完整版 | 成年人看片网站 | 日韩视频1 | 亚洲永久精品视频 | 久久久网址 | 播五月婷婷 | 日韩色在线观看 | 国产免费视频一区二区裸体 | 免费av在线 | 四虎亚洲精品 | 久草电影免费在线观看 | 最新av在线播放 | 久久伊人爱 | av在线一二三区 | 午夜91在线 | 婷婷色在线观看 | 精品电影一区二区 | 久久久激情网 | 欧美一级欧美一级 | 婷婷久月 | 日韩亚洲国产精品 | 特级西西www44高清大胆图片 | 天天射网站 | 九九免费在线看完整版 | 一区二区在线影院 | 人人插人人玩 | 国产夫妻自拍av | 国产在线不卡精品 | 久久久国产精品一区二区三区 | 亚洲最新视频在线 | 91精品视频观看 | 欧美极品一区二区三区 | 天天射天天| 奇米777777 | 最新国产精品视频 | 日韩免费视频在线观看 | 亚洲国产精品久久久 | 成年人在线免费看视频 | 麻豆你懂的 | 成人中心免费视频 | 欧美久久久久久久久久久久 | 国产欧美精品一区二区三区四区 | 黄色大片日本 | 国产视频一区在线 | 中文字幕在线观看免费 | 成人在线电影观看 | 亚洲国产精品一区二区尤物区 | 久草在在线视频 | 久久精品一区二区三区中文字幕 | 麻豆激情电影 | 国产青春久久久国产毛片 | 国产高清视频在线播放 | 午夜精品麻豆 | 夜夜操天天操 | 久草色在线观看 | 日韩精品在线看 | 亚洲影视资源 | 中文字幕字幕中文 | www五月婷婷 | 久久综合免费视频影院 | 色综合色综合色综合 | 婷婷.com| 国产精品日韩在线 | 色综合婷婷 | 中文字幕成人网 | 少妇bbbb| 91亚洲精品国偷拍 | 黄色一级免费电影 | 国产精品九九久久久久久久 | 五月婷婷av | 久久99影院 | 国产精品久久久久久久久久久久午夜 | 99久久精品视频免费 | 亚洲欧洲日韩 | 日韩av成人在线观看 | 久久精品老司机 | 亚洲天堂自拍视频 | 久久免费看a级毛毛片 | 久久免费精彩视频 | 69亚洲视频| 中文字幕免费一区二区 | 99久久婷婷国产精品综合 | 色噜噜噜噜 | 久久久精品在线观看 | 国产va饥渴难耐女保洁员在线观看 | 国产精品1区2区3区在线观看 | 亚洲最新av在线 | 香蕉在线视频播放网站 | 99久久精品费精品 | 日韩夜夜爽| 久久成人一区二区 | 免费日p视频 | 婷婷视频在线播放 | 欧美极品在线播放 | 久青草视频| 黄色91在线观看 | 99精品黄色片免费大全 | 在线观看日韩国产 | 婷婷伊人综合亚洲综合网 | 五月天丁香 | 日韩午夜大片 | 亚洲视屏一区 | 国产成人免费精品 | 久久久久久久久亚洲精品 | 91网免费观看 | 久久久久久高潮国产精品视 | 免费午夜视频在线观看 | 久久成人精品视频 | 久久久国产一区二区三区四区小说 | 亚洲精品乱码白浆高清久久久久久 | 国产高清久久久久 | 久操伊人 | 日韩成人精品在线观看 | 99riav1国产精品视频 | 天天干天天操天天入 | 久久久www成人免费毛片 | 狠狠色伊人亚洲综合网站色 | 亚洲精品麻豆视频 | 久久99国产精品 | 欧美日韩91| 福利视频精品 | 欧美久久久 | 在线观看精品一区 | 国产成人61精品免费看片 | 又紧又大又爽精品一区二区 | 婷婷五月色综合 | 久久草在线视频国产 | 亚洲国产成人在线 | 日韩欧美一区二区三区视频 | 三级在线视频观看 | 日韩欧美一区二区三区视频 | 国产高清不卡一区二区三区 | 91c网站色版视频 | 中文字幕日韩在线播放 | 免费色网 | 97精品电影院 | 久久久久久久久黄色 | 国内精品久久久久国产 | 久久久久久久久久国产精品 | 黄色www免费 | 亚洲精品国产精品99久久 | 99在线高清视频在线播放 | 欧美aa一级 | 久久久亚洲精品 | 日韩精品免费一区二区在线观看 | 亚洲va在线va天堂va偷拍 | 美女网站色在线观看 | 黄色软件在线观看免费 | 中文字幕欧美日韩va免费视频 | 热久久电影| 波多野结衣一区 | 午夜视频一区二区 | 亚洲精品视频中文字幕 | 91精品夜夜| 国产黄在线免费观看 | 中文字幕 在线 一 二 | 伊人国产在线观看 | 国产精品精品久久久久久 | 在线视频 影院 | 日韩欧美高清一区二区三区 | 偷拍精品一区二区三区 | 日韩欧美在线高清 | 999一区二区三区 | 色综合久久88色综合天天 | 日韩理论在线 | 久久精品视频在线观看 | 亚洲日本va中文字幕 | 亚州精品在线视频 | 亚洲成人精品av | 成人午夜电影网站 | 中文字幕在线视频免费播放 | 久久久香蕉视频 | 久久精品99国产 | 夜色资源站国产www在线视频 | 激情五月婷婷综合网 | 免费视频二区 | 久久国产精品一国产精品 | 在线观看深夜视频 | a级国产乱理论片在线观看 伊人宗合网 | 亚洲免费激情 | 免费又黄又爽视频 | 综合久久久 | 国产精品乱码久久久久 | 日韩免费网址 | 91天天操| 91成人在线视频 | 国产在线a | 国内精品二区 | 国产精品一区二区视频 | 欧美超碰在线 | 国产精品在线看 | 一区二区毛片 | 日日操网| 亚洲在线综合 | 黄色精品视频 | 亚洲欧美日本一区二区三区 | 亚洲午夜精品电影 | 久久天天躁| 久久精品一区二区国产 | 99热最新| 日韩亚洲国产中文字幕 | av在线免费网 | 欧美精品久久久久a | 婷婷在线免费 |