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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java知识点全面汇总

發布時間:2023/12/14 java 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java知识点全面汇总 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.



相關概念

面向對象的三個特征

封裝,繼承,多態,這個應該是人人皆知,有時候也會加上抽象。

多態的好處

允許不同類對象對同一消息做出響應,即同一消息可以根據發送對象的不同而采用多種不同的行為方式(發送消息就是函數調用)。主要有以下優點:

  • 可替換性:多態對已存在代碼具有可替換性

  • 可擴充性:增加新的子類不影響已經存在的類結構

  • 接口性:多態是超類通過方法簽名,向子類提供一個公共接口,由子類來完善或者重寫它來實現的。

  • 靈活性

  • 簡化性

  • 代碼中如何實現多態

    實現多態主要有以下三種方式
    1. 接口實現?
    2. 繼承父類重寫方法?
    3. 同一類中進行方法重載

    虛擬機是如何實現多態的

    動態綁定技術(dynamic binding),執行期間判斷所引用對象的實際類型,根據實際類型調用對應的方法。

    接口的意義

    接口的意義用三個詞就可以概括:規范,擴展,回調。

    抽象類的意義

    抽象類的意義可以用三句話來概括:

  • 為其他子類提供一個公共的類型

  • 封裝子類中重復定義的內容

  • 定義抽象方法,子類雖然有不同的實現,但是定義時一致的

  • 接口和抽象類的區別https://blog.csdn.net/weixin_37766296/article/details/80316284


    父類的靜態方法能否被子類重寫

    不能。重寫只適用于實例方法,不能用于靜態方法,而子類當中含有和父類相同簽名的靜態方法,我們一般稱之為隱藏

    什么是不可變對象

    不可變對象指對象一旦被創建,狀態就不能再改變。任何修改都會創建一個新的對象,如 String、Integer及其它包裝類

    靜態變量和實例變量的區別?(使用范圍不一樣)

    靜態變量存儲在方法區,屬于類所有。實例變量存儲在堆當中,其引用存在當前線程棧。

    能否創建一個包含可變對象的不可變對象?

    當然可以創建一個包含可變對象的不可變對象的,你只需要謹慎一點,不要共享可變對象的引用就可以了,如果需要變化時,就返回原對象的一個拷貝。最常見的例子就是對象中包含一個日期對象的引用。

    java 創建對象的幾種方式

  • 采用new

  • 通過反射

  • 采用clone

  • 通過序列化機制

  • 前2者都需要顯式地調用構造方法。造成耦合性最高的恰好是第一種,因此你發現無論什么框架,只要涉及到解耦必先減少new的使用。

    switch中能否使用string做參數

    在idk 1.7之前,switch只能支持byte, short, char, int或者其對應的封裝類以及Enum類型。從idk 1.7之后switch開始支持String。

    switch能否作用在byte, long上?

    可以用在byte上,但是不能用在long上。

    String s1=”ab”, String s2=”a”+”b”, String s3=”a”, String s4=”b”, s5=s3+s4請問s5==s2返回什么?

    返回false。在編譯過程中,編譯器會將s2直接優化為”ab”,會將其放置在常量池當中,s5則是被創建在堆區,相當于s5=new String(“ab”);

    你對String對象的intern()熟悉么?

    intern()方法會首先從常量池中查找是否存在該常量值,如果常量池中不存在則現在常量池中創建,如果已經存在則直接返回。
    比如?
    String s1=”aa”;?
    String s2=s1.intern();?
    System.out.print(s1==s2);//返回true

    Object中有哪些公共方法?

  • equals()

  • clone()

  • getClass()

  • notify(),notifyAll(),wait()

  • toString

    ?

  • java當中的四種引用

    強引用,軟引用,弱引用,虛引用。不同的引用類型主要體現在GC上:

  • 強引用:如果一個對象具有強引用,它就不會被垃圾回收器回收。即使當前內存空間不足,JVM也不會回收它,而是拋出 OutOfMemoryError 錯誤,使程序異常終止。如果想中斷強引用和某個對象之間的關聯,可以顯式地將引用賦值為null,這樣一來的話,JVM在合適的時間就會回收該對象。

  • 軟引用:在使用軟引用時,如果內存的空間足夠,軟引用就能繼續被使用,而不會被垃圾回收器回收,只有在內存不足時,軟引用才會被垃圾回收器回收。

  • 弱引用:具有弱引用的對象擁有的生命周期更短暫。因為當 JVM 進行垃圾回收,一旦發現弱引用對象,無論當前內存空間是否充足,都會將弱引用回收。不過由于垃圾回收器是一個優先級較低的線程,所以并不一定能迅速發現弱引用對象。

  • 虛引用:顧名思義,就是形同虛設,如果一個對象僅持有虛引用,那么它相當于沒有引用,在任何時候都可能被垃圾回收器回收。

  • ?

    更多了解參見深入對象引用:

    http://blog.csdn.net/dd864140130/article/details/49885811

    WeakReference與SoftReference的區別?

    這點在四種引用類型中已經做了解釋,這里簡單說明一下即可:?
    雖然 WeakReference 與 SoftReference 都有利于提高 GC 和 內存的效率,但是 WeakReference ,一旦失去最后一個強引用,就會被 GC 回收,而軟引用雖然不能阻止被回收,但是可以延遲到 JVM 內存不足的時候。

    為什么要有不同的引用類型

    不像C語言,我們可以控制內存的申請和釋放,在Java中有時候我們需要適當的控制對象被回收的時機,因此就誕生了不同的引用類型,可以說不同的引用類型實則是對GC回收時機不可控的妥協。有以下幾個使用場景可以充分的說明:

  • 利用軟引用和弱引用解決OOM問題:用一個HashMap來保存圖片的路徑和相應圖片對象關聯的軟引用之間的映射關系,在內存不足時,JVM會自動回收這些緩存圖片對象所占用的空間,從而有效地避免了OOM的問題.

  • 通過軟引用實現Java對象的高速緩存:比如我們創建了一Person的類,如果每次需要查詢一個人的信息,哪怕是幾秒中之前剛剛查詢過的,都要重新構建一個實例,這將引起大量Person對象的消耗,并且由于這些對象的生命周期相對較短,會引起多次GC影響性能。此時,通過軟引用和 HashMap 的結合可以構建高速緩存,提供性能。

  • java中==和eqauls()的區別,equals()和`hashcode的區別

    ==是運算符,用于比較兩個變量是否相等,而equals是Object類的方法,用于比較兩個對象是否相等。默認Object類的equals方法是比較兩個對象的地址,此時和==的結果一樣。換句話說:基本類型比較用==,比較的是他們的值。默認下,對象用==比較時,比較的是內存地址,如果需要比較對象內容,需要重寫equal方法。

    equals()和hashcode()的聯系

    hashCode()是Object類的一個方法,返回一個哈希值。如果兩個對象根據equal()方法比較相等,那么調用這兩個對象中任意一個對象的hashCode()方法必須產生相同的哈希值。
    如果兩個對象根據eqaul()方法比較不相等,那么產生的哈希值不一定相等(碰撞的情況下還是會相等的。)

    a.hashCode()有什么用?與a.equals(b)有什么關系

    hashCode() 方法是相應對象整型的 hash 值。它常用于基于 hash 的集合類,如 Hashtable、HashMap、LinkedHashMap等等。它與 equals() 方法關系特別緊密。根據 Java 規范,使用 equal() 方法來判斷兩個相等的對象,必須具有相同的 hashcode。

    將對象放入到集合中時,首先判斷要放入對象的hashcode是否已經在集合中存在,不存在則直接放入集合。如果hashcode相等,然后通過equal()方法判斷要放入對象與集合中的任意對象是否相等:如果equal()判斷不相等,直接將該元素放入集合中,否則不放入。

    有沒有可能兩個不相等的對象有相同的hashcode

    有可能,兩個不相等的對象可能會有相同的 hashcode 值,這就是為什么在 hashmap 中會有沖突。如果兩個對象相等,必須有相同的hashcode 值,反之不成立。

    可以在hashcode中使用隨機數字嗎?

    不行,因為同一對象的 hashcode 值必須是相同的

    a==b與a.equals(b)有什么區別

    如果a 和b 都是對象,則 a==b 是比較兩個對象的引用,只有當 a 和 b 指向的是堆中的同一個對象才會返回 true,而 a.equals(b) 是進行邏輯比較,所以通常需要重寫該方法來提供邏輯一致性的比較。例如,String 類重寫 equals() 方法,所以可以用于兩個不同對象,但是包含的字母相同的比較。

    3*0.1==0.3返回值是什么

    false,因為有些浮點數不能完全精確的表示出來。

    a=a+b與a+=b有什么區別嗎?

    +=操作符會進行隱式自動類型轉換,此處a+=b隱式的將加操作的結果類型強制轉換為持有結果的類型,而a=a+b則不會自動進行類型轉換。如:
    byte a = 127;?
    byte b = 127;?
    b = a + b; // error : cannot convert from int to byte?
    b += a; // ok?
    (譯者注:這個地方應該表述的有誤,其實無論 a+b 的值為多少,編譯器都會報錯,因為 a+b 操作會將 a、b 提升為 int 類型,所以將 int 類型賦值給 byte 就會編譯出錯)

    short s1= 1; s1 = s1 + 1; 該段代碼是否有錯,有的話怎么改?

    有錯誤,short類型在進行運算時會自動提升為int類型,也就是說s1+1的運算結果是int類型。

    short s1= 1; s1 += 1; 該段代碼是否有錯,有的話怎么改?

    +=操作符會自動對右邊的表達式結果強轉匹配左邊的數據類型,所以沒錯。

    & 和 &&的區別

    首先記住&是位操作,而&&是邏輯運算符。另外需要記住邏輯運算符具有短路特性,而&不具備短路特性。

    public?class?Test{static?String name;public?static?void?main(String[] args){if(name!=null&userName.equals("")){System.out.println("ok");}else{System.out.println("erro");}} }

    ?

    以上代碼將會拋出空指針異常。

    一個java文件內部可以有類?(非內部類)

    能有一個public公共類,但是可以有多個default修飾的類。

    ?

    ?

    如何正確的退出多層嵌套循環?

    使用標號和break;

    通過在外層循環中添加標識符

    ?

    ?

    ?

    內部類的作用

    內部類可以有多個實例,每個實例都有自己的狀態信息,并且與其他外圍對象的信息相互獨立.在單個外圍類當中,可以讓多個內部類以不同的方式實現同一接口,或者繼承同一個類.創建內部類對象的時刻不依賴于外部類對象的創建。內部類并沒有令人疑惑的”is-a”管系,它就像是一個獨立的實體。

    內部類提供了更好的封裝,除了該外圍類,其他類都不能訪問。

    final, finalize和finally的不同之處

    final 是一個修飾符,可以修飾變量、方法和類。如果 final 修飾變量,意味著該變量的值在初始化后不能被改變。finalize 方法是在對象被回收之前調用的方法,給對象自己最后一個復活的機會,但是什么時候調用 finalize 沒有保證。finally 是一個關鍵字,與 try 和 catch 一起用于異常的處理。finally 塊一定會被執行,無論在 try 塊中是否有發生異常。

    clone()是哪個類的方法?

    java.lang.Cloneable 是一個標示性接口,不包含任何方法,clone 方法在 object 類中定義。并且需要知道 clone() 方法是一個本地方法,這意味著它是由 c 或 c++ 或 其他本地語言實現的。

    深拷貝和淺拷貝的區別是什么?

    淺拷貝:被復制對象的所有變量都含有與原來的對象相同的值,而所有的對其他對象的引用仍然指向原來的對象。換言之,淺拷貝僅僅復制所考慮的對象,而不復制它所引用的對象。

    深拷貝:被復制對象的所有變量都含有與原來的對象相同的值,而那些引用其他對象的變量將指向被復制過的新對象,而不再是原有的那些被引用的對象。換言之,深拷貝把要復制的對象所引用的對象都復制了一遍。

    static都有哪些用法?

    幾乎所有的人都知道static關鍵字這兩個基本的用法:靜態變量和靜態方法。也就是被static所修飾的變量/方法都屬于類的靜態資源,類實例所共享。

    除了靜態變量和靜態方法之外,static也用于靜態塊,多用于初始化操作

    public?calss PreCache{static{//執行相關操作} }

    ?

    此外static也多用于修飾內部類,此時稱之為靜態內部類。

    最后一種用法就是靜態導包,即import static.import static是在JDK 1.5之后引入的新特性,可以用來指定導入某個類中的靜態資源,并且不需要使用類名。資源名,可以直接使用資源名,比如:

    import?static?java.lang.Math.*;public?class?Test{public?static?void?main(String[] args){//System.out.println(Math.sin(20));傳統做法System.out.println(sin(20));} }

    ?

    final有哪些用法

    final也是很多面試喜歡問的地方,能回答下以下三點就不錯了:
    1.被final修飾的類不可以被繼承?
    2.被final修飾的方法不可以被重寫?
    3.被final修飾的變量不可以被改變。如果修飾引用,那么表示引用不可變,引用指向的內容可變。
    4.被final修飾的方法,JVM會嘗試將其內聯,以提高運行效率?
    5.被final修飾的常量,在編譯階段會存入常量池中。

    回答出編譯器對final域要遵守的兩個重排序規則更好:
    1.在構造函數內對一個final域的寫入,與隨后把這個被構造對象的引用賦值給一個引用變量,這兩個操作之間不能重排序。
    2.初次讀一個包含final域的對象的引用,與隨后初次讀這個final域,這兩個操作之間不能重排序。

    數據類型相關

    java中int char,long各占多少字節?

    類型位數字節數
    short216
    int432
    long8

    64

    char216
    float432
    double864
    ???


    64位的JVM當中,int的長度是多少?

    Java 中,int 類型變量的長度是一個固定值,與平臺無關,都是 32 位。意思就是說,在 32 位 和 64 位 的Java 虛擬機中,int 類型的長度是相同的。

    int和Integer的區別

    Integer是int的包裝類型,在拆箱和裝箱中,二者自動轉換。int是基本類型,直接存數值,而integer是對象,用一個引用指向這個對象。

    int 和Integer誰占用的內存更多?

    Integer 對象會占用更多的內存。Integer是一個對象,需要存儲對象的元數據。但是 int 是一個原始類型的數據,所以占用的空間更少

    String, StringBuffer和StringBuilder區別

    String是字符串常量,final修飾:StringBuffer字符串變量(線程安全);
    StringBuilder 字符串變量(線程不安全)。

    String和StringBuffer

    String和StringBuffer主要區別是性能:String是不可變對象,每次對String類型進行操作都等同于產生了一個新的String對象,然后指向新的String對象。所以盡量不在對String進行大量的拼接操作,否則會產生很多臨時對象,導致GC開始工作,影響系統性能。

    StringBuffer是對對象本身操作,而不是產生新的對象,因此在有大量拼接的情況下,我們建議使用StringBuffer。

    但是需要注意現在JVM會對String拼接做一定的優化:
    String s=“This is only ”+”simple”+”test”會被虛擬機直接優化成String s=“This is only simple test”,此時就不存在拼接過程

    StringBuffer和StringBuilder

    StringBuffer是線程安全的可變字符串,其內部實現是可變數組。StringBuilder是jdk 1.5新增的,其功能和StringBuffer類似,但是非線程安全。因此,在沒有多線程問題的前提下,使用StringBuilder會取得更好的性能。

    什么是編譯器常量?使用它有什么風險?

    公共靜態不可變(public static final )變量也就是我們所說的編譯期常量,這里的 public 可選的。實際上這些變量在編譯時會被替換掉,因為編譯器知道這些變量的值,并且知道這些變量在運行時不能改變。這種方式存在的一個問題是你使用了一個內部的或第三方庫中的公有編譯時常量,但是這個值后面被其他人改變了,但是你的客戶端仍然在使用老的值,甚至你已經部署了一個新的jar。為了避免這種情況,當你在更新依賴 JAR 文件時,確保重新編譯你的程序

    java當中使用什么類型表示價格比較好?

    如果不是特別關心內存和性能的話,使用BigDecimal,否則使用預定義精度的 double 類型。

    如何將byte轉為String

    可以使用 String 接收 byte[] 參數的構造器來進行轉換,需要注意的點是要使用的正確的編碼,否則會使用平臺默認編碼,這個編碼可能跟原來的編碼相同,也可能不同。

    可以將int強轉為byte類型么?會產生什么問題?

    我們可以做強制轉換,但是Java中int是32位的而byte是8 位的,所以,如果強制轉化int類型的高24位將會被丟棄,byte 類型的范圍是從-128到128

    關于垃圾回收

    你知道哪些垃圾回收算法?

    垃圾回收從理論上非常容易理解,具體的方法有以下幾種:?
    1. 標記-清除?
    2. 標記-復制?
    3. 標記-整理?
    4. 分代回收
    ?
    更詳細的內容參見深入理解垃圾回收算法:點擊打開鏈接

    如何判斷一個對象是否應該被回收

    這就是所謂的對象存活性判斷,常用的方法有兩種:1.引用計數法; 2.對象可達性分析。由于引用計數法存在互相引用導致無法進行GC的問題,所以目前JVM虛擬機多使用對象可達性分析算法。

    簡單的解釋一下垃圾回收

    Java 垃圾回收機制最基本的做法是分代回收。內存中的區域被劃分成不同的世代,對象根據其存活的時間被保存在對應世代的區域中。一般的實現是劃分成3個世代:年輕、年老和永久(新生,老年,持久)。內存的分配是發生在年輕世代中的。當一個對象存活時間足夠長的時候,它就會被復制到年老世代中。對于不同的世代可以使用不同的垃圾回收算法。進行世代劃分的出發點是對應用中對象存活時間進行研究之后得出的統計規律。一般來說,一個應用中的大部分對象的存活時間都很短。比如局部變量的存活時間就只在方法的執行過程中。基于這一點,對于年輕世代的垃圾回收算法就可以很有針對性。

    調用System.gc()會發生什么?

    通知GC開始工作,但是GC真正開始的時間不確定。


    進程,線程相關

    說說進程,線程,協程之間的區別

    簡而言之,進程是程序運行和資源分配的基本單位,一個程序至少有一個進程,一個進程至少有一個線程。進程在執行過程中擁有獨立的內存單元,而多個線程共享內存資源減少切換次數從而效率更高。線程是進程的一個實體,是cpu調度和分派的基本單位,是比程序更小的能獨立運行的基本單位。同一進程中的多個線程之間可以并發執行。

    你了解守護線程嗎?它和非守護線程有什么區別

    程序運行完畢,jvm會等待非守護線程完成后關閉,但是jvm不會等待守護線程。守護線程最典型的例子就是GC線程。

    什么是多線程上下文切換

    多線程的上下文切換是指CPU控制權一個已經正在運行的線程切換到另外一個就緒并等待獲取CPU執行權的線程的過程。

    創建兩種線程的方式?他們有什么區別?

    通過實現java.lang.Runnable或者通過擴展java.lang.Thread類。相比擴展Thread,實現Runnable接口可能更優.原因有二:

  • Java不支持多繼承。因此擴展Thread類就代表這個子類不能擴展其他類。而實現Runnable接口的類還可能擴展另一個類。

  • 類可能只要求可執行即可,因此繼承整個Thread類的開銷過大

  • Thread類中的start()和run()方法有什么區別?

    start()方法被用來啟動新創建的線程,而且start()內部調用了run()方法,這和直接調用run()方法的效果不一樣。當你調用run()方法的時候,只會是在原來的線程中調用,沒有新的線程啟動,start()方法才會啟動新線程。

    怎么檢測一個線程是否持有對象監視器

    Thread類提供了一個holdsLock(Object obj)方法,當且僅當對象obj的監視器被某條線程持有的時候才會返回true,注意這是一個static方法,這意味著”某條線程”指的是當前線程。

    Runnable和Callable的區別

    Runnable接口中的run()方法的返回值是void,它做的事情只是純粹地去執行run()方法中的代碼而已;Callable接口中的call()方法是有返回值的,是一個泛型,和Future、FutureTask配合可以用來獲取異步執行的結果。?
    這其實是很有用的一個特性,因為多線程相比單線程更難、更復雜的一個重要原因就是因為多線程充滿著未知性,某條線程是否執行了?某條線程執行了多久?某條線程執行的時候我們期望的數據是否已經賦值完畢?無法得知,我們能做的只是等待這條多線程的任務執行完畢而已。而Callable+Future/FutureTask卻可以方便獲取多線程運行的結果可以在等待時間太長沒獲取到需要的數據的情況下取消該線程的任務。

    什么導致線程阻塞

    阻塞指的是暫停一個線程的執行以等待某個條件發生如某資源就緒),學過操作系統的同學對它一定已經很熟悉了。Java 提供了大量方法來支持阻塞,下面讓我們逐一分析。

    方法說明
    sleep()sleep() 允許 指定以毫秒為單位的一段時間作為參數,它使得線程在指定的時間內進入阻塞狀態,不能得到CPU 時間,指定的時間一過,線程重新進入可執行狀態。 典型地,sleep() 被用在等待某個資源就緒的情形:測試發現條件不滿足后,讓線程阻塞一段時間后重新測試,直到條件滿足為止
    suspend() 和 resume()兩個方法配套使用,suspend()使得線程進入阻塞狀態,并且不會自動恢復,必須其對應的resume() 被調用,才能使得線程重新進入可執行狀態。典型地,suspend() 和 resume() 被用在等待另一個線程產生的結果的情形:測試發現結果還沒有產生后,讓線程阻塞,另一個線程產生了結果后,調用 resume() 使其恢復
    yield()yield() 使當前線程放棄當前已經分得的CPU 時間,但不使當前線程阻塞,即線程仍處于可執行狀態,隨時可能再次分得 CPU 時間。調用 yield() 的效果等價于調度程序認為該線程已執行了足夠的時間從而轉到另一個線程
    wait() 和 notify()兩個方法配套使用,wait() 使得線程進入阻塞狀態,它有兩種形式一種允許 指定以毫秒為單位的一段時間作為參數,另一種沒有參數,前者當對應的 notify() 被調用或者超出指定時間時線程重新進入可執行狀態,后者則必須對應的 notify() 被調用


    wait(),notify()和suspend(),resume()之間的區別

    (參考博文:點擊打開鏈接)

    初看起來它們與 suspend() 和 resume() 方法對沒有什么分別,但是事實上它們是截然不同的。區別的核心在于,前面敘述的所有方法,阻塞時都不會釋放占用的鎖(如果占用了的話),而這一對方法則相反。上述的核心區別導致了一系列的細節上的區別。

    首先,前面敘述的所有方法都隸屬于 Thread 類,但是這一對卻直接隸屬于 Object 類,也就是說,所有對象都擁有這一對方法。初看起來這十分不可思議,但是實際上卻是很自然的,因為這一對方法阻塞時要釋放占用的鎖,而鎖是任何對象都具有的,調用任意對象的 wait() 方法導致線程阻塞,并且該對象上的鎖被釋放。而調用 任意對象的notify()方法則導致從調用該對象的 wait() 方法而阻塞的線程中隨機選擇的一個解除阻塞(但要等到獲得鎖后才真正可執行)。

    其次,前面敘述的所有方法都可在任何位置調用,但是這一對方法卻必須在 synchronized 方法或塊中調用,理由也很簡單,只有在synchronized 方法或塊中當前線程才占有鎖,才有鎖可以釋放。同樣的道理,調用這一對方法的對象上的鎖必須為當前線程所擁有,這樣才有鎖可以釋放。因此,這一對方法調用必須放置在這樣的 synchronized 方法或塊中,該方法或塊的上鎖對象就是調用這一對方法的對象。若不滿足這一條件,則程序雖然仍能編譯,但在運行時會出現IllegalMonitorStateException 異常。

    wait() 和 notify() 方法的上述特性決定了它們經常和synchronized關鍵字一起使用,將它們和操作系統進程間通信機制作一個比較就會發現它們的相似性:synchronized方法或塊提供了類似于操作系統原語的功能,它們的執行不會受到多線程機制的干擾,而這一對方法則相當于 block 和wakeup 原語(這一對方法均聲明為 synchronized)。它們的結合使得我們可以實現操作系統上一系列精妙的進程間通信的算法(如信號量算法),并用于解決各種復雜的線程間通信問題。

    關于 wait() 和 notify() 方法最后再說明兩點:?
    第一:調用 notify() 方法導致解除阻塞的線程是從因調用該對象的 wait() 方法而阻塞的線程中隨機選取的,我們無法預料哪一個線程將會被選擇,所以編程時要特別小心,避免因這種不確定性而產生問題。

    第二:除了 notify(),還有一個方法 notifyAll() 也可起到類似作用,唯一的區別在于,調用 notifyAll() 方法將把因調用該對象的 wait() 方法而阻塞的所有線程一次性全部解除阻塞。當然,只有獲得鎖的那一個線程才能進入可執行狀態。

    談到阻塞,就不能不談一談死鎖,略一分析就能發現,suspend() 方法和不指定超時期限的 wait() 方法的調用都可能產生死鎖。遺憾的是,Java 并不在語言級別上支持死鎖的避免,我們在編程中必須小心地避免死鎖。

    以上我們對 Java 中實現線程阻塞的各種方法作了一番分析,我們重點分析了 wait() 和 notify() 方法,因為它們的功能最強大,使用也最靈活,但是這也導致了它們的效率較低,較容易出錯。實際使用中我們應該靈活使用各種方法,以便更好地達到我們的目的。

    產生死鎖的條件(互請不循環)

    1.互斥條件:一個資源每次只能被一個進程使用。?
    2.請求與保持條件:一個進程因請求資源而阻塞時,對已獲得的資源保持不放。?
    3.不剝奪條件:進程已獲得的資源,在未使用完之前,不能強行剝奪。?
    4.循環等待條件:若干進程之間形成一種頭尾相接的循環等待資源關系。

    為什么wait()方法和notify()/notifyAll()方法要在同步塊中被調用

    這是JDK強制的,wait()方法和notify()/notifyAll()方法在調用前都必須先獲得對象的鎖

    wait()方法和notify()/notifyAll()方法在放棄對象監視器時有什么區別

    wait()方法和notify()/notifyAll()方法在放棄對象監視器的時候的區別在于:wait()方法立即釋放對象監視器,notify()/notifyAll()方法則會等待線程剩余代碼執行完畢才會放棄對象監視器。

    wait()與sleep()的區別

    關于這兩者已經在上面進行詳細的說明,這里就做個概括好了:

    • sleep()來自Thread類,和wait()來自Object類。調用sleep()方法的過程中,線程不會釋放對象鎖。而 調用 wait 方法線程會釋放對象鎖

    • sleep()睡眠后不出讓系統資源,wait讓其他線程可以占用CPU

    • sleep(milliseconds)需要指定一個睡眠時間,時間一到會自動喚醒.而wait()可需要配合notify()或者notifyAll()使用

      ?

      ?

    為什么wait, nofity和nofityAll這些方法不放在Thread類當中

    一個很明顯的原因是JAVA提供的鎖是對象級的而不是線程級的,每個對象都有鎖,通過線程獲得。如果線程需要等待某些鎖那么調用對象中的wait()方法就有意義了。如果wait()方法定義在Thread類中,線程正在等待的是哪個鎖就不明顯了。簡單的說,由于wait,notify和notifyAll都是鎖級別的操作,所以把他們定義在Object類中因為鎖屬于對象。

    怎么喚醒一個阻塞的線程

    如果線程是因為調用了wait()、sleep()或者join()方法而導致的阻塞,可以中斷線程,并且通過拋出InterruptedException來喚醒它;如果線程遇到了IO阻塞,無能為力,因為IO是操作系統實現的,Java代碼并沒有辦法直接接觸到操作系統。

    什么是多線程的上下文切換

    多線程的上下文切換是指CPU控制權由一個已經正在運行的線程切換到另外一個就緒并等待獲取CPU執行權的線程的過程。

    synchronized和ReentrantLock的區別

    https://blog.csdn.net/qq838642798/article/details/65441415

    synchronized是和if、else、for、while一樣的關鍵字,ReentrantLock是類,這是二者的本質區別。既然ReentrantLock是類,那么它就提供了比synchronized更多更靈活的特性,可以被繼承、可以有方法、可以有各種各樣的類變量,ReentrantLock比synchronized的擴展性體現在幾點上:?
    (1)ReentrantLock可以對獲取鎖的等待時間進行設置,這樣就避免了死鎖?
    (2)ReentrantLock可以獲取各種鎖的信息?
    (3)ReentrantLock可以靈活地實現多路通知?
    另外,二者的鎖機制其實也是不一樣的:ReentrantLock底層調用的是Unsafe的park方法加鎖,synchronized操作的應該是對象頭中mark word。

    FutureTask是什么

    這個其實前面有提到過,FutureTask表示一個異步運算的任務。FutureTask里面可以傳入一個Callable的具體實現類,可以對這個異步運算的任務的結果進行等待獲取、判斷是否已經完成、取消任務等操作。當然,由于FutureTask也是Runnable接口的實現類,所以FutureTask也可以放入線程池中。

    一個線程如果出現了運行時異常怎么辦?

    如果這個異常沒有被捕獲的話,這個線程就停止執行了。另外重要的一點是:如果這個線程持有某個某個對象的監視器,那么這個對象監視器會被立即釋放。

    Java當中有哪幾種鎖

  • 自旋鎖: 自旋鎖在JDK1.6之后就默認開啟了。基于之前的觀察,共享數據的鎖定狀態只會持續很短的時間,為了這一小段時間而去掛起和恢復線程有點浪費,所以這里就做了一個處理,讓后面請求鎖的那個線程在稍等一會,但是不放棄處理器的執行時間,看看持有鎖的線程能否快速釋放。為了讓線程等待,所以需要讓線程執行一個忙循環也就是自旋操作。在jdk6之后,引入了自適應的自旋鎖,也就是等待的時間不再固定了,而是由上一次在同一個鎖上的自旋時間及鎖的擁有者狀態來決定。

  • 偏向鎖: 在JDK1.之后引入的一項鎖優化,目的是消除數據在無競爭情況下的同步原語。進一步提升程序的運行性能。 偏向鎖就是偏心的偏,意思是這個鎖會偏向第一個獲得他的線程,如果接下來的執行過程中,改鎖沒有被其他線程獲取,則持有偏向鎖的線程將永遠不需要再進行同步。偏向鎖可以提高帶有同步但無競爭的程序性能,也就是說他并不一定總是對程序運行有利,如果程序中大多數的鎖都是被多個不同的線程訪問,那偏向模式就是多余的,在具體問題具體分析的前提下,可以考慮是否使用偏向鎖。

  • 輕量級鎖: 為了減少獲得鎖和釋放鎖所帶來的性能消耗,引入了“偏向鎖”和“輕量級鎖”,所以在Java SE1.6里鎖一共有四種狀態,無鎖狀態,偏向鎖狀態,輕量級鎖狀態和重量級鎖狀態,它會隨著競爭情況逐漸升級。鎖可以升級但不能降級,意味著偏向鎖升級成輕量級鎖后不能降級成偏向鎖。

  • 如何在兩個線程間共享數據

    通過在線程之間共享對象就可以了,然后通過wait/notify/notifyAll、await/signal/signalAll進行喚起和等待,比方說阻塞隊列BlockingQueue就是為線程之間共享數據而設計的。

    如何正確的使用wait()?使用if還是while?

    wait() 方法應該在循環調用,因為當線程獲取到 CPU 開始執行的時候,其他條件可能還沒有滿足,所以在處理前,循環檢測條件是否滿足會更好。下面是一段標準的使用 wait 和 notify 方法的代碼:

    synchronized?(obj) {while?(condition does not hold)obj.wait();?// (Releases lock, and reacquires on wakeup)...?// Perform action appropriate to condition }

    ?

    什么是線程局部變量ThreadLocal

    線程局部變量是局限于線程內部的變量,屬于線程自身所有,不在多個線程間共享。Java提供ThreadLocal類來支持線程局部變量,是一種實現線程安全的方式。但是在管理環境下(如 web 服務器)使用線程局部變量的時候要特別小心,在這種情況下,工作線程的生命周期比任何應用變量的生命周期都要長。任何線程局部變量一旦在工作完成后沒有釋放,Java 應用就存在內存泄露的風險。

    ThreadLoal的作用是什么?

    簡單說ThreadLocal就是一種以空間換時間的做法在每個Thread里面維護了一個ThreadLocal.ThreadLocalMap把數據進行隔離,數據不共享,自然就沒有線程安全方面的問題了。

    生產者消費者模型的作用是什么?

    (1)通過平衡生產者的生產能力和消費者的消費能力來提升整個系統的運行效率,這是生產者消費者模型最重要的作用。
    (2)解耦,這是生產者消費者模型附帶的作用,解耦意味著生產者和消費者之間的聯系少,聯系越少越可以獨自發展而不需要收到相互的制約。

    寫一個生產者-消費者隊列

    可以通過阻塞隊列實現,也可以通過wait-notify來實現。

    使用阻塞隊列來實現

    //消費者 public?class?Producer?implements?Runnable{private?final BlockingQueue<Integer>?queue;public?Producer(BlockingQueue q){this.queue=q;}@Overridepublic?void?run()?{try?{while?(true){Thread.sleep(1000);//模擬耗時queue.put(produce());}}catch?(InterruptedException e){}}private?int?produce()?{int?n=new?Random().nextInt(10000);System.out.println("Thread:"?+ Thread.currentThread().getId() +?" produce:"?+ n);return?n;} } //消費者 public?class?Consumer?implements?Runnable?{private?final BlockingQueue<Integer>?queue;public?Consumer(BlockingQueue q){this.queue=q;}@Overridepublic?void?run()?{while?(true){try?{Thread.sleep(2000);//模擬耗時consume(queue.take());}catch?(InterruptedException e){}}}private?void?consume(Integer n)?{System.out.println("Thread:"?+ Thread.currentThread().getId() +?" consume:"?+ n);} } //測試 public?class?Main?{public?static?void?main(String[] args)?{BlockingQueue<Integer>?queue=new?ArrayBlockingQueue<Integer>(100);Producer p=new?Producer(queue);Consumer c1=new?Consumer(queue);Consumer c2=new?Consumer(queue);new?Thread(p).start();new?Thread(c1).start();new?Thread(c2).start();} }

    ?

    使用wait-notify來實現

    該種方式應該最經典,這里就不做說明了。

    如果你提交任務時,線程池隊列已滿,這時會發生什么

    如果你使用的LinkedBlockingQueue,也就是無界隊列的話,沒關系,繼續添加任務到阻塞隊列中等待執行,因為LinkedBlockingQueue可以近乎認為是一個無窮大的隊列,可以無限存放任務;如果你使用的是有界隊列比方說ArrayBlockingQueue的話,任務首先會被添加到ArrayBlockingQueue中,ArrayBlockingQueue滿了,則會使用拒絕策略RejectedExecutionHandler處理滿了的任務,默認是AbortPolicy。

    為什么要使用線程池

    避免頻繁地創建和銷毀線程,達到線程對象的重用。另外,使用線程池還可以根據項目靈活地控制并發的數目。

    java中用到的線程調度算法是什么

    搶占式。一個線程用完CPU之后,操作系統會根據線程優先級、線程饑餓情況等數據算出一個總的優先級并分配下一個時間片給某個線程執行。

    Thread.sleep(0)的作用是什么

    由于Java采用搶占式的線程調度算法,因此可能會出現某條線程常常獲取到CPU控制權的情況,為了讓某些優先級比較低的線程也能獲取到CPU控制權,可以使用Thread.sleep(0)手動觸發一次操作系統分配時間片的操作,這也是平衡CPU控制權的一種操作。

    什么是CAS

    CAS,全稱為Compare and Swap,即比較-替換。假設有三個操作數:內存值V、舊的預期值A、要修改的值B,當且僅當預期值A和內存值V相同時,才會將內存值修改為B并返回true,否則什么都不做并返回false。當然CAS一定要volatile變量配合,這樣才能保證每次拿到的變量是主內存中最新的那個值,否則舊的預期值A對某條線程來說,永遠是一個不會變的值A,只要某次CAS操作失敗,永遠都不可能成功。

    什么是樂觀鎖和悲觀鎖

    樂觀鎖:樂觀鎖認為競爭不總是會發生,因此它不需要持有鎖,將比較-替換這兩個動作作為一個原子操作嘗試去修改內存中的變量,如果失敗則表示發生沖突,那么就應該有相應的重試邏輯。

    悲觀鎖:悲觀鎖認為競爭總是會發生,因此每次對某資源進行操作時,都會持有一個獨占的鎖,就像synchronized,不管三七二十一,直接上了鎖就操作資源了。

    ConcurrentHashMap的并發度是什么?

    ConcurrentHashMap的并發度就是segment的大小,默認為16,這意味著最多同時可以有16條線程操作ConcurrentHashMap,這也是ConcurrentHashMap對Hashtable的最大優勢,任何情況下,Hashtable能同時有兩條線程獲取Hashtable中的數據嗎?

    ConcurrentHashMap的工作原理

    ConcurrentHashMap在jdk 1.6和jdk 1.8實現原理是不同的。

    jdk 1.6:

    ConcurrentHashMap是線程安全的,但是與Hashtablea相比,實現線程安全的方式不同。Hashtable是通過對hash表結構進行鎖定,是阻塞式的,當一個線程占有這個鎖時,其他線程必須阻塞等待其釋放鎖。ConcurrentHashMap是采用分離鎖的方式,它并沒有對整個hash表進行鎖定,而是局部鎖定,也就是說當一個線程占有這個局部鎖時,不影響其他線程對hash表其他地方的訪問。?
    具體實現:ConcurrentHashMap內部有一個Segment.

    jdk 1.8

    在jdk 8中,ConcurrentHashMap不再使用Segment分離鎖,而是采用一種樂觀鎖CAS算法來實現同步問題,但其底層還是“數組+鏈表->紅黑樹”的實現。

    CyclicBarrier和CountDownLatch區別

    這兩個類非常類似,都在java.util.concurrent下,都可以用來表示代碼運行到某個點上,二者的區別在于:

    • CyclicBarrier的某個線程運行到某個點上之后,該線程即停止運行,直到所有的線程都到達了這個點,所有線程才重新運行;CountDownLatch則不是,某線程運行到某個點上之后,只是給某個數值-1而已,該線程繼續運行。

    • CyclicBarrier只能喚起一個任務,CountDownLatch可以喚起多個任務

    • CyclicBarrier可重用,CountDownLatch不可重用,計數值為0該CountDownLatch就不可再用了。

    java中的++操作符線程安全么?

    不是線程安全的操作。它涉及到多個指令,如讀取變量值,增加,然后存儲回內存,這個過程可能會出現多個線程交差。

    你有哪些多線程開發良好的實踐?

  • 給線程命名

  • 最小化同步范圍

  • 優先使用volatile

  • 盡可能使用更高層次的并發工具而非wait和notify()來實現線程通信,如BlockingQueue,Semeaphore

  • 優先使用并發容器而非同步容器.

  • 考慮使用線程池


  • 關于volatile關鍵字

    可以創建Volatile數組嗎?

    Java 中可以創建 volatile類型數組,不過只是一個指向數組的引用,而不是整個數組。如果改變引用指向的數組,將會受到volatile 的保護,但是如果多個線程同時改變數組的元素,volatile標示符就不能起到之前的保護作用了。

    volatile能使得一個非原子操作變成原子操作嗎?

    一個典型的例子是在類中有一個 long 類型的成員變量。如果你知道該成員變量會被多個線程訪問,如計數器、價格等,你最好是將其設置為 volatile。為什么?因為 Java 中讀取 long 類型變量不是原子的,需要分成兩步,如果一個線程正在修改該 long 變量的值,另一個線程可能只能看到該值的一半(前 32 位)。但是對一個 volatile 型的 long 或 double 變量的讀寫是原子。

    一種實踐是用 volatile 修飾 long 和 double 變量,使其能按原子類型來讀寫。double 和 long 都是64位寬,因此對這兩種類型的讀是分為兩部分的,第一次讀取第一個 32 位,然后再讀剩下的 32 位,這個過程不是原子的,但 Java 中 volatile 型的 long 或 double 變量的讀寫是原子的。volatile 修復符的另一個作用是提供內存屏障(memory barrier),例如在分布式框架中的應用。簡單的說,就是當你寫一個 volatile 變量之前,Java 內存模型會插入一個寫屏障(write barrier)讀一個 volatile 變量之前,會插入一個讀屏障(read barrier)。意思就是說,在你寫一個 volatile 域時,能保證任何線程都能看到你寫的值,同時,在寫之前,也能保證任何數值的更新對所有線程是可見的,因為內存屏障會將其他所有寫的值更新到緩存。

    volatile類型變量提供什么保證?

    volatile 主要有兩方面的作用:1.避免指令重排2.可見性保證.例如,JVM 或者 JIT為了獲得更好的性能會對語句重排序,但是 volatile 類型變量即使在沒有同步塊的情況下賦值也不會與其他語句重排序。 volatile 提供 happens-before 的保證,確保一個線程的修改能對其他線程是可見的。某些情況下,volatile 還能提供原子性,如讀 64 位數據類型,像 long 和 double 都不是原子的(低32位和高32位),但 volatile 類型的 double 和 long 就是原子的。


    關于集合

    Java中的集合及其繼承關系

    關于集合的體系是每個人都應該爛熟于心的,尤其是對我們經常使用的List,Map的原理更該如此.這里我們看這張圖即可:?

    更多內容可見集合類總結:

    http://write.blog.csdn.net/postedit/40826423

    poll()方法和remove()方法區別?

    poll() 和 remove() 都是從隊列中取出一個元素,但是 poll() 在獲取元素失敗的時候會返回空,但是 remove() 失敗的時候會拋出異常。

    LinkedHashMap和PriorityQueue的區別

    PriorityQueue 是一個優先級隊列,保證最高或者最低優先級的的元素總是在隊列頭部,但是 LinkedHashMap 維持的順序是元素插入的順序。當遍歷一個 PriorityQueue 時,沒有任何順序保證,但是 LinkedHashMap 課保證遍歷順序是元素插入的順序。

    WeakHashMap與HashMap的區別是什么?

    WeakHashMap 的工作與正常的 HashMap 類似,但是使用弱引用作為 key,意思就是當 key 對象沒有任何引用時,key/value 將會被回收。

    ArrayList和LinkedList的區別?

    最明顯的區別是 ArrrayList底層的數據結構是數組,支持隨機訪問,而 LinkedList 的底層數據結構是雙向循環鏈表,不支持隨機訪問。使用下標訪問一個元素,ArrayList 的時間復雜度是 O(1),而 LinkedList 是 O(n)。

    ArrayList和Array有什么區別?

  • Array可以容納基本類型和對象,而ArrayList只能容納對象。

  • Array是指定大小的,而ArrayList大小是固定的

  • ArrayList和HashMap默認大小?

    在 Java 7 中,ArrayList 的默認大小是 10 個元素,HashMap 的默認大小是16個元素(必須是2的冪)。這就是 Java 7 中 ArrayList 和 HashMap 類的代碼片段。

    private?static?final?int?DEFAULT_CAPACITY =?10;//from HashMap.java JDK 7 static?final?int?DEFAULT_INITIAL_CAPACITY =?1?<<?4;?// aka 16

    ?

    Comparator和Comparable的區別?

    Comparable 接口用于定義對象的自然順序,而 comparator 通常用于定義用戶定制的順序。Comparable 總是只有一個,但是可以有多個 comparator 來定義對象的順序。

    如何實現集合排序?

    你可以使用有序集合,如 TreeSet 或 TreeMap,你也可以使用有順序的的集合,如 list,然后通過 Collections.sort() 來排序。

    如何打印數組內容

    你可以使用 Arrays.toString() 和 Arrays.deepToString() 方法來打印數組。由于數組沒有實現 toString() 方法,所以如果將數組傳遞給 System.out.println() 方法,將無法打印出數組的內容,但是 Arrays.toString() 可以打印每個元素。

    LinkedList的是單向鏈表還是雙向?

    雙向循環列表,具體實現自行查閱源碼。

    TreeMap是實現原理

    采用紅黑樹實現,具體實現自行查閱源碼。

    遍歷ArrayList時如何正確移除一個元素

    該問題的關鍵在于面試者使用的是 ArrayList 的 remove() 還是 Iterator 的 remove()方法。這有一段示例代碼,是使用正確的方式來實現在遍歷的過程中移除元素,而不會出現 ConcurrentModificationException 異常的示例代碼。

    什么是ArrayMap?它和HashMap有什么區別?

    ArrayMap是Android SDK中提供的,非Android開發者可以略過。
    ArrayMap是用兩個數組來模擬map,更少的內存占用空間,更高的效率。
    具體參考這篇文章:ArrayMap VS HashMap:http://lvable.com/?p=217%5D

    HashMap的實現原理

    1. HashMap概述: HashMap是基于哈希表的Map接口的非同步實現。此實現提供所有可選的映射操作,并允許使用null值和null鍵。此類不保證映射的順序,特別是它不保證該順序恒久不變。?
    2. HashMap的數據結構: 在java編程語言中,最基本的結構就是兩種,一個是數組,另外一個是模擬指針(引用),所有的數據結構都可以用這兩個基本結構來構造的,HashMap也不例外。HashMap實際上是一個“鏈表散列”的數據結構,即數組和鏈表的結合體。

    當我們往Hashmap中put元素時,首先根據key的hashcode重新計算hash值,根絕hash值得到這個元素在數組中的位置(下標),如果該數組在該位置上已經存放了其他元素,那么在這個位置上的元素將以鏈表的形式存放,新加入的放在鏈頭,最先加入的放入鏈尾.如果數組中該位置沒有元素,就直接將該元素放到數組的該位置上.

    需要注意Jdk 1.8中對HashMap的實現做了優化,當鏈表中的節點數據超過八個之后,該鏈表會轉為紅黑樹來提高查詢效率,從原來的O(n)到O(logn)

    你了解Fail-Fast機制嗎?

    Fail-Fast即我們常說的快速失敗,

    更多內容參看fail-fast機制:http://blog.csdn.net/chenssy/article/details/38151189

    Fail-fast和Fail-safe有什么區別

    Iterator的fail-fast屬性與當前的集合共同起作用,因此它不會受到集合中任何改動的影響。Java.util包中的所有集合類都被設計為fail->fast的,而java.util.concurrent中的集合類都為fail-safe的。當檢測到正在遍歷的集合的結構被改變時,Fail-fast迭代器拋出ConcurrentModificationException,而fail-safe迭代器從不拋出ConcurrentModificationException。


    關于日期

    SimpleDateFormat是線程安全的嗎?

    非常不幸,DateFormat 的所有實現,包括 SimpleDateFormat 都不是線程安全的,因此你不應該在多線程序中使用,除非是在對外線程安全的環境中使用,如 將 SimpleDateFormat 限制在 ThreadLocal 中。如果你不這么做,在解析或者格式化日期的時候,可能會獲取到一個不正確的結果。因此,從日期、時間處理的所有實踐來說,我強力推薦 joda-time 庫。

    如何格式化日期?

    Java 中,可以使用 SimpleDateFormat 類或者 joda-time 庫來格式日期。DateFormat 類允許你使用多種流行的格式來格式化日期。參見答案中的示例代碼,代碼中演示了將日期格式化成不同的格式,如 dd-MM-yyyy 或 ddMMyyyy。


    關于異常

    簡單描述java異常體系

    相比沒有人不了解異常體系,關于異常體系的更多信息可以見

    白話異常機制:http://blog.csdn.net/dd864140130/article/details/42504189

    什么是異常鏈

    詳情直接參見上面的白話異常機制,不做解釋了。

    throw和throws的區別

    throw用于主動拋出java.lang.Throwable 類的一個實例化對象,意思是說你可以通過關鍵字 throw 拋出一個 Error 或者 一個Exception,如:throw new IllegalArgumentException(“size must be multiple of 2″),?
    而throws 的作用是作為方法聲明和簽名的一部分,方法被拋出相應的異常以便調用者能處理。Java 中,任何未處理的受檢查異常強制在 throws 子句中聲明。


    關于序列化

    Java 中,Serializable 與 Externalizable 的區別

    Serializable 接口是一個序列化 Java 類的接口,以便于它們可以在網絡上傳輸或者可以將它們的狀態保存在磁盤上,是 JVM 內嵌的默認序列化方式,成本高、脆弱而且不安全。Externalizable 允許你控制整個序列化過程,指定特定的二進制格式,增加安全機制。


    關于JVM

    JVM特性

    平臺無關性.?
    Java語言的一個非常重要的特點就是與平臺的無關性。而使用Java虛擬機是實現這一特點的關鍵。一般的高級語言如果要在不同的平臺上運行,至少需要編譯成不同的目標代碼。而引入Java語言虛擬機后,Java語言在不同平臺上運行時不需要重新編譯。Java語言使用模式Java虛擬機屏蔽了與具體平臺相關的信息,使得Java語言編譯程序只需生成在Java虛擬機上運行的目標代碼(字節碼),就可以在多種平臺上不加修改地運行。Java虛擬機在執行字節碼時,把字節碼解釋成具體平臺上的機器指令執行。

    簡單解釋一下類加載器

    有關類加載器一般會問你四種類加載器的應用場景以及雙親委派模型,

    更多的內容參看深入理解JVM加載器:

    http://blog.csdn.net/dd864140130/article/details/49817357

    簡述堆和棧的區別

    VM 中堆和棧屬于不同的內存區域,使用目的也不同。棧常用于保存方法幀和局部變量,而對象總是在堆上分配。棧通常都比堆小,也不會在多個線程之間共享,而堆被整個 JVM 的所有線程共享。

    簡述JVM內存分配

  • 基本數據類型比變量和對象的引用都是在棧分配的。

  • 堆內存用來存放由new創建的對象和數組。

  • 類變量(static修飾的變量),程序在一加載的時候就在堆中為類變量分配內存,堆中的內存地址存放在棧中。

  • 實例變量:當你使用java關鍵字new的時候,系統在堆中開辟并不一定是連續的空間分配給變量,是根據零散的堆內存地址,通過哈希算法換算為一長串數字以表征這個變量在堆中的”物理位置”,實例變量的生命周期–當實例變量的引用丟失后,將被GC(垃圾回收器)列入可回收“名單”中,但并不是馬上就釋放堆中內存。

  • 局部變量: 由聲明在某方法,或某代碼段里(比如for循環),執行到它的時候在棧中開辟內存,當局部變量一但脫離作用域,內存立即釋放。


  • 其他

    java當中采用的是大端還是小端?

    XML解析的幾種方式和特點

    DOM, SAX, PULL三種解析方式:

    • DOM:消耗內存:先把xml文檔都讀到內存中,然后再用DOM API來訪問樹形結構,并獲取數據。這個寫起來很簡單,但是很消耗內存。要是數據過大,手機不夠牛逼,可能手機直接死機

    • SAX:解析效率高,占用內存少,基于事件驅動的:更加簡單地說就是對文檔進行順序掃描,當掃描到文檔(document)開始與結束、元素(element)開始與結束、文檔(document)結束等地方時通知事件處理函數,由事件處理函數做相應動作,然后繼續同樣的掃描,直至文檔結束。

    • PULL:與 SAX 類似,也是基于事件驅動,我們可以調用它的next()方法,來獲取下一個解析事件(就是開始文檔,結束文檔,開始標簽,結束標簽),當處于某個元素時可以調用XmlPullParser的getAttributte()方法來獲取屬性的值,也可調用它的nextText()獲取本節點的值。

    JDK 1.7特性

    然 JDK 1.7 不像 JDK 5 和 8 一樣的大版本,但是,還是有很多新的特性,如 try-with-resource 語句,這樣你在使用流或者資源的時候,就不需要手動關閉,Java 會自動關閉。Fork-Join 池某種程度上實現 Java 版的 Map-reduce。允許 Switch 中有 String 變量和文本。菱形操作符(<>)用于類型推斷,不再需要在變量聲明的右邊申明泛型,因此可以寫出可讀寫更強、更簡潔的代碼。

    JDK 1.8特性

    java 8 在 Java 歷史上是一個開創新的版本,下面 JDK 8 中 5 個主要的特性:?
    Lambda 表達式,允許像對象一樣傳遞匿名函數?
    Stream API,充分利用現代多核 CPU,可以寫出很簡潔的代碼?
    Date 與 Time API,最終,有一個穩定、簡單的日期和時間庫可供你使用?
    擴展方法,現在,接口中可以有靜態、默認方法。?
    重復注解,現在你可以將相同的注解在同一類型上使用多次。

    Maven和ANT有什么區別?

    雖然兩者都是構建工具,都用于創建 Java 應用,但是 Maven 做的事情更多,在基于“約定優于配置”的概念下,提供標準的Java 項目結構,同時能為應用自動管理依賴(應用中所依賴的 JAR 文件。

    JDBC最佳實踐

    • 優先使用批量操作來插入和更新數據

    • 使用PreparedStatement來避免SQL漏洞

    • 使用數據連接池

    • 通過列名來獲取結果集

    IO操作最佳實踐

    • 使用有緩沖的IO類,不要單獨讀取字節或字符

    • 使用NIO和NIO 2或者AIO,而非BIO

    • 在finally中關閉流

    • 使用內存映射文件獲取更快的IO

    來源于:https://blog.csdn.net/dd864140130/article/details/55833087

    ?

    ?

    ?

    ?

    ?

    ?


    ?

    總結

    以上是生活随笔為你收集整理的Java知识点全面汇总的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    97国产超碰 | av电影在线观看 | 日韩欧美在线一区 | 又黄又网站 | 玖玖玖精品| 久久国产精品99久久久久 | 日本精品视频在线播放 | 久久国产成人午夜av影院潦草 | 五月天伊人 | 综合五月 | 天天草综合 | 在线国产一区 | 99精品视频网站 | 国产精品国产三级在线专区 | 91免费高清 | 欧美一级免费 | 成人激情开心网 | 人成在线免费视频 | 在线观看91 | 久久久久久久久久久免费 | 五月丁婷婷 | 成人黄色片在线播放 | 国产精品美女在线 | 99国产情侣在线播放 | 欧美国产大片 | 免费网站在线观看人 | 亚洲国产成人在线观看 | 日韩av中文字幕在线免费观看 | 成人免费网视频 | 精品国产1区2区3区 国产欧美精品在线观看 | 91伊人久久大香线蕉蜜芽人口 | 狠狠干婷婷色 | 一本一本久久a久久精品牛牛影视 | 西西444www | 色a资源在线 | 亚洲精品xxx | 91精品色 | 激情自拍av| 97品白浆高清久久久久久 | 三级av免费观看 | 国产一区二区久久精品 | 色噜噜在线观看视频 | 麻豆精品视频 | 天天天射 | 视频在线观看国产 | 高清不卡毛片 | 天天爱天天射天天干天天 | 欧美成人性战久久 | 探花视频免费观看高清视频 | 男女拍拍免费视频 | 国产成人福利片 | 麻豆91视频| 中文字幕电影高清在线观看 | 丁香在线 | 国产专区欧美专区 | 成年人视频免费在线播放 | 手机av在线免费观看 | 激情视频一区二区三区 | 91香蕉国产 | 玖玖视频网 | 天天干天天天天 | 日韩色爱| 99精品久久久久久久久久综合 | 久久久久综合精品福利啪啪 | 国内精品视频一区二区三区八戒 | 欧美日韩在线视频一区 | 日韩欧美精品一区 | 日本性动态图 | 国产资源在线视频 | 中文字幕亚洲综合久久五月天色无吗'' | 国产 在线 高清 精品 | 亚洲精品一区二区三区新线路 | 亚洲黄色免费观看 | 99国产一区二区三精品乱码 | 成年人免费电影 | 精品国产一区二区三区日日嗨 | 国产精品99久久久久久久久久久久 | 欧美在线18| 国产精品日韩久久久久 | 免费视频一二三区 | 久久线视频 | 久久精品91久久久久久再现 | 久久久精品 | 麻豆一区二区三区视频 | 色在线视频网 | 在线免费观看黄 | 成人免费观看av | av五月婷婷 | 婷婷午夜| 久久久久这里只有精品 | 欧美一级性生活视频 | 国产黄色片一级三级 | 一级黄色在线免费观看 | 色射爱 | 亚洲一二三在线 | 夜夜躁日日躁 | 中文字幕人成乱码在线观看 | 欧美日韩一区二区在线观看 | 又湿又紧又大又爽a视频国产 | 丁香花中文字幕 | 人人cao| 在线免费视频a | 国产精品久久久一区二区三区网站 | www..com毛片| 国产精品ⅴa有声小说 | 国产免费叼嘿网站免费 | 狠狠色免费| 国产成年免费视频 | 精品国产乱码久久久久久天美 | 91av美女| 91在线文字幕 | 欧美午夜a | 免费高清影视 | 91av手机在线 | 国产高清福利在线 | 波多野结衣在线视频一区 | 日日干天天插 | 日韩精品久久久久久久电影99爱 | 国产黄色片免费看 | 久久不卡电影 | 久久久久久久毛片 | 午夜视频二区 | 午夜av免费看 | 亚洲国产精彩中文乱码av | 中文字幕在线观看免费高清电影 | 成人在线视频论坛 | 国产精品99久久久久的智能播放 | 亚洲另类交 | 91人人人 | 久久久久成人精品免费播放动漫 | 成人午夜性影院 | 久久亚洲精品国产亚洲老地址 | 人人爱人人舔 | 在线三级中文 | 91视频在线 | 在线播放日韩 | 亚洲综合黄色 | 91麻豆精品国产自产在线游戏 | 亚洲国产成人高清精品 | 国产特级毛片aaaaaa | av中文字幕网站 | 黄色免费观看视频 | 激情综合网五月婷婷 | 免费网站v | 欧美少妇xxx | 精品视频在线看 | www.日日操.com | 人人澡人人爱 | 在线成人av | 欧美,日韩| 91av电影网| 日韩视频在线观看免费 | 人人爽久久久噜噜噜电影 | www.xxx.性狂虐| 亚洲欧美日本一区二区三区 | 波多野结衣一区二区 | 亚洲国产成人高清精品 | 婷婷伊人网 | 日日干精品 | 国产精品国产三级国产不产一地 | 国产一级视频在线观看 | 免费看毛片在线 | 美女搞黄国产视频网站 | 天天插天天| 亚洲精品tv | 五月婷综合网 | 国产在线观看免费av | 国产九九九精品视频 | av视屏在线播放 | 色婷婷欧美 | 黄色国产大片 | 免费av福利 | 五月天com | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 国产剧情一区二区 | 少妇高潮冒白浆 | 日本中出在线观看 | 国产精品 中文在线 | 欧美爽爽爽| 91大神dom调教在线观看 | 91丨九色丨国产在线观看 | 夜夜操天天干, | 亚洲精品视频二区 | 国产xxxxx在线观看 | 色天堂在线视频 | 尤物九九久久国产精品的分类 | 精品免费一区 | 亚洲日本中文字幕在线观看 | 久久好看免费视频 | 色久综合 | 中文字幕影片免费在线观看 | 日韩精品综合在线 | 91精品国产自产在线观看 | www.99av| 亚洲女同ⅹxx女同tv | 精品国产一区二区在线 | 在线久草视频 | 国产精品区免费视频 | 天天爱天天操天天干 | 久久免费国产 | 午夜精品视频在线 | 国产成人区 | 成人午夜精品福利免费 | 这里有精品在线视频 | 久久综合影视 | 国产精品久久久久久久久大全 | 狠狠操91| 日韩精品一区二区在线视频 | 韩国精品福利一区二区三区 | 国产综合在线观看视频 | 久久小视频 | 麻豆国产在线播放 | 成人av电影在线观看 | 亚洲伦理中文字幕 | 国产日韩精品一区二区三区 | 国产精品视频线看 | 欧美在线视频第一页 | 欧美日韩精品二区第二页 | 免费看毛片在线 | 国产精品粉嫩 | 亚洲永久精品一区 | 欧美一区二区伦理片 | 免费91在线 | 中文在线字幕观看电影 | 四虎影视欧美 | 国产精品久久久久久久久大全 | 狠狠操狠狠插 | 免费在线a| 成人黄色小说网 | 伊人天堂av| 精品国产电影 | 国产99久久久国产精品免费二区 | 91精品国自产在线观看欧美 | 日韩美在线 | 国产一区福利 | 91久久国产自产拍夜夜嗨 | 国产 日韩 在线 亚洲 字幕 中文 | 午夜电影中文字幕 | 久久福利小视频 | 欧美一区二区三区特黄 | 人人爽人人爽人人片 | 日韩中文字幕网站 | 日韩免费三区 | 黄色小说网站在线 | 久久国产女人 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 精品欧美日韩 | 91试看 | 1024手机基地在线观看 | 99久久99久久精品国产片 | 在线观看国产日韩欧美 | 免费观看av网站 | 天天艹天天干天天 | 久久综合爱 | 欧美日韩久| 亚洲狠狠操 | 超碰在线观看av.com | 久久中文字幕视频 | 国产69久久久欧美一级 | 国产色爽 | 亚洲激情五月 | 日本三级香港三级人妇99 | 日韩偷拍精品 | 久久一区精品 | 在线国产一区 | 天天草av | 97国产超碰在线 | 99热这里精品 | 日日干 天天干 | 亚洲a色 | 国产午夜精品一区二区三区在线观看 | 国产一区二区三区久久久 | www.久久99| 日本特黄特色aaa大片免费 | 亚洲做受高潮欧美裸体 | 女人18毛片a级毛片一区二区 | 久久99久久99精品免费看小说 | 久久婷婷开心 | 成人国产在线 | 精品少妇一区二区三区在线 | 久久国产精品影片 | 四虎在线免费观看 | 欧美性色19p| 黄色录像av| 亚洲一二三久久 | 国产精品久久久久久久久软件 | 91av视频在线播放 | 韩国av免费在线 | 欧美一级片免费播放 | 国产黄免费在线观看 | 日日干夜夜操视频 | 久久你懂的 | 欧美日韩首页 | 国产理论片在线观看 | 国产精美视频 | 亚洲综合在线五月天 | 在线观看av小说 | 亚洲国产97在线精品一区 | 西西444www大胆高清视频 | 久久久久久久久久久福利 | 久久国内精品99久久6app | 天天综合网~永久入口 | 国产成人在线一区 | 日韩精品一区二区电影 | 天天综合天天做天天综合 | av丝袜在线 | 亚洲精品资源在线 | 国产中文字幕91 | 99国产精品一区二区 | 一级黄色片在线 | 国产综合精品久久 | 91色视频 | 国产福利专区 | 九九精品毛片 | 免费h精品视频在线播放 | 国产一级二级三级在线观看 | 色狠狠婷婷| 91亚洲精品在线 | 天天玩天天干天天操 | 91av在线免费看 | 亚洲国产精品久久 | 99热这里只有精品免费 | 久久精品站 | 日韩欧美国产视频 | 亚洲一区av| 99热九九这里只有精品10 | 欧美视频99 | 精品国产欧美一区二区三区不卡 | 三级av在线播放 | 国产在线观看,日本 | 天天天天色综合 | 亚洲精品中文字幕在线 | 亚洲黄色三级 | 91麻豆精品国产91久久久无需广告 | 92av视频| 婷婷色网址 | 在线а√天堂中文官网 | 日韩美女免费线视频 | 国产成人一区在线 | 欧美精品在线观看免费 | 97色涩| 日韩精品免费一区二区 | 日韩在线视频网站 | 亚洲精品乱码久久久久久高潮 | 亚洲福利精品 | 日韩精品中文字幕在线 | 国产不卡在线观看 | 亚洲视频综合 | 久久久婷 | 狠狠插狠狠操 | 午夜影院一级片 | 超碰免费观看 | 日韩精品免费在线观看视频 | 91激情小视频 | 在线观看国产永久免费视频 | 一区二区三区四区不卡 | 成年人视频在线免费观看 | 国产一二区在线观看 | 日韩欧美一区二区三区视频 | 国产成人精品综合久久久久99 | 亚洲片在线观看 | 精品久久久成人 | 亚洲精品国产精品乱码在线观看 | 私人av| 人人超碰在线 | 国产精品一区二区av日韩在线 | 中文字幕 在线看 | 中文字幕资源网在线观看 | 18做爰免费视频网站 | 色av色av色av | 国产在线观看高清视频 | 日日夜夜爱 | 国产精品大全 | 日本三级中文字幕在线观看 | 久久久久免费精品 | 精品视频在线视频 | 国产热re99久久6国产精品 | 日韩av电影免费在线观看 | 欧洲精品视频一区 | 国产精品video | 久草在线观看资源 | 亚洲国产人午在线一二区 | 日韩在线视频一区二区三区 | 中文区中文字幕免费看 | 91在线九色| 日韩在线激情 | 黄色美女免费网站 | 黄色精品一区二区 | 国产亚洲永久域名 | 天天操天天综合网 | av电影在线观看 | 色狠狠操 | 免费观看av网站 | 天天躁天天操 | 99视频在线观看一区三区 | 亚洲作爱| 99久久国产免费免费 | 婷婷五月情 | 久久九九网站 | 国产美女视频免费 | 五月激情六月丁香 | 欧美一级激情 | 亚洲精品tv久久久久久久久久 | 粉嫩av一区二区三区四区在线观看 | 免费在线观看国产精品 | 久久一区二区三区超碰国产精品 | 五月婷婷丁香色 | 国产成人av一区二区三区在线观看 | 久久人人爽视频 | 国产成人av电影在线观看 | 亚洲一区日韩 | av专区在线 | 一区二区精品在线观看 | 中文字幕在线看视频 | 激情www | 久久久午夜精品福利内容 | 日韩精品在线看 | 免费成人在线视频网站 | 中文字幕丝袜一区二区 | 日韩二三区| 四虎影视成人 | 中文字幕 在线看 | 狠狠色狠狠色合久久伊人 | 色小说av | 国产资源在线播放 | 久久精品网站免费观看 | 精品久久久久久国产91 | 久久视频中文字幕 | 五月婷婷综合久久 | 亚洲最大成人免费网站 | 欧美精品一区在线发布 | 国产一区二区三区在线免费观看 | 国产精品私人影院 | 成人免费一区二区三区在线观看 | 中文字幕日韩免费视频 | 天天操天天干天天插 | 日韩视频区 | 国产老妇av | 中文字幕在线观看一区 | 免费观看www7722午夜电影 | 久久夜色网 | 天天插天天狠天天透 | 免费看一级特黄a大片 | www.夜夜 | 午夜婷婷在线播放 | 精品一区二区在线免费观看 | 精品免费99久久 | 91黄色免费网站 | 久久精品中文字幕一区二区三区 | 日日夜夜网 | av黄色大片 | 欧洲精品一区二区 | 综合久久久久久 | 97视频在线观看成人 | 精品国产aⅴ一区二区三区 在线直播av | 日本高清免费中文字幕 | 91视频在线观看大全 | 亚洲人人爱| 日本三级在线观看中文字 | 国产在线精品二区 | 欧美a级片网站 | 久草免费色站 | 99精品欧美一区二区三区黑人哦 | 天天av天天 | 欧美乱熟臀69xxxxxx | 人人澡人 | 色视频网站在线观看一=区 a视频免费在线观看 | 久久狠狠婷婷 | 一区二区三区四区五区在线视频 | 久久只精品99品免费久23小说 | 久久av观看 | 99亚洲国产| 国产精品嫩草69影院 | 黄色在线视频网址 | 97精品视频在线播放 | 一区二区三区不卡在线 | 伊人丁香| 狠狠躁夜夜躁人人爽超碰97香蕉 | 亚洲美女视频在线观看 | 日韩高清精品一区二区 | 国产精品 国产精品 | 亚洲亚洲精品在线观看 | 欧美视频www | 丁香婷婷综合网 | 久久99精品热在线观看 | 黄色一二级片 | 精品久久影院 | 又湿又紧又大又爽a视频国产 | 97在线视频免费观看 | 亚洲国产片 | 国产91精品高清一区二区三区 | 99精品黄色片免费大全 | 精品国精品自拍自在线 | 日韩免费在线观看视频 | 成人av电影在线观看 | 九九在线国产视频 | 玖玖视频在线 | 91在线视频网址 | 久久亚洲免费视频 | 九九九免费视频 | 五月激情五月激情 | 亚洲精品成人免费 | 婷婷色吧| 欧美激情视频在线免费观看 | 中文字幕第 | 免费福利在线播放 | 最新国产福利 | 国产精品久久久久久一二三四五 | 国产麻豆视频网站 | 91热精品| 91porny九色91啦中文 | 99久久er热在这里只有精品66 | 国产理论片在线观看 | 狠狠插狠狠操 | 久久伊人八月婷婷综合激情 | 在线免费日韩 | 四虎成人av | 黄网站app在线观看免费视频 | 激情婷婷| 中文字幕视频观看 | 国产无遮挡猛进猛出免费软件 | 999精品 | 婷婷深爱五月 | 亚洲一区二区天堂 | av免费在线免费观看 | 91亚洲狠狠婷婷综合久久久 | 91在线精品视频 | 99久久久久免费精品国产 | 激情欧美一区二区免费视频 | 成人午夜黄色影院 | 精品人妖videos欧美人妖 | 国产精品嫩草影院99网站 | 欧美va天堂在线电影 | 人人超在线公开视频 | 黄色一级性片 | 97视频人人澡人人爽 | 丁香5月婷婷久久 | 99免费在线视频观看 | 99视频在线免费播放 | 日本一区二区三区免费看 | 欧美成人在线免费 | 国产精品二区在线观看 | 欧美a级在线免费观看 | 91av官网| 亚洲国产97在线精品一区 | 中文字幕高清免费日韩视频在线 | 久久久久免费 | 香蕉网在线 | 干av在线 | 国产一区二区在线免费播放 | 人人插人人艹 | 97在线看片 | 国产精品 中文字幕 亚洲 欧美 | 亚洲综合激情 | 亚洲精品99久久久久久 | 美女国产 | 国产日韩在线观看一区 | 成人久久精品 | 国产69熟| 国产精品一区二区精品视频免费看 | 黄网站色成年免费观看 | 人人澡av | 最新av在线免费观看 | 欧美激情视频一区二区三区免费 | 亚洲 综合 激情 | 国产成人精品一区二区三区在线观看 | 97色在线视频 | 国产精品综合在线观看 | 国产色在线,com | 欧洲激情综合 | 亚洲精品乱码久久久久久蜜桃动漫 | 久久久精品亚洲 | 99视频免费 | 亚洲最新av在线 | 国产剧情av在线播放 | 国产vs久久| 国产成人在线一区 | 81国产精品久久久久久久久久 | 一区二区视频在线观看免费 | 午夜骚影 | 伊人五月 | 日韩欧美不卡 | 国产女v资源在线观看 | 91成人在线看 | 国产精品九九九九九九 | 久日精品| 欧美日韩另类视频 | 亚洲精品在线观 | 91精品国产乱码久久 | 国产日韩精品在线 | 免费亚洲视频 | 91亚洲精品在线 | 中文字幕不卡在线88 | 亚洲综合激情小说 | 涩涩网站在线观看 | 色视频国产直接看 | 少妇精69xxtheporn | 日韩精品一区二区在线观看 | 婷婷在线网站 | 激情电影在线观看 | 密桃av在线 | 精品亚洲成a人在线观看 | 欧美与欧洲交xxxx免费观看 | 久久狠狠亚洲综合 | 亚洲免费a| 婷婷综合亚洲 | 婷婷色av | 国产美女精品视频 | av再线观看| 午夜精品久久久久久久爽 | 成人在线视频一区 | www.夜夜草 | a国产精品 | 91成人精品一区在线播放69 | 久久久久久久久久久久久久av | 久久人人看 | 午夜91视频 | 欧美动漫一区二区三区 | 免费看的毛片 | 美女视频一区二区 | 91亚洲成人 | 国产精品综合av一区二区国产馆 | 精品欧美一区二区三区久久久 | 国产中文字幕视频在线观看 | 四虎影视成人永久免费观看视频 | 日b黄色片 | 最近的中文字幕大全免费版 | 日本在线视频一区二区三区 | 国产五十路毛片 | 亚洲综合激情 | 国产黄色片一级三级 | 久久精品国产精品亚洲 | av黄色影院 | 久日精品 | 成年人黄色免费看 | 99久久国产免费免费 | 成人国产精品 | 欧美久久电影 | 99热国产精品 | 精品成人久久 | 国产一区播放 | 欧美日韩国产免费视频 | 99婷婷狠狠成为人免费视频 | 中文字幕一区二区三区精华液 | 探花系列在线 | 国产视频一区在线播放 | 在线观看免费黄视频 | 国产不卡视频在线 | 天天干天天插伊人网 | 欧美a级片免费看 | 国产综合在线视频 | 精品一二三区视频 | 日本中文字幕电影在线免费观看 | 丁香婷婷深情五月亚洲 | 国产麻豆视频网站 | 欧美性精品 | 激情影院在线观看 | 欧美久久久久久久久中文字幕 | 久久免费视频2 | 国产91精品看黄网站在线观看动漫 | 视频一区视频二区在线观看 | 亚洲精品国产综合久久 | 成年人免费电影在线观看 | 欧美日韩成人一区 | 日韩在线高清免费视频 | 久久亚洲成人网 | 美女视频久久久 | 99久久久久久 | 99热精品在线观看 | 免费网站黄 | 国内视频一区二区 | 国产视频久久久久 | 日本三级在线观看中文字 | 99re中文字幕| 在线观看国产永久免费视频 | 中文字幕在线看视频 | 亚洲另类视频在线 | 日韩电影精品一区 | 五月婷婷一区二区三区 | www激情网 | 成人av在线看 | 天天色天天射天天综合网 | 成人网444ppp| 日韩v欧美v日本v亚洲v国产v | 日韩免费在线一区 | 国产美女无遮挡永久免费 | 国产在线精品区 | 日韩激情综合 | 国产精品一区免费在线观看 | 超碰97公开 | 午夜av免费在线观看 | 国产亚洲精品久久久久久电影 | 中文资源在线播放 | 色狠狠操 | 麻豆视频免费看 | www.久久色| 免费福利视频网站 | 在线 精品 国产 | 深爱婷婷网| 国产精品久久久久久a | 麻豆免费精品视频 | 亚洲伊人第一页 | av福利电影 | 超碰99人人| 在线国产一区二区 | 久草在线最新免费 | 久久久久久久久精 | 中文字幕视频免费观看 | 五月天欧美精品 | 天天透天天插 | 日韩av视屏 | 亚洲aⅴ一区二区三区 | 国内精品久久久久久中文字幕 | 四虎在线永久免费观看 | 丝袜美腿在线视频 | 热久久国产精品 | 色狠狠狠 | 免费视频久久久久 | 国产欧美在线一区二区三区 | 国产成人精品一区二区在线观看 | 免费看污黄网站 | 久久欧美在线电影 | 精品999在线观看 | 欧美最新大片在线看 | 91丨九色丨国产在线观看 | 欧美一二区视频 | 99re中文字幕 | 欧美日韩视频在线一区 | 日韩欧美在线视频一区二区 | 丁香婷婷色综合亚洲电影 | 婷五月天激情 | 美女视频永久黄网站免费观看国产 | 超碰在线亚洲 | 精品1区2区3区| 狠狠的操狠狠的干 | 国产精品毛片一区二区 | 69精品视频 | 正在播放国产一区二区 | 欧美久久久 | 成人国产精品免费观看 | 午夜久久福利视频 | 欧美日韩国产精品一区二区三区 | 日韩69视频 | 91麻豆免费看 | 成人国产精品 | 国产在线超碰 | 五月婷婷丁香激情 | 日韩,中文字幕 | 亚洲视频六区 | 五月天亚洲综合 | 精品久久毛片 | 91成人精品一区在线播放69 | 国产精品 中文字幕 亚洲 欧美 | 久久这里精品视频 | 亚洲国产高清在线 | 国产精品视频999 | 国产精品第10页 | 在线观看国产高清视频 | 亚洲国产免费看 | 在线观看国产日韩欧美 | 国产在线精品播放 | 黄色网大全 | 91在线九色 | 欧美日韩一区二区久久 | 午夜体验区 | 欧美激情第28页 | 亚洲另类久久 | 国产在线精品一区二区不卡了 | 久久 地址| 在线视频麻豆 | 五月天九九 | 在线一二区 | 亚洲永久国产精品 | 五月婷在线播放 | 中文字幕在线成人 | 欧美一级小视频 | 日韩精品你懂的 | 97在线视 | 伊人网av | 久久精品久久久久电影 | 日韩欧美在线视频一区二区三区 | av字幕在线 | 亚洲视频在线免费看 | 欧美日韩性生活 | 国产无套视频 | www国产亚洲精品久久麻豆 | 亚洲精品视频二区 | 日韩三级在线 | 丁香婷婷自拍 | 9992tv成人免费看片 | 久久国产精品第一页 | 天天插天天狠 | 国产精品美女毛片真酒店 | 亚洲精品视频大全 | 中文字幕色播 | 中文久草 | 久久超碰在线 | 亚洲国产精品500在线观看 | 日韩av成人 | www亚洲一区 | 婷婷激情网站 | 久久99精品久久久久久三级 | 日本久久综合视频 | 日韩欧美国产成人 | 亚洲自拍偷拍色图 | 中文字幕一区二区三区在线视频 | 最新99热 | 人人看黄色 | www.少妇| 亚洲国产中文字幕在线 | 久久久久久久久久久国产精品 | 伊人五月 | 久久综合加勒比 | 99精品视频在线观看播放 | 欧美一级乱黄 | 精品久久久久久久 | 国产精品成人一区二区三区吃奶 | 97在线观看免费 | 伊人国产女 | 国内99视频 | 免费裸体视频网 | 久久av在线 | 91九色精品国产 | 国产成人精品综合久久久 | 在线观看一 | 国产一级性生活 | 色五月成人 | 色综合婷婷久久 | 国产乱视频| 一区二区影视 | 一区二区三区在线免费播放 | 黄色影院在线免费观看 | 国产精品永久久久久久久久久 | 在线一二区 | 视频在线99re | 婷婷av网| 91精品国产福利在线观看 | 美女视频黄免费 | 国产免费高清视频 | 欧美性生爱 | 福利av影院| 夜夜骑日日操 | 日日碰狠狠添天天爽超碰97久久 | 国产成人av电影在线 | 亚洲涩涩网站 | 天天色播 | av免费成人 | 97干com| 久久艹精品 | 日韩电影精品一区 | 视频一区视频二区在线观看 | 久久精品123 | 国产亚洲视频在线 | 五月婷婷丁香 | www.com黄色 | 国产在线更新 | 九九热免费视频在线观看 | 99在线观看视频网站 | 亚洲精品乱码久久久久久蜜桃不爽 | 国产日韩精品一区二区三区在线 | 久久免费视频一区 | 五月av在线 | 青青河边草免费观看完整版高清 | 亚洲精品在线免费观看视频 | 国产精品国产三级国产aⅴ9色 | 免费国产ww| 999超碰| 久久国产精品久久久久 | 91亚洲精品国偷拍自产在线观看 | 国产一级在线观看视频 | 日韩在线观看视频中文字幕 | 国产精品久久99 | 日韩一区二区三免费高清在线观看 | 久久97精品 | 在线电影中文字幕 | 国产精品一区二 | 天堂在线一区二区三区 | 肉色欧美久久久久久久免费看 | 天天躁日日躁狠狠躁 | 亚洲欧美视频一区二区三区 | 成人av观看| 免费看成人a | 国产精品va在线播放 | 超级碰99| 麻豆视频免费观看 | 少妇搡bbbb搡bbb搡69 | 日韩成人免费电影 | 日本mv大片欧洲mv大片 | 九九免费精品视频在线观看 | 久久福利 | 五月婷香蕉久色在线看 | 一级国产视频 | 日韩电影一区二区三区在线观看 | 91插插影库 | 国产精品免费麻豆入口 | 在线观看成人 | 蜜臀久久99精品久久久无需会员 | 999色视频 | 亚洲蜜桃av | 色七七亚洲影院 | 欧美午夜视频在线 | 99婷婷狠狠成为人免费视频 | 美女视频黄色免费 | 国产在线不卡一区 | 久久九精品 | 国产精品网红直播 | 美国三级黄色大片 | 国产我不卡 | 伊人婷婷在线 | 成人精品国产免费网站 | 国产一区免费视频 | 国产日韩精品一区二区在线观看播放 | 免费a v网站 | 久久免费成人精品视频 | 久久免费视频这里只有精品 | 国产最新视频在线观看 | 欧美日韩免费在线视频 | 欧美日韩精品在线观看 | 日韩av在线资源 | 久草在线中文视频 | 操操操操网 | 国产手机精品视频 | 国产在线观看二区 | 四虎4hu永久免费 | 最近中文字幕mv免费高清在线 | 欧美一区二区在线免费看 | 在线视频欧美日韩 | 久久精品中文视频 | 国产成人一区二区三区在线观看 | 久久久久久久免费 | 一区二区三区日韩在线 | 一区二区三区在线不卡 | 久久亚洲私人国产精品va | 色99视频 | 人人澡人人爱 | 日本中文字幕影院 | 免费成人av在线看 | 国产精品久久婷婷六月丁香 | 婷婷中文字幕综合 | 亚洲闷骚少妇在线观看网站 | 久久久精选 | 97人人爽 | 天天射天天干 | 麻豆免费在线视频 | 久久 在线 | 麻豆视频免费在线播放 | 国产午夜精品久久 | 久久成年人网站 | 国产黄色片免费在线观看 | a色视频 | 国产精品自产拍在线观看蜜 | 天天综合网久久 | 亚洲午夜精品电影 | 婷婷伊人综合亚洲综合网 | 久久免费视频这里只有精品 | 91麻豆精品国产91久久久无限制版 | 91成人精品 | 免费国产在线精品 | 日本午夜免费福利视频 | 免费看片黄色 | 色婷婷av国产精品 | 亚洲天天| 高清av网站 | 成人一区二区在线观看 | 99久久精品免费看国产四区 | 久久久久免费精品国产小说色大师 | 国产亚洲视频在线免费观看 | 亚洲精品国产自产拍在线观看 | av黄色国产 | 国产18精品乱码免费看 | 国产免费嫩草影院 | 国产精品 亚洲精品 | 一区二区三区福利 | av网站地址 | 亚洲第一区精品 | 国产资源免费 | 天天夜夜亚洲 | 97电影在线观看 | 欧美 另类 交 | www.com久久久| 麻豆影视在线免费观看 | 久草久 | 一区二区免费不卡在线 | 久久精品激情 | 亚洲最大免费成人网 | 手机看片午夜 | 黄毛片在线观看 | 日韩黄色一区 | 性色av一区二区三区在线观看 | 99久久精品国产欧美主题曲 | av高清一区二区三区 | 久久 一区 | 97在线免费视频观看 | 在线视频 精品 | 美女视频永久黄网站免费观看国产 | 亚洲成人软件 | 91在线视频免费 | 国产精品综合在线观看 |